Giáo trình Vận trù học (Phần 1)

Vận trù học (Operations Research) được xem là một công cụ định lượng nền tảng

của Khoa học quản lí mà trong đó các phương pháp và kĩ thuật của Toán học và các

công cụ tính toán, lưu trữ và xử lí dữ liệu của Tin học được áp dụng để mô hình hóa,

phân tích và tìm ra lời giải cho các bài toán quyết định, nhằm hỗ trợ bộ máy quản lí

đưa ra các quyết định hợp lí nhất. Trên thế giới việc nghiên cứu và ứng dụng Vận trù

học ngày càng phát triển sâu rộng với nhiều tạp chí chuyên ngành nổi tiếng, môn Vận

trù học được giảng dạy với thời lượng khá lớn bao gồm nhiều nội dung phong phú và

cấp thiết trong nhiều chương trình đào tạo đại học và cao học.

pdf98 trang | Chia sẻ: phuongt97 | Lượt xem: 1160 | Lượt tải: 0download
Bạn đang xem trước 20 trang nội dung tài liệu Giáo trình Vận trù học (Phần 1), để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
5 = 0 v4 = 3 u1 = −4 3 2000 2 4000 7 6 0 6000 u2 = 0 7 1500 5 (−1) 2 2000 3 1500 0 2000 7000 u3 = −5 2 2500 5 4 5 0 2500 6000 4000 2000 1500 (2000) Kết quả tính toán các số thế vị được cho trong bảng III.10. Phương án tìm được chưa phải phương án tối ưu do e22 = 5 −(0 + 6) = −1. Chuyển sang phương án mới trong bảng III.11, với tổng cước phí vận tải là 38000 − 1500 = 36500. Sau khi tính giá trị các thế vị và kiểm tra điều kiện tối ưu eij < 0, ∀ ô (i, j) chưa sử dụng, chúng ta kết luận là đã tìm được phương án vận tải tối ưu. Số hàng nằm trong ô giả (2, 5) là số hàng dư ra tại địa điểm cung thứ hai. Bảng III.11. Phương án vận tải tối ưu v1 = 6 v2 = 5 v3 = 2 v5 = 3 v4 = 0 u1 = −3 3 3500 2 2500 7 6 0 6000 u2 = 0 7 5 1500 2 2000 3 1500 0 2000 7000 u3 = −4 2 5 4 5 0 2500 Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 66 2500 6000 4000 2000 1500 (2000) Giải bài toán vận tải bằng phần mềm Lingo Để giải bài toán vận tải trong Lingo, ta có thể sử dụng các bài toán mẫu. Hình III.1. Nhập số liệu cho bài toán vận tải Muốn làm điều đó, ta cần nhấn vào biểu tượng Lingo trên màn hình và thực hiện các lệnh File > Open > Tran.lng để vào bài toán vận tải mẫu. Sau đó nhập các số liệu đầu vào của bài toán cần giải, chẳng hạn, của ví dụ đã xét trong các mục trên thay cho các số liệu của bài toán mẫu (xem hình III.1). Sau đó chúng ta thực hiện LINGO>Solve, kết quả tính toán sẽ hiện ra trên màn hình (xem hình III.2). Hình III.2. Kết quả của bài toán vận tải 2. MÔ HÌNH MẠNG PERT (Program Evaluation and Review Technique) 2.1. Các khái niệm cơ bản về PERT Vai trò của PERT PERT có thể được hiểu là phương pháp hoặc kĩ thuật theo dõi và đánh giá dự án với mục đích giúp cho bộ máy quản lí trả lời các câu hỏi sau đây: − Dự án sẽ hoàn thành khi nào? − Mỗi hoạt động của dự án nên được bắt đầu vào thời điểm nào và kết thúc vào thời điểm nào? − Những hoạt động nào của dự án phải kết thúc đúng thời hạn để tránh cho toàn bộ dự án bị kết thúc chậm hơn so với kế hoạch? − Liệu có thể chuyển các nguồn dự trữ (nhân lực, vật lực) từ các hoạt động “không găng” sang các hoạt động “găng” (các hoạt động phải hoàn thành đúng tiến độ) mà không ảnh hưởng tới thời hạn hoàn thành dự án? − Những hoạt động nào cần tập trung theo dõi? Để bước đầu hình dung về PERT, chúng ta xét ví dụ sau đây. Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 68 Ví dụ 1: Giả sử cần thực hiện một dự án hoặc chương trình có các hoạt động được liệt kê trong bảng III.12. Bảng III.12. Các hoạt động của một dự án, thứ tự và thời gian thực hiện Hoạt động Hoạt động kề trước Thời gian thực hiện (tuần) A B C D E F G H I J K L − − − A A E B B D, F C H, J G, I, K 2 2 2 3 4 0 (hoạt động giả) 7 6 4 10 3 4 Ta cần lập kế hoạch thực hiện dự án trên để hoàn thành toàn bộ các hoạt động của dự án trong thời gian ngắn nhất, đồng thời phải xác định được những hoạt động nào cần chú trọng (được hiểu là các hoạt động “găng”). Vẽ sơ đồ mạng PERT Hình III.3. Sơ đồ mạng PERT Trên hình III.3 ta thấy mạng PERT là một mạng các nút có đánh số được nối với nhau bởi các cung có mũi tên. Mỗi cung có mũi tên biểu diễn một hoạt động của dự án, còn mỗi nút biểu diễn thời điểm kết thúc một số hoạt động và/hoặc thời điểm bắt đầu của một số hoạt động khác. Hoạt động giả F được kí hiệu bởi cung mũi tên với nét rời có thời gian thực hiện bằng 0, nhằm tránh cho hoạt động D và E có cùng nút bắt đầu và nút kết thúc. Như vậy, 3 1 9 2 4 5 7 6 8 B A D C E H G K I J F L trong sơ đồ mạng PERT ta buộc phải tuân theo quy ước: hai hoạt động khác nhau thì không được có cùng nút bắt đầu cũng như nút kết thúc. Xác định thời gian tối thiểu thực hiện dự án Để xác định thời gian tối thiểu thực hiện dự án, trước hết chúng ta nghiên cứu khái niệm thời điểm bắt đầu sớm nhất và thời điểm kết thúc sớm nhất (EST và EFT − Earliest start time và Earliest finish time) cho từng hoạt động. Ví dụ 2: Hoạt động A có ESTA = 0 và EFTA = 2, vì − Thời điểm bắt đầu sớm nhất là khi bắt đầu khởi động dự án, − Thời điểm kết thúc sớm nhất là sau 2 tuần. Mối quan hệ giữa EST và FFT là: EFT = EST + thời gian thực hiện hoạt động. Một cách tổng quát, để xác định EST chúng ta có quy tắc “thời điểm bắt đầu sớm nhất”: thời điểm bắt đầu sớm nhất của một hoạt động rời một nút nào đó là thời điểm muộn nhất trong các thời điểm kết thúc sớm nhất đối với các hoạt động đi vào nút đó. Áp dụng quy tắc trên đây, có thể tính được ESTK = 12 (do EFTH = 8, EFTJ = 12 và số lớn hơn là 12) và EFTK = 15. Kết quả tìm EST và EFT cho các hoạt động dự án được tính toán tiến từ nút 1 đến nút 9 và được tóm tắt trong bảng III.13 và hình III.4. Vậy thời gian kết thúc sớm nhất dự án là sau 19 tuần. Bảng III.13. Tính EST, LST, EFT, LFT và tìm đường găng Hoạt động EST LST EFT LFT LST−EST (LFT−EFT) Trên cung găng A B C D E F G H I J K L 0 0 0 2 2 6 2 2 6 2 12 15 5 4 0 8 7 11 8 6 11 2 12 15 2 2 2 5 6 6 9 8 10 12 15 19 7 6 2 11 11 11 15 12 15 12 15 19 5 4 0 6 5 5 6 4 5 0 0 0 * * * * 3 1 9 2 4 5 7 6 8 B A D C F E H G K I J L 2 0 2 5 20 2 6 6 6 2 12 0 2 2 2 9 6 10 15 12 19 15 8 Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 70 Hình III.4. Tính EST và EFT cho các hoạt động của dự án Bước tiếp theo là xác định thời điểm bắt đầu muộn nhất và thời điểm kết thúc muộn nhất (LST và LFT − Latest start time và Latest finish time) cho từng hoạt động. Ví dụ 3: Hoạt động L có LSTL = 15 và LFTL = 19, vì − Thời điểm kết thúc muộn nhất là sau 19 tuần (nếu ta ấn định dự án phải kết thúc sau 19 tuần), − Thời điểm bắt đầu muộn nhất là tuần 15 (do hoạt động L cần thời gian 4 tuần để thực hiện). Mối quan hệ giữa LST và LFT là: LST = LFT − thời gian thực hiện hoạt động. Một cách tổng quát, để xác định LFT chúng ta có quy tắc “thời điểm kết thúc muộn nhất”: thời điểm kết thúc muộn nhất của một hoạt động đi vào một nút nào đó là thời điểm sớm nhất trong các thời điểm bắt đầu muộn nhất đối với các hoạt động rời nút đó. Áp dụng quy tắc trên đây, có thể tính được LFTA = 7 (do LSTD = 8, LSTE = 7 và số bé hơn là 7) và LSTA = 5. Kết quả tìm LFT và LST cho các hoạt động dự án được tính toán lùi từ nút 9 về nút 1 và được tóm tắt trong bảng III.11 và hình III.5. 3 1 9 2 4 5 7 6 8 B A D C F E H G K I J L 7 5 8 11 6 4 7 11 11 11 2 12 0 8 2 6 15 11 15 15 12 19 15 12 Hình III.5. Tính LFT và LST cho các hoạt động của dự án Chú ý: Mỗi cung có mũi tên là một hoạt động, nhưng có thể bao gồm nhiều hoạt động nhỏ khác. Nói cách khác, bản thân từng hoạt động của dự án có thể lại là một mạng PERT nhỏ. Xác định hoạt động găng, đường găng Hoạt động găng là hoạt động mà LST - EST = LFT - EFT = 0, hay [EST, EFT] ≡ [LST, LFT] ⇔ EST LST EFT LFT =⎧⎨ =⎩ ⇔ Slack LST EST 0 Slack LFT EFT 0 = − =⎧⎨ = − =⎩ (độ trễ cho phép bằng 0). Giải thích: Slack ≡ độ nới lỏng (độ trễ). Trong ví dụ đang xét, các hoạt động găng là: C → J → K → L (xem bảng II.14) và tạo thành đường găng (Critical Path). Vì vậy, phương pháp mạng PERT còn có tên là phương pháp đường găng (CPM − Critical Path Method). Xác định đường găng bằng phần mềm Lingo Để xác định đường găng bằng phần mềm Lingo, ta có thể sử dụng các bài toán mẫu bằng cách nhấn vào biểu tượng Lingo và thực hiện các lệnh File > Open > Pert.lng để vào bài toán PERT mẫu. Sau đó nhập các số liệu đầu vào của bài toán cần giải vào thay các số liệu của bài toán mẫu, chẳng hạn như số liệu của ví dụ đã cho (xem hình III.6). Hình III.6. Nhập số liệu cho bài toán PERT Sau đó chúng ta thực hiện LINGO > Solve, kết quả tính toán sẽ hiện trên màn hình (xem hình III.7). Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 72 Hình III.7. Kết quả tìm cung găng của bài toán PERT 2.2. Sơ đồ PERT với số liệu ngẫu nhiên Thời gian thực hiện từng hoạt động của dự án nói chung là một lượng biến động khó dự đoán trước, chúng ta giả thiết chúng là các biến ngẫu nhiên. Giả sử ta có các số liệu ước tính về thời gian thực hiện các hoạt động của dự án (xem bảng III.14) a, m, b. Lúc đó thời gian trung bình và độ lệch chuẩn thời gian thực hiện các hoạt động được ước tính theo công thức a 4m bt 6 + += . Bảng III.14. Số liệu ước tính về thời gian thực hiện các hoạt động Thời gian ước tính Hoạt động Hoạt động kề trước a (sớm nhất) m (nhiều khả năng xảy ra nhất) b (muộn nhất) t (thời gian trung bình) σ (độ lệch tiêu chuẩn, độ biến thiên) A B C D E F G H I J − − − A A E B B D, F C 1 1 1 1 2 0 3 2 1 4 2 2 2 2 3 0 6 5 4 9 3 3 3 9 10 0 15 14 7 20 2 2 2 3 4 0 7 6 4 10 1/3 1/3 1/3 4/3 4/3 0 2 2 1 8/3 K L H, J G, I, K 1 4 2 4 9 4 3 4 4/3 0 Bước tiếp theo là lập sơ đồ mạng cho dự án với các thời gian trung bình t và tìm đường găng. Đường găng là C → J → K → L bao gồm các hoạt động găng C, J, K và L. Các hoạt động này có độ trễ cho phép bằng 0, hay nói cách khác, không cho phép sự chậm trễ nào. Đây là các hoạt động cần hết sức chú trọng, việc chậm thực hiện bất cứ một hoạt động nào trong số này đều kéo theo sự chậm trễ trong tiến độ của cả dự án. Từ Critical Path (tiếng Anh) được dịch sang tiếng Việt là đường găng vì lí do đó. Thời gian thực hiện dự án là một lượng ngẫu nhiên tính theo công thức: T = TC + TJ + TK + TL. Ta tìm kì vọng của T (thời gian trung bình thực hiện dự án) theo công thức: m = mT = tC + tJ + tK + tL = 2 + 10 + 3 + 4 = 19 (tuần). Tính độ lệch chuẩn của thời gian thực hiện dự án: 2 2 22 T C J K Lσ = σ = σ + σ + σ + σ = 2 2 2(1/ 3) (8 / 3) (4 / 3) 0+ + + = 3. Ta coi T (thời gian thực hiện dự án) là biến ngẫu nhiên tuân theo luật chuẩn N(m = 19; σ = 3). Đồ thị hàm mật độ xác suất của T cho trên hình III.8. Để tính P, xác suất thực hiện dự án trong vòng (không vượt quá) 19 tuần, ta phải quy T về biến ngẫu nhiên với phân phối chuẩn tắc N(0, 1) như cho trong phụ lục 1. Lúc đó: P(T ≤ 19) = P T m 19 19 3 − −⎛ ⎞≤⎜ ⎟σ⎝ ⎠ = P(Z ≤ 0) = 0,5 (hay 50%), ở đây Z = (T - m)/σ là biến ngẫu nhiên tuân theo phân phối N(0, 1). 21 19 t Hình III.8. Đường cong mật độ chuẩn 75% Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 74 Tương tự, xác suất thực hiện dự án trong vòng (không vượt quá) 21 tuần được tính như sau: P(T ≤ 21) = P T m 21 19 3 − −⎛ ⎞≤⎜ ⎟σ⎝ ⎠ = P (Z ≤ 0,666) = 75%. Ta chuyển sang xem xét vấn đề về độ tin cậy của thời gian hoàn thành dự án. Chẳng hạn chúng ta muốn trả lời câu hỏi sau: Muốn thời gian thực hiện dự án có độ tin cậy 90% thì thời gian tối thiểu (tính theo số tuần) là bao nhiêu? Đặt P (T ≤ t) = 90%. Tra bảng phân phối chuẩn tắc N(0, 1), tìm được z = 1,28. Vì z = (t − 19)/3 = 1,28 nên t = 19 + 3. 1,28 ≈ 23 (tuần). Như vậy, dự án đang xem xét có khả năng hoàn thành với độ tin cậy tới 90% trong vòng (không vượt quá) 23 tuần. 2.3. Điều chỉnh dự án khi kế hoạch một số hoạt động bị phá vỡ Ví dụ 4: Đôi khi trong quá trình thực hiện dự án, kế hoạch của một số hoạt động bị phá vỡ. Chính vì vậy, khi phát hiện dự án đang bị chậm so với kế hoạch đề ra ta cần định lại thời gian thực hiện (thời gian rút gọn) một số hoạt động trong giai đoạn tới. Xét các dữ kiện cho trong hình III.9 và bảng III.15. Bảng III.15. Số liệu điều chỉnh khi kế hoach bị phá vỡ Hoạt động Thời gian định mức Thời gian rút gọn Kinh phí bổ sung/1đơn vị thời gian rút gọn (triệu đồng) A B C D E 6 4 3 8 7 4 3 2 6 4 2 3 1 1,5 0,5 Sau khi có thời gian định mức cho các hoạt động như trong bảng II.18, dễ dàng tìm được thời gian tối thiểu cần thiết để hoàn thành kế hoạch là 16 (tuần). Tuy nhiên do yêu 2 1 3 4 5 A C D B E Hình III.9. Sơ đồ mạng PERT dự án cần điều chỉnh cầu mới, cần rút gọn thời gian hoàn thành dự án trong vòng (không vượt quá) 10 (tuần). Muốn vậy ta thực hiện các điểm sau: − Tìm thời gian tối thiểu dự định thực hiện dự án (16 tuần) và tìm đường găng. − Ước tính thời gian rút gọn tối đa (cột 3, bảng III.15). − Khi rút gọn thời gian trên đường găng cũng phải chú trọng đồng thời các cung đường khác. Trên hình III.9, ta thấy cần thực hiện A, C và E với thời gian rút gọn tối đa (4, 2, 4 để tổng các thời gian thực hiện các hoạt động găng là 10 tuần), đồng thời rút gọn các hoạt động B và D ở mức cho phép: − Phương án 1: rút bớt thời gian thực hiện hoạt động B một tuần và rút bớt D một tuần. − Phương án 2: không rút bớt B và rút bớt D hai tuần. Vậy khi cần điều chỉnh thời gian thực hiện dự án ta cần thay đổi kế hoạch của một số hoạt động theo các bước đã nêu trên. Tuy có nhiều phương án điều chỉnh dự án, nhưng trong việc phá vỡ kế hoạch các hoạt động của dự án để đáp ứng tiến độ mới cần chú ý về khía cạnh chi phí gia tăng để có một phương án tối ưu đảm bảo rút gọn được thời gian thực hiện với chi phí nhỏ nhất. Đối với ví dụ trên ta chọn phương án 2. Có thể áp dụng phương pháp tổng quát để điều chỉnh dự án theo các mục tiêu ở trên (phương pháp đơn hình cho BTQHTT đơn và đa mục tiêu) như sẽ được trình bày sau đây. 2.4. Tính thời gian rút gọn tối ưu bằng phương pháp đơn hình Để tính thời gian rút gọn bằng phương pháp đơn hình (có thể sử dụng các phần mềm máy tính thích hợp), ta phải đưa ra được mô hình toán học, hay cách khác, cần phát biểu được BTQHTT (đơn hay đa mục tiêu). Trước hết, cần xác định các biến quyết định. Gọi x1, x2, x3, x4, x5 là các thời điểm mà các hoạt động xảy ra (tại các nút); yA, yB, yC, yD, yE là thời gian cần rút bớt cho các hoạt động để yêu cầu mới về đẩy nhanh tiến độ được thoả mãn. Ta có BTQHTT đa mục tiêu sau (cần cực tiểu hóa cả thời gian thực hiện dự án lẫn tổng chi phí gia tăng): Mục tiêu 1: z1 = x5 → Min Mục tiêu 2: z2 = 2yA + 3yB + yC + 1,5yD + 0,5yE → Min với các ràng buộc: Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 76 2 A 1 4 C 2 3 B 1 5 E 4 5 D 3 i j A B C D E 5 1 x 6 y x x 3 y x x 4 y x x 7 y x x 8 y x x 0,i 1, 2, 3, 4, 5 y 0, j A,B,C,D,E y 2, y 1, y 1, y 2, y 3 x x 10. (*) ⎧ ≥ − +⎪ ≥ − +⎪⎪ ≥ − +⎪ ≥ − +⎪⎪ ≥ − +⎨⎪ ≥ =⎪⎪ ≥ =⎪ ≤ ≤ ≤ ≤ ≤⎪⎪ ≤ +⎩ Có 2 cách giải mô hình: − Chuyển mục tiêu 1 thành ràng buộc (*). Nếu lúc đó BTQHTT không có phương án khả thi thì phải nới lỏng dần (*): chẳng hạn thay (*) bởi x5 ≤ x1 + 11. − Để nguyên cả hai mục tiêu để giải theo phương pháp BTQHTT đa mục tiêu. 2.5. Áp dụng mạng PERT trong phân tích chi phí và quản lí tài chính dự án Trong giai đoạn đầu ứng dụng PERT và CPM, các phương pháp này thường được áp dụng cho bài toán tìm thời gian tối thiểu thực hiện dự án, tìm các hoạt động găng. Chúng ít khi được áp dụng để phân tích chi phí, mặc dù trong các dự án thì việc phân tích chi phí (bao gồm chi phí trực tiếp, gián tiếp và chi phí tiện ích) cũng rất quan trọng. Tuy nhiên ngày nay, PERT và CPM được áp dụng rất rộng rãi cho các bài toán dạng này. Ví dụ 5: Chúng ta xem xét dự án với các dữ kiện cho trong bảng III.16 và hình III.10. Dễ thấy, thời gian tối thiểu để hoàn thành dự án là 15 (tháng). Bảng III.16. Dữ kiện cho bài toán PERT chi phí Hoạt động EST LST Thời gian thực hiện (tháng) Tổng chi phí (triệu đồng) Chi phí/một tháng (triệu đồng) A B C D E F G H I 0 0 3 3 7 4 4 12 5 0 8 9 3 7 10 10 12 11 3 2 1 4 5 2 1 3 4 30 200 40 20 75 100 75 18 240 10 100 40 5 15 50 75 6 60 2 1 8 3 6 4 5 B A D I G E C F H Hình III.10. Mạng PERT cho bài toán phân tích chi phí Nguyên tắc điều hành tài chính một dự án là: − Luồng kinh phí phải được đưa vào dần dần sao cho đáp ứng được tiến độ dự án. − Nếu kinh phí đưa vào thừa hoặc thiếu (theo tiến độ) thì phải kịp thời điều chỉnh. Cần nắm bắt được: những hoạt động nào không dùng hết kinh phí dự kiến, những hoạt động nào sử dụng kinh phí nhiều hơn dự kiến để có sự điều chỉnh thích hợp. − Các báo cáo định kì cho phép kiểm soát được dự án về tiến độ và luồng kinh phí. Muốn vậy, trước hết cần lập bảng theo dõi kinh phí cho dự án từ tháng 1 đến tháng 15 (xem bảng III.17). Phần trên của từng ô ứng với các hoạt động giải ngân sớm nhất, phần dưới ứng với giải ngân muộn nhất. Hai hàng cuối bảng dành cho kinh phí trong từng tháng và tổng kinh phí cộng dồn cho tới tháng đó tương ứng với hoạt động giải ngân sớm nhất và giải ngân muộn nhất. Bảng III.17. Dữ kiện cho bài toán PERT chi phí T. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 A 10 10 10 10 10 10 B 100 100 100 100 C 40 40 D 5 5 5 5 5 5 5 5 E 15 15 15 15 15 15 15 15 15 15 F 50 50 50 50 Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 78 G 75 75 H 6 6 6 6 6 6 I 60 60 60 60 60 60 60 60 Σ 110 10 110 10 10 10 45 5 130 5 115 5 65 5 75 15 75 115 15 155 15 140 15 125 6 66 6 66 6 66 Σ+ 110 10 220 20 230 30 275 35 405 40 520 45 585 50 660 65 735 180 750 335 765 475 780 600 786 666 792 732 798 798 Dựa vào bảng III.17, có thể vẽ được đồ thị miền kinh phí khả thi như trên hình III.11. Nếu tiến độ giải ngân nằm ngoài miền kinh phí khả thi thì cần gấp rút đưa ra các biện pháp điều chỉnh tiến độ giải ngân. Ngoài ra, cũng có thể điều chỉnh kinh phí các hoạt động của dự án dựa vào bảng III.17. Hình II.11. Đồ thị miền kinh phí khả thi Chú ý: Các vấn đề cơ bản cần giải quyết khi áp dụng phương pháp PERT hay CPM trong theo dõi và đánh giá dự án là: − Xác định được sơ đồ mạng PERT của dự án. − Tìm được đường găng và các hoạt động găng. đường giải ngân sớm nhất miền kinh phí khả thi đường giải ngân muộn nhất − Tính được độ tin cậy ứng với các mốc thời hạn hoàn thành dự án khi số liệu là ngẫu nhiên. − Biết cách điều chỉnh thời gian rút gọn khi tiến độ thực hiện dự án là chậm so với kế hoạch. − Phân tích chi phí và điều hành kinh phí dự án. 3. MỘT SỐ MÔ HÌNH MẠNG KHÁC 3.1. Bài toán cây khung tối thiểu Bài toán cây khung tối thiểu được nghiên cứu và ứng dụng trong nhiều lĩnh vực (Công nghệ thông tin, Điện lực, Quy hoạch thuỷ lợi,...). Vấn đề đặt ra là cần xác định một mạng đường đi tới mọi nút của mạng xuất phát từ một nút nào đó trong mạng, sao cho tổng độ dài các cung đường này là ngắn nhất. Phương pháp tốt nhất giải bài toán cây khung tối thiểu (minimal spanning tree) thuộc về R. Prim sẽ được trình bày trong mục này. Ví dụ 1: Mắc cáp truyền hình trong khu vực dân cư từ trạm phát đến được 7 hộ gia đình với chi phí đường dây là bé nhất. Sơ đồ khoảng cách từ trạm phát tới các hộ gia đình như trên hình III.12. Bài toán đặt ra là phải phát triển được cây khung hay đường đi tối thiểu sao cho tổng chiều dài các cung đường là bé nhất. Để giải ta lập bảng III.18 (chiều dài các cung đường được quy gọn), trong đó M là kí kiệu một số ≈ +∞, biểu thị cung đường không thể xảy ra trên thực tế. Mỗi hàng hay mỗi cột của bảng đều biểu thị các nút, chẳng hạn ô nằm trên giao của hàng 2 và cột 7 (cũng giống như ô nằm trên giao của hàng 7 và cột 2) đều chứa số 9, là khoảng cách giữa hai nút 2 và 7. Một hàng và một cột được nói là liên thông với nhau nếu ô nằm trên giao của hàng và cột này chứa giá trị khác M. Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 80 2 Nguån ®iÖn (1) 4 6 3 5 7 300 1000 100 500 800 200 1100 900 600 400 Hình III.12. Sơ đồ khoảng cách từ nguồn điện tới các xã Bảng III.18. Bảng khoảng cách các cung đường √ √ Nút (cột) (Nút hàng) 1 2 3 4 5 6 7 √ 1 0 11 1 3 6 10 4 2 11 0 M M M M 9 √ 3 1 M 0 M 5 M M √ 4 3 M M 0 M 7 M 5 6 M 5 M 0 2 M 6 10 M M 7 2 0 8 √ 7 4 9 M M M 8 0 Thuật giải Prim Bước khởi tạo. Lập bảng khoảng cách giữa các nút mạng. Trong bảng trên, chọn cột bất kì (ví dụ cột 1, tức là ta chọn nút 1 để bắt đầu), gạch bỏ cột vừa chọn ra khỏi bảng. Các bước lặp Bước 1: Đánh dấu vào hàng tương ứng (hàng cùng chỉ số) với cột vừa chọn. Trên các hàng đã được đánh dấu tìm ô có giá trị nhỏ nhất. Bước 2: Chọn cột tương ứng với ô vừa tìm được (cột 3 biểu diễn nút chọn mới, ghi cung đường vừa tìm được 1 → 3), rồi gạch bỏ nó đi (gạch bỏ cột 3). Nếu trong bảng vẫn còn các cột chưa gạch bỏ hết thì quay về bước 1, nếu trái lại chuyển sang bước kết thúc. Bước kết thúc. Nếu tất cả các cột đã bị gạch bỏ hết thì dừng với tất cả các cung đường liên thông tìm được tạo nên cây khung tối thiểu. Chú ý: Những câu in nghiêng minh hoạ cho bước khởi tạo và bước lặp đầu tiên. Sau 6 bước lặp, quá trình giải kết thúc với các cung đường sau: 1 → 3, 1 → 4, 1 → 7, 3 → 5, 5 → 6 và 7 → 2. Tổng độ dài các cung đường của cây khung tối thiểu là ∑ = 1 + 3 + 4 + 5 + 2 + 9 = 24. Ngoài ra, có thể chọn nút khởi tạo là bất cứ nút nào. Thuật toán Prim có thể được tóm tắt như sau: Gọi N0 là tập nút đã cho với các khoảng cách giữa các nút đã biết. Tại mỗi bước lặp, từ một tập nút N đã được lựa chọn từ N0 và một tập cung đường T đã có ở bước trước, cần tìm được nút tiếp theo trong tập N0\N sao cho khoảng cách ngắn nhất từ nút đó tới các nút trong tập N là bé nhất so với khoảng cách ngắn nhất từ một nút bất kì khác trong tập N0\N tới các nút trong tập N. Nút chọn được như vậy được đưa vào tập N, còn khoảng cách ngắn nhất tìm được tương ứng với một cung đường được đưa vào tập T. Quá trình được tiếp tục cho tới khi tập N trùng với tập N0, cây khung tối thiểu chính là tập T thu được. Thuật toán Prim còn được ứng dụng trong các bài toán xác định chi phí tối thiểu nhiều dạng khác. Trong ví dụ trên, tập N0 qua các bước lặp được phát triển như sau: {1}, {1, 3}, {1, 3, 4, 7}, {1, 3, 4, 7, 5}, {1, 4, 3, 7, 5}, {1, 4, 3, 7, 5, 6}, {1, 4, 3, 7, 5, 6, 2}. 3.2. Bài toán tìm đường đi ngắn nhất và quy hoạch động Bài toán tìm đường đi ngắn nhất Trong bài toán tìm đường đi ngắn nhất, chúng ta muốn xác định hành trình ngắn nhất từ một địa điểm xuất phát (điểm gốc) để đi tới điểm cần đến (điểm đích) trên một mạng liên thông. Để cho dễ hiểu, chúng ta xem xét ví dụ sau đây. Ví dụ 2: Bài toán người đi du lịch. Có một người đi du lịch, xuất phát từ nút 1 và kết thúc hành trình ở nút 10 theo hành trình trên hình III.13. 2 1 7 3 5 4 6 9 8 10 175 175 150 275 200 400 150 100 200 300 100 125 250 275 350 200 Hình III.12. Sơ đồ hành trình đường đi Trường Đại học Nông nghiệp Hà Nội – Giáo trình Vận trù học 82 Người du lịch xuất phát từ nút 1. Trong giai đoạn đầu anh ta chỉ được quyền (và bắt buộc) chọn một trong ba nút (thành phố) 2, 3, 4 để vào thăm quan. Giai đoạn tiếp theo, anh ta chỉ được chọn một trong ba nút 5, 6, 7 để du lịch. Trong giai đoạn tiếp nối, anh ta có quyền vào một trong hai nút 8 hoặc 9 trước khi kết thúc hành trình tại nút 10. Như vậy, trong mỗi giai đoạn người đi du lịch chỉ được quyền đi vào một thành phố (mỗi thành phố được coi là một trạng thái của giai đoạn đó). Hãy tìm cách xác định đường đi ngắn nhất từ nút 1 tới nút 10 thoả mãn các điều kiện đặt ra của bài toán. Nguyên tắc tối ưu Bellman trong quy hoạch động Sử dụng nguyên tắc tối ưu Bellman trong quy hoạch động để giải bài toán người du lịch, chúng ta chia bài toán thành nhiều giai đoạn, tức là thành nhiều bài toán nhỏ. Tại mỗi giai đoạn ta cần tìm phương án tối ưu là các phương án tốt nhất của tình trạng hiện có, xét trong mối quan hệ với các phương án tối ưu đã tìm được của các giai đoạn trước. Ta có thể giải quyết bài toán dần theo từng giai đoạn theo cách tính toán tiến hoặc tính toán lùi. Để giải bài toán này, ta áp dụng cách tính toán lùi (backward computing) với các kí kiệu và dữ kiện cho trong bảng III.19. Bảng III.19. Các giai đoạn của bài toán quy hoạch động Giai đoạn Đầu vào Đầu ra Đường đi tối ưu Khoảng cách tới đích Giai đoạn I 8 9 10 10 8 → 10 9 → 10 150 100 Giai đoạn II 5 6 7 8 9 5 → 8 6 → 9 7 → 8 400 300 275 Giai đoạn III 2 3 4 5 6 7 2 → 6 3 → 5 4 → 6 600 600 500 Giai đoạn IV 1 2 3 4 1 → 2 1 → 3 1 → 4 700 775 650 Giải thích: Sử dụng nguyên tắc tối ưu Bellman để tìm đường đi ngắn nhất từ nút 4 tới nút 10, chúng ta tìm được phương án

Các file đính kèm theo tài liệu này:

  • pdfgiao_trinh_van_tru_hoc_phan_1.pdf
Tài liệu liên quan