مسئله کمهزینهترین جریان
مسئله کمهزینهترین جریان، پیدا کردن کمهزینهترین راه فرستادن میزان مشخصی از جریان درون یک شبکه شاره است. حل این مسئله در زندگی روزمره کاربردهایی دارد از جمله شبکههای هزینهدار (مانند شبکههای مخابراتی) و همچنین در مواردی که تناسب آن با مسئله خیلی مشهود نیست، مانند تعیین محل قرارگیری انبارها.
تعریف
ویرایشیک شبکه شاره داریم که آن را با گراف جهتدار با مبدا و مقصد که در آن یال دارای ظرفیت ، جریان و هزینه میباشد، نشان می دهیم (اکثر الگوریتمهای کمهزینهترین جریان یال با هزینه منفی را پشتیبانی میکنند.) هزینه فرستادن این جریان است. شما باید جریان را از s به t بفرستید.
تعریف مسئله کمینه کردن هزینه کل جریان است:
با شرطهای زیر:
محدودیت ظرفیت: تقارن یکسویه: بقای جریان: جریان خواستهشده:
ارتباط با مسئلههای دیگر
ویرایشحالت دیگری از این مسئله پیدا کردن جریان بیشینهای است که بین جریانهای بیشینه کمترین هزینه را دارد که میتوان آن را مسئله کمهزینهترین بیشینه جریان نامید. این حالت در پیدا کردن کمهزینهترین تطابق بیشینه کاربرد دارد.
در بعضی راهحلها پیدا کردن کمهزینهترین بیشینه جریان ساده است. در غیر این صورت، میتوان از جستجوی دودویی روی استفاده کرد.
میتوان از مسئله کمهزینهترین گردش در حل این مسئله استفاده کرد. این کار با صفر قرار دادن کران پایین همهی یالها، اضافه کردن یک یال از مقصد به مبدا با ظرفیت و کران پایین و قرار دادن کل جریان برابر انجام میشود.
دو مسئله زیر حالات خاص این مسئله به شمار می آیند:
- اگر محدودیت ظرفیت برداشته شود، به مسئله یافتن کوتاهترین مسیر تبدیل میشود.
- اگر همه هزینهها صفر باشند، به مسئله بیشینه جریان تبدیل میشود.
راهحلها
ویرایشاز آنجایی که ما تابعی خطی را بهینه میکنیم و تمام شروط خطی اند، این مسئله با استفاده از برنامهریزی خطی قابل حل است.
علاوه بر آن الگوریتمهای ترکیبیاتی مختلفی نیز وجود دارند، برای بررسی جامع تر، [۱] را ببینید. تعدادی از آنها تعمیم الگوریتم بیشینه جریان هستند، بقیه روشهای کاملاً متفاوتی استفاده میکنند.
الگوریتمهای اساسی شناخته شده (حالتهای زیادی دارند):
- Cycle canceling یک روش کلی اولیه[۲]
- Minimum mean cycle canceling یک الگوریتم ساده قویا چندجملهای[۳]
- Successive shortest path and capacity scaling روشهای دوگانه که میتوان آنها را به عنوان تعمیمهای الگوریتم فورد–فالکرسون در نظر گرفت.[۴]
- Cost scaling یک روش اولیه-دوگانه، که حالت کلی الگوریتم ارسال-برچسب است.[۵]
- Network simplex حالت خاص برنامهریزی خطی غیر مرکب است که در زمان چندجملهای اجرا میشود.[۶]
- الگوریتم Out-of-kilter توسط D.R.Fulkerson
کاربرد
ویرایشکم وزن ترین تطابق بیشینه دو بخشی
ویرایشدر گراف دو بخشی ، میخواهیم تطابق بیشینه با کمترین هزینه را بیابیم. w: E → R را تابع وزن یالهای گراف در نظر بگیرید. هدف از مسئله کم وزنترین تطابق بیشینه دو بخشی یا مسئله تخصیص، پیدا کردن یک تطابق کامل M ⊆ E است که مجموع وزنهایش کمینه باشد. میخواهیم این مسئله را به یک مسئله شبکه شاره کاهش دهیم.
را در نظر بگیرید. ظرفیت تمام یالهای را 1 بگذارید. رأس مبدا را اضافه کرده و به تمام رئوس متصل میکنیم و رأس مقصد را اضافه کرده و تمام رئوس را به آن متصل میکنیم. ظرفیت تمام یالهای جدید را یک و هزینه آنها را صفر در نظر میگیریم. ثابت میشود که یک کم وزنترین تطابق دو بخشی در موجود است اگر و فقط اگر یک کم هزینهترین جریان در وجود داشته باشد.[۷]
جستارهای وابسته
ویرایشپانویسها و منابع
ویرایش- ^ Ravindra K. Ahuja, Thomas L. Magnanti, and James B. Orlin (1993). Network Flows: Theory, Algorithms, and Applications. Prentice-Hall, Inc. ISBN 0-13-617549-X.
{{cite book}}
: نگهداری یادکرد:نامهای متعدد:فهرست نویسندگان (link) - ^ Morton Klein (1967). "A primal method for minimal cost flows with applications to the assignment and transportation problems". Management Science. 14: 205–220.
- ^ Andrew V. Goldberg and Robert Tarjan (1989). "Finding minimum-cost circulations by canceling negative cycles". Journal of the ACM. 36 (4): 873–886.
- ^ Jack Edmonds and Richard M. Karp (1972). "Theoretical improvements in algorithmic efficiency for network flow problems". Journal of the ACM. 19 (2): 248–264.
- ^ Andrew V. Goldberg and Robert Tarjan (1990). "Finding minimum-cost circulations by successive approximation". Math. Oper. Res. 15 (3): 430–466.
- ^ James B. Orlin (1997). "A polynomial time primal network simplex algorithm for minimum cost flows". Mathematical Programming. 78: 109–129.