Bài viết này cần thêm chú thích nguồn gốc để kiểm chứng thông tin. |
Trong toán học, Bài toán vận tải (tiếng Anh: transportation problem) là một dạng của bài toán quy hoạch tuyến tính. Bài toán vận tải có thể biểu diễn như một đồ thị hai phía, có hướng. Nó có thể ứng dụng vào nhiều vấn đề khác nhau. Giải thuật đơn hình trên bài toán vận tải cũng đơn giản hơn. Bài toán được chính thức hóa lần đầu bởi nhà toán học người Pháp Gaspard Monge vào năm 1781.[1]
Giả sử có m kho hàng cùng chứa một loại hàng hóa, kho chứa tấn hàng. Cần vận chuyển số hàng trên đến n cửa hàng , cửa hàng cần số hàng . Cước phí vận chuyển một tấn hàng từ kho đến cửa hàng là . Hãy lập phương án vận chuyển sao cho tổng chi phí vận chuyển là nhỏ nhất.
Các kho hàng được gọi là các điểm phát, các cửa hàng được gọi là các điểm thu. Ví dụ: Có 3 điểm phát và 4 điểm thu, số hàng ở các điểm phát, nhu cầu ở các điểm thu, cước phí vận chuyển cho trong bảng sau:
Bảng trên đây được gọi là bảng vận tải.
Mỗi phương án vận chuyển là một ma trận X = , trong đó là số hàng hóa chuyển từ Ai đến Bj. ()
Chi phí vận chuyển của phương án X là:
Để một phương án thực sự là chấp nhận được cho bài toán vận tải, các giá trị phải thỏa mãn các ràng buộc đối với các điểm phát (ràng buộc dòng) là
và các ràng buộc với các điểm thu (ràng buộc cột)
Như vậy bài toán vận tải là bài toán QHTT dạng chính tắc với mn biến, hàm mục tiêu G(X) cần cực tiểu và m+n ràng buộc.
Giải thuật giải bài toán vận tải cũng là thuật toán đơn hình. Nó xuất phát từ việc chọn phương án đầu tiên rồi cải tiến dần cho đến khi đạt tối ưu.
Có một số phương pháp tìm phương án ban đầu.
Phương pháp này trước hết phân phối lượng hàng lớn nhất có thể được vào ô dầu tiên ở góc tây-bắc, nghĩa là ô (1,1), bằng cách đặt . Khi đó, hoặc điểm phát hết hàng, hoặc điểm thu hết nhu cầu, ta có thể loại điểm phát hoặc điểm ra khỏi bảng, rối lại tiếp tục phân phối cho ô tây bắc trong phần còn lại của bảng.
Với ví dụ cho ở trên ta có
Các số nhỏ ghi ở góc trên mỗi ô là cước phí vận chuyển mỗi đơn vị hàng hoá từ điểm phát thứ i đến điểm thu thứ j.
Khi đó tổng chi phí vận chuyển cho phương án này là:
Đây chưa phải là phương án tối ưu.
Ta cũng lần lượt phân phối vào các ô như trên nhưng tiêu chuẩn ưu tiên là cước phí nhỏ nhất trong những ô còn có thể phân phối.
Trong ví dụ trên
Tổng chi phí vận chuyển theo phương án này là:
Sau khi dùng một trong các phương pháp lập phương án ban đầu (ngoài hai phương pháp trên còn có một số phương pháp khác), trong các phương án nhận được ta được một số ô (i, j) có giá trị , các ô đó được gọi là các ô chọn, một số ô khác có được gọi là các ô tự do. Nếu viết lại hệ ràng buộc của bài toán vận tải như với bài toán quy hoạch tuyến tính tổng quát, các ô chọn trong các phương án ban đầu ứng với các ẩn cơ sở. Nếu phương án là không suy biến thì các ô tự do đều ứng với các ẩn tự do, nếu phương án là suy biến có thể có những ô tự do ứng với các ẩn cơ sở. Khi viết bài toán vận tải dưới dạng bài toán QHTT tổng quát, với điều kiện cân bằng cung cầu, hạng của hệ ràng buộc của BTVT m điểm phát, n điểm thu là r=m+n-1. Do vậy khi không suy biến một phương án (cơ sở) tạo ra từ một trong các phương pháp trên có đúng m+n-1 ô chọn là ô cơ sở, các ô còn lại là ô tự do.
Ta xem xét việc điều chỉnh một phương án cơ sở sẽ mang lại "lợi" hay "hại" cho giá thành vận chuyển. Giả sử trong một điều chỉnh nào đó một ô tự do được tăng thêm một lượng hàng h. Khi đó trong dòng phải có một ô nào đó giảm đi lượng h để tổng hàng hoá trong dòng không đổi, tiếp theo, hàng trong cột giảm đi tại thì phải tăng trong cùng cột tại dòng cùng cột ngiã là tại ô ,... sau một số hữu hạn bước, mỗi bước chuyển từ đi theo hàng sang đi theo cột ta quay về gặp ô cùng cột với ô đầu tiên, ô để giảm lượng hàng ở đó đi một lượng đúng bằng h, nghĩa là ta có một chu trình.
Định nghĩa
Một chu trình trong bảng vận tải là một dãy các ô trong đó ô đầu tiên và ô thứ hai nằm trên cùng một dòng, hai ô liên tiếp hoặc nằm trên cùng một dòng, hoặc cùng nằm trên một cột, ba ô liên tiếp không nằm trên cùng một hàng hoặc một cột, ô đầu tiên và ô cuối cùng nằm trên cùng một cột. Có thể viết dãy các ô trong chu trình như sau
Có thể hình dung chu trình là một đường đi khép kín qua các ô của bảng vận tải trong đó cứ mỗi lần qua một ô nó lại rẽ một góc .
Tính chất
Phương án cơ sở của BTVT là tối ưu khi và chỉ khi nó không có ô tự do với giá trị âm.
Phương pháp thế vị tính giá của ô tự do
Giá của các ô tự do có thể tính nhờ phương pháp thế vị như sau:
Đưa thêm m+n ẩn và .
Hệ m+n-1 phương trình với m+n-1 ô cơ sở có thể giải dễ dàng nhờ cho một ẩn, chẳng hạn . Khi đó giá của các ô tự do (i, j) được tính bằng công thức .