سیمپلکس دوگان – به زبان ساده
در آموزشهای پیشین مجله فرادرس، با روش سیمپلکس اولیه آشنا شدیم که در آن، ستون سمت راست (RHS) همیشه نامنفی بود و به همین دلیل جواب اساسی یا پایه در هر تکرار شدنی بود. همچنین، وقتی برخی عناصر منفی بودند، دیدم که جواب پایه نشدنی است. با توجه به این نکته، ما همیشه با جوابهای پایه شدنی سر و کار داشتیم. در الگوریتم سیمپلکس اولیه، برای پایان الگوریتم باید برخی عناصر در سطر منفی شوند تا شرایط بهینگی برقرار شود. در حالتی که همه عناصر این سطر نامنفی باشند، میگوییم پایه متناظر شدنیِ دوگان است. از طرف دیگر، اگر برخی عناصر سطر منفی باشند، یک پایه نشدنی دوگان داریم.همانطور که گفتیم، روش سیمپلکس اولیه با پایههای اولیه شدنی، اما دوگان نشدنی (غیربهینه) متناظر است. در جواب نهایی (بهینه)، پایه هم اولیه و هم دوگان، شدنی هستند. در این آموزش، یک رویکرد متفاوت، به نام روش «سیمپلکس دوگان» (Dual Simplex) یا سیمپلکس ثانویه بیان میکنیم که عکس روش اولیه کار میکند.
در روش سیمپلکس دوگان ، تا مرحله تکرار آخر، هر پایه آزمایش شده نشدنی اولیه (برخی عناصر سمت راست منفی) و شدنی دوگان (همه عناصر سطر نامنفی) است. در تکرار نهایی (بهینه)، هر دو جواب در اولیه و دوگان شدنی خواهد بود. در این فرایند، شدنی بودن دوگان را حفظ میکنیم و شدنی بودن اولیه را پیش میبریم. برای یک مسئله مشخص، هر دو الگوریتم سیمپلکس اولیه و ثانویه، علیرغم آنکه فرایند تکرار از مسیرهای متفاوتی انجام شده است، در جواب مشابهی خاتمه مییابند.
الگوریتم سیمپلکس دوگان اغلب برای مسائلی که در آنها یک جواب شدنی دوگان به راحتی در دسترس است، مناسب خواهد بود. این روش، به ویژه برای بازبهینهسازی یک مسئله پس از افزودن یک قید یا تغییر پارامتری که منجر به نشدنی بودن جواب قبلی میشود، مناسب است. در ادامه، خواهیم دید که الگوریتم سیمپلکس دوگان بسیار شبیه الگوریتم سیمپلکس اولیه است.
الگوریتم سیمپلکس دوگان
با توجه به ماتریس یا جدول سیمپلکس، الگوریتم باید با یک جواب پایه یا اساسی شروع شود که شدنی دوگان است، بنابراین، همه عناصر سطر باید نامنفی باشند. الگوریتم سیمپلکس اولیه یک متغیر را برای وارد شدن به پایه انتخاب میکند و آنگاه متغیری را که باید خارج شود پیدا میکند، به گونهای که شدنی بودن اولیه حفظ شود. روش سیمپلکس دوگان برخلاف این روش عمل میکند. در این روش، ابتدا یک متغیر برای خروج از پایه انتخاب میشود و آنگاه متغیری را پیدا میکند که باید وارد پایه شود تا شدنی بودن دوگان را حفظ کند. این موضوع، تفاوت اساسی بین این دو روش است. در الگوریتم زیر، فرض شده که یک جواب اساسی با یک جدول ارائه شده است.
گام اول (مقداردهی اولیه): با یک پایه شدنی دوگان شروع میکنیم و را در نظر میگیریم. جدولی برای این پایه به فرم سیمپلکس تشکیل میدهیم. اگر درایههای ستون سمت راست همه نامنفی باشند، جواب شدنی اولیه خواهد بود، بنابراین، توقف میکنیم و به جواب بهینه میرسیم.
گام دوم (تکرار ): این گام شامل سه مرحله است.
الف) یک متغیر خارج شونده انتخاب کنید. یک سطر با یک ثابت سمت راست منفی پیدا کنید و آن را بنامید،؛ یعنی . اکنون را به عنوان سطر لولا و را به عنوان متغیر خارج شونده در نظر بگیرید. یک قانون متداول برای انتخاب ، انتخاب منفیترین مقدار ستون سمت راست یا RHS است؛ یعنی:
ب) متغیر وارد شونده را تعیین کنید. برای هر ضریب منفی در سطر لولا، مقدار منفی نسبت بین هزینه کاهش یافته در سطر و ضریب ساختاری در سطر را محاسبه کنید. اگر ضریب منفی، یعنی وجود نداشت، توقف کنید، زیرا جواب شدنی وجود ندارد.
فرض کنید ستونی که با حداقل نسبت و با شاخص مشخص شده، ستون لولا باشد. همچنین متغیر ورودی است. ستون لولا با آزمون نسبت زیر تعیین میشود:
ج) پایه را تغییر دهید. را با جایگزین کنید. با انجام عملیات زیر یک جدول جدید ایجاد کنید (این موارد مشابه الگوریتم سیمپلکس ساده است).
را به عنوان بردار اُمین سطر جدول فعلی و را به عنوان اُمین سطر جدول جدید در نظر بگیرید. فرض کنید درایه سمت راست برای سطر در جدول فعلی و درایه سمت راست یا RHS برای جدول جدید باشد.
را به عنوان عنصر اُمین سطر ستون لولای در نظر بگیرید.
سطر لولا در جدول جدید به صورت زیر است:
سطرهای دیگر در جدول جدید برای به شکل زیر هستند:
این عملیات اثر قیمتگذاری ستون لولا را دارد. تعویض آن یک در سطر خواهد داشت و یک در سایر سطرهای دیگر مطابق فرم سیمپلکس.
گام سوم (آزمون امکانسنجی): اگر همه درایههای ستون سمت راست نامنفی باشند، جواب شدنی اولیه است، بنابراین، توقف کنید و جواب بهینه است. در غیر این صورت، را قرار دهید و به گام دوم بازگردید.
مثال روش سیمپلکس دوگان
سادهترین حالت زمانی رخ میدهد که یک پایه شدنی دوگان واضح وجود دارد و میتوان از آن برای مقداردهی اولیه الگوریتم سیمپلکس دوگان استفاده کرد. مسئله زیر را در نظر بگیرید.
میخواهیم تابع هدف زیر را کمینه کنیم:
با توجه به قیود زیر:
گام ۱: متغیرهای کمکی و را به دستگاه اضافه میکنیم که منجر به جدول نخست میشود که نشدنی اولیه است، اما شدنی دوگان است.
تکرار ۱: سطر ۲ به عنوان سطر لولا انتخاب میشود تا از پایه خارج شود. آزمون نسبت مشخص میکند که باید وارد پایه شود. شکل زیر جدول محاسبات نسبت را نشان میدهد.
پس از عملیات ارزشگذاری برای به دست آوردن فرم سیمپلکس برای ، جدول زیر را خواهیم داشت. آزمون امکانسنجی در گام ۳ با شکست مواجه میشود، زیرا پایه هنوز شدنی اولیه نیست، بنابراین، به گام ۲ بازمیگردیم. گامهای انتخاب سطر و ستون را برای تکرار بعدی نشان میدهیم.
تکرار ۲: سطر ۱ به عنوان لولا انتخاب میشود، بنابراین، پایه را ترک میکند و به آن وارد میشود. این امر به جدول زیر میانجامد که هنوز دارای یک مقدار RHS منفی است، بنابراین، به گام ۲ بازمیگردیم.
تکرار ۳: با انتخاب سطر ۲ به عنوان سطر لولا، از پایه خارج میشود و وارد میشود. جدول بهروز شده در ادامه نشان داده شده است که هم شدنی اولیه است و هم دوگان و مشخص میکند که جواب بهینه به دست آمده است. الگوریتم به پایان رسیده است.
تغییر ثوابت سمت راست
اکنون میخواهیم ببینیم که پس از تغییر ثوابت سمت راست، باید چگونه عمل کنیم. یکی از کاربردهای الگوریتم سیمپلکس دوگان بازبهینهسازی یک مسئله حل شده پس از تغییر یک یا چند ثابت سمت راست آن است. این موضوع در مثال زیر توضیح داده شده است. جدول بهینه نیز با ، و به عنوان متغیرهای کمکی نشان داده شده است.
مسئله زیر را در نظر بگیرید:
با تغییر ثوابت سمت راست، تنها درایههای ستون سمت راست جدول تغییر میکند. به ویژه، اگر را از به و را از به در مسئله اصلی تغییر دهیم، ستون RHS در جدول بالا برای پایه کنونی به صورت زیر در خواهد آمد:
در نتیجه، وقتی با جایگزین میشود، جدول زیر را خواهیم داشت که یک گزینه برای الگوریتم سیمپلکس دوگان است.
دقت کنید که در سطر ظاهر میشود و در سطر جدول است، زیرا سطر متناظر با و سطر متناظر با است.
تغییر مقادیر RHS اثری بر هزینههای کاهش یافته ندارد، بنابراین، درایههای سطر نامنفی باقی میمانند؛ البته مقدار منفی مشخص میکند که جواب پایه اکنون نشدنی است. از جدول واضح است که از پایه خارج شده و در تکرار بعد وارد میشود.
اضافه کردن قید
مسئله قبل را در نظر بگیرید. میخواهیم قید را به آن اضافه کنیم. جواب در جدول بهینه، یعنی و ، برای این قید برقرار نیست. بنابراین، باید آن را نیز به جدول وارد کنیم. ابتدا متغیر کمکی را از کم میکنیم تا تساوی زیر را به جای نامساوی داشته باشیم:
سپس آن را در ضرب میکنیم تا به فرم صحیح برسیم. سطری که متناظر با این قید است و ستونی که متناظر با متغیر کمکی است به جدول اضافه میکنیم و جدول زیر را خواهیم داشت.
برای بازیابی فرم سیمپلکس برای ستون ، باید سطر را به سطر اضافه کنیم. اکنون جدول به فرم سیمپلکس است.
همانطور که انتظار میرود، جواب شدنی دوگان است، اما شدنی اولیه نیست. تنها مقدار RHS منفی در سطر ظاهر میشود، بنابراین، باید پایه را ترک کند. متغیر ورودی تنها گزینه با درایه منفی در سطر لولا است. جدول بهینه به شکل زیر است.
با استفاده از نرمافزار اکسل میتوانید مسائل را به روش سیمپلکس به آسانی حل کنید. برای آشنایی با پیادهسازی روش سیمپلکس در اکسل، پیشنهاد میکنیم مطلب «سیمپلکس در اکسل — راهنمای کاربردی» را مطالعه کنید.
فیلم آموزش تحقیق در عملیات (برنامه ریزی خطی)
برای آشنایی بیشتر با روش سیمپلکس میتوانید به دوره ویدیویی «آموزش تحقیق در عملیات (برنامه ریزی خطی)» مراجعه کنید. این آموزش ۲ ساعت و ۴۶ دقیقهای، در ۵ درس ارائه شده است. در درس اول، مفاهیم برنامهریزی خطی و مدلسازی شرح داده شده است. درس دوم به معرفی روشهای حل مسائل برنامهریزی خطی اختصاص یافته است. موضوع درس سوم، جبر ماتریسی و سیمپلکس اصلاح شده است. در درس چهارم، دوگان مسائل برنامهریزی خطی به طور کامل توضیح داده شده است. در نهایت، تحلیل حساسیت و برنامهریزی پارامتریک در درس پنجم معرفی شده است.
- برای دیدن فیلم آموزش تحقیق در عملیات (برنامه ریزی خطی) + اینجا کلیک کنید.