برنامه ریزی خطی پیشرفته (21715) Advanced Linear Programming بنام خدا برنامه ریزی خطی پیشرفته (21715) Advanced Linear Programming Lecture 1 Introduction مدرس: ناصر سلماسی
برنامه ریزی خطی پیشرفته (21715) نام درس: برنامهریزی خطی پیشرفته (21715( Advanced Linear Programming وب سایت درس: http://courseware.sharif.edu/ دليل انتخاب درس؟ معرفی تکنیکهای کارای حل مسالههای برنامهریزی خطی بزرگ و پیچیده (و عدد صحیح)
برنامه ریزی خطی پیشرفته (21715) مدرس ناصر سلماسي تلفن 5738-6616 آدرس الكترونيكي (Email): nsalmasi@sharif.edu ساعتهاي رفع اشكال: شنبهها و دوشنبهها 13:30 الی 15:00
برنامه ریزی خطی پیشرفته (21715) مربی تمرین سعید بهجت آدرس الكترونيكي (Email): saeed.behjat@yahoo.com
برنامهریزی خطی پیشرفته (21715) روش مطالعه درس در طول ترم 6 تا 8 ساعت مطالعه هفتگی (مطالعه و برنامه نویسی) حضور در کلاس و مشارکت در مباحث تمرینها و/ یا پروژههای هفتگی آشنايي دانشجویان با يك زبان برنامهنويسي آشنایی با تحقیق درعملیات مقدماتی
برنامه ریزی خطی پیشرفته (21715) مراجع Linear Programming and Network Flows, By M. Bazaraa, J. J. Jarvis, H.D., Sherali, Fourth Edition, John Wiley and Sons Inc., 2010. Linear Programming, By K.G. Murty, John Wiley and Sons Inc., 1983. Linear Programming, By G. Hadley, Eighth Printing in 1974, Addison-Wesley Publishing Company. 1962. Optimization Theory for Large Systems, By L. S. Lasdon, The Macmillan Company, 1970.
برنامه ریزی خطی پیشرفته (21715) مراجع (ادامه) Linear Programming and Extensions, By G.B. Dantzig, The RAND Corporation, Third printing, 1966. Linear and Nonlinear Programming, By I. Griva, S.G. Nash and A. Sofer, Second Edition, McGraw Hill, 2009. Introduction to Linear Optimization, By D. Bertsimas and J.N. Tsitsiklis, Athena Scientific, Belmont, Massachusetts, 1997. Modern Heuristic Techniques for Combinatorial Problems, By Colin R Reeves, McGraw-Hill, 1995.
برنامه ریزی خطی پیشرفته (21715) مراجع (ادامه) Robust Optimization, By A. Ben-Tal, L.E. Ghaoui, and A. Nemirovski, Princeton Series in Applied Mathematics, 2009. Applied Integer Programming: Modeling and Solution, By, D.S Chen, R.G. Batson, and Y. Dang, Wiley, 2010. An Introduction to Optimization, By E.K.P. Chong and S.H. Zak, Third Edition, John Wiley and Sons Inc., 2008.
برنامه ریزی خطی پیشرفته (21715) مراجع (ادامه) Deterministic Operations Research: Models and Methods in Linear Optimization, By D. J. Rader JR. John Wiley and Sons Inc., 2010. Fractional Programming, By B.D. Craven, 1988, Heldermann Verlag, Berlin. Several published articles related to discussed topics.
برنامه ریزی خطی پیشرفته (21715) نمره بندي نمره شرح 6 ميانترم 4 تمرينها پايانترم سمینار و گزارش
برنامهریزی خطی پیشرفته (21715) تمرین ها تمرینهای هفتگی در طول ترم ارسال تمرينها: قبل از كلاس در روز موعد تحويل به آدرس الکترونیکی مدرس تحویل در ابتدای کلاس
برنامهریزی خطی پیشرفته (21715) سمینار و گزارش آن انتخاب یک موضوع تحقیقی مربوط به برنامه ریزی خطی و بررسی مقاله های مربوطه و شرح دقیق یکی از مقاله ها توسط دانشجو 10% نمره بابت ارایه پیشنهادی بهبود دهنده قابل اجرا استفاده از تکنیک های ارایه شده در کلاس برای حل یک مساله واقعی مشاوره با مدرس درس برای تصویب موضوع ارزیابی تحقیق بر پایه سمینار کلاسی توسط دانشجو ارایه گزارش کتبی در مورد تحقیق و نتایج آن
برنامهریزی خطی پیشرفته (21715) سمینار و گزارش آن (ادامه) مهلت انتخاب موضوع: دهم اردیبهشت ماه موعد تحویل گزارش کتبی پروژه: روز ارایه نهایی (18 خرداد ماه) ارسال گزارش بصورت الکترونیکی (تایپ شده) ارزیابی بر اساس اصول نگارش یک گزارش حرفه ای
برنامهریزی خطی پیشرفته (21715) پروژهها و تمرينها بصورت انفرادي تشویق به مشورت با سايرين از دست دادن قسمتی از نمره برای هر تاخیر از موعدهای تحویل تمرین ها گزارش سمینار (پروژه و یا انتخاب موضوع) و...
برنامهریزی خطی پیشرفته (21715) قرار دادن تمرينها، پروژهها و اطلاعیه های مهم در وب سایت کلاس الزام دانشجويان به رجوع مرتب به وب سایت درس الزام نام گذاری فايلهاي برنامه بصورت زير: Yourname_HW3.doc Yourname_HW3.cpp Yourname_Project3.doc Yourname_Project3.cpp
برنامهریزی خطی پیشرفته (21715) ارسال تمرينها قبل از ساعت كلاس در روز موعد تحويل به آدرس الکترونیکی مدرس (در صورت نیاز به پست الکترونیکی) جمع آوری تمرین ها در ابتدای کلاس مجاز نبودن هیچگونه تاخیر استفاده از نرم افزار CPLEX یا LINGO برای انجام تمرین ها و پروژه ها
برنامهریزی خطی پیشرفته (21715) تاریخهای مهم زمان مسئولیت 92/2/2 امتحان میان ترم 92/2/10 انتخاب موضوع سمینار 92/3/18 ارایه نهایی 92/4/5 عصر امتحان پایان ترم
کامپیوتر و مدیریت داده ها و اطلاعات( (21977 کامپیوتر و مدیریت داده ها و اطلاعات( (21977
برنامه ریزی خطی پیشرفته (21715) سر فصل مطالب Lecture No. Title No. of sessions Lecture 1: Introduction 3 Lecture 2: The Primal Dual Method 2 Lecture 3: Geometry of the Simplex Method 4 Lecture 4: Fractional Programming Lecture 5: Duality in Linear Programming 1 Lecture 6: Complexity Lecture 7: Interior Point Techniques Lecture 8: Lagrangian Relaxation Method Lecture 9: Decomposition Techniques 5 Lecture 10: Branch-and-Price Technique Lecture 11: Robust Optimization
برنامهریزی خطی پیشرفته (21715) تحقیق در عملیات* چیست؟ کاربرد علوم ریاضی در تصمیمگیری بصورت علمی مبتنی بر مدل ریاضی * Operations Research
برنامهریزی خطی پیشرفته (21715) شاخه ای از تحقیق در عملیات: استفاده از متغیرهای تصمیم مساله بصورت خطی تعریف: مساله بهینهسازی (بیشینه سازی یا کمینهسازی) یک تابع خطی با مدنظر قراردادن محدودیتهایی بصورت نامساوی و یا مساویهای خطی (بازارا و همکاران 2010)
برنامهریزی خطی پیشرفته (21715) معرفی مساله برنامه ریزی خطی توسط دنزیگ در 1947 بهترین روش حل ارایه شده برای حل بهینه مساله: الگوریتم سیمپلکس (دنزیگ، 1949) با حرکت به روی مرزهای منطقه موجه ارایه روشهای متعدد برای حل مساله (روشهای نقطههای داخلی و...)
برنامهریزی خطی پیشرفته (21715) حالت کانونی یک مساله برنامه ریزی خطی پارامترهای مدل: aij (ضرایب تکنولوژی) bj(مقدارهای بردار سمت راست) ci ضریب های متغیرهای تصمیم در تابع هدف متغیرهای تصمیم: Xi (n متغیر تصمیم) m محدودیت Max Z = C1X1 + C2X2 +… +CnXn محدودیت های کارکردی a11X1 + a12X2 +… +a1nXn ≤ b1 a21X1 + a22X2 +… +a2nXn ≤ b2 . am1X1 + am2X2 +… +amnXn ≤ bm محدودیت های غیر کارکردی Xi ≥ 0 i = 1,2, …, n
برنامهریزی خطی پیشرفته (21715) حالت کانونی یک مساله برنامه ریزی خطی (ادامه) پارامترهای مدل: aij (ضرایب تکنولوژی) bj(مقدارهای بردار سمت راست) ci ضریب های متغیرهای تصمیم در تابع هدف متغیرهای تصمیم: Xi (n متغیر تصمیم) m محدودیت Min Z = C1X1 + C2X2 +… +CnXn محدودیت های کارکردی a11X1 + a12X2 +… +a1nXn ≥b1 a21X1 + a22X2 +… +a2nXn ≥ b2 . am1X1 + am2X2 +… +amnXn ≥ bm محدودیت های غیر کارکردی Xi ≥ 0 i = 1,2, …, n
برنامهریزی خطی پیشرفته (21715) حالت استاندارد یک مساله برنامه ریزی خطی محدودیت های کارکردی بصورت تساوی متعیرهای تصمیم مثبت اهمیت: امکان استفاده از روش سیمپلکس تنها برای مساله های تبدیل شده به حالت استاندارد Max Z = C1X1 + C2X2 +… +CnXn محدودیت های کارکردی a11X1 + a12X2 +… +a1nXn = b1 a21X1 + a22X2 +… +a2nXn = b2 . am1X1 + am2X2 +… +amnXn = bm محدودیت های غیر کارکردی Xi ≥ 0 i = 1,2, …, n
برنامهریزی خطی پیشرفته (21715) حالت ماتریسی یک مساله برنامهریزی خطی C برداری 1*n X بردار n*1 A ماتریس m*n b ماتریس m*1 Max Z = CX AX ≤ b X ≥ 0
برنامهریزی خطی پیشرفته (21715) مثال:
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی جواب (Solution): وجود دو تعریف مختلف در منبع ها هر مقداری که به متغیرهای تصمیم اختصاص یابد. هر مقداری که به متغیرهای تصمیم اختصاص یابد و محدودیتهای کارکردی را ارضا کند. جواب موجه (Feasible Solution): جوابی که تمامی محدودیتهای کارکردی و غیر کارکردی را ارضا کند. جواب بهینه (Optimal Solution): جواب موجهی که بهترین مقدار را برای تابع هدف تامین می کند.
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی (ادامه) معادلات حدی (Boundary Equations): محدودیتی که رابطه نامساوی آن با رابطه مساوی جایگزین شود. جواب گسترده: مجموعه مقادیر تمام متغیرهای تصمیم و کمکی برای هر نقطه (نه فقط گوشه)
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی (ادامه) اهمیت فراوان تحلیل جواب گسترده یک نقطه تشخیص موجه بودن و ناموجه بودن یک نقطه تشخیص گوشه بودن یک نقطه شناسایی نقاط مرزی شناسایی نقاط داخلی سوال: صفر بودن مقدار یک متغیر تصمیم در جواب گسترده به چه معنی است؟
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی (ادامه) جواب گوشه یا پایه (Corner): در فضای n بعدی نقطه ای که از محل تلاقی n محدودیت مستقل حاصل شود. دارای نام های دیگری مانند Extreme Point (حداکثر) تعداد گوشه های یک مساله برنامه ریزی خطی است در صورتی که محدودیت ها بصورت نامساوی باشند. تمامی این گوشهها موجه نیستند. فرمولی برای محاسبه تعداد گوشههای موجه یک مساله وجود ندارد.
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی (ادامه) معادلات معرف یک گوشه: محدودیتهایی مستقل از هم از مساله (کارکردی و غیر کارکردی) که باعث ایجاد یک گوشه میشوند (معادلات حدی که یک گوشه را ایجاد میکنند). جواب پایه موجه (Basic Feasible Solution; BFS): جواب گوشه ای که در تمامی محدودیتها صدق کند. جواب گسترده این نقطه حداکثر دارای m متغیر غیر صفر و حداقلn مقدار صفر است در صورتی که محدودیت ها بصورت نامساوی باشند.
برنامهریزی خطی پیشرفته (21715) تعاریف مقدماتی (ادامه) گوشههای مجاور: دو گوشهای که در n-1 معادله معرف مشترک باشند. تعداد گوشههای مجاور هر گوشه در یک مساله برنامهریزی خطی حداکثر برابر m*n است. سوال: تعداد گوشههای موجه مجاور هر گوشه چیست؟ حداکثر؟ حداقل؟
برنامهریزی خطی پیشرفته (21715) برای حل مسالههای برنامهریزی خطی حالتی به عنوان حالت استاندارد تعریف و الگوریتم سیمپلکس بر مبنای آن تعریف می شود. روش تبدیل مساله های غیر استاندارد به استاندارد (مطالعه بر عهده خودتان) خصوصیت های جواب بهینه: حداقل یکی از جواب های بهینه حتما در یکی از گوشههای موجه پایه است. تعداد گوشههای یک مساله بی نهایت نیست . چنانچه مقدار تابع هدف در یک گوشه از تمام گوشه های مجاور موجه بهتر بود جواب بهینه است.
برنامهریزی خطی پیشرفته (21715) الگوریتم سیمپلکس گام یک: از یک گوشه موجه ابتدایی آغاز کنید. گام دو: از گوشه موجود به سمت گوشه مجاور بهتر حرکت کنید. گام سه: اگر به گوشهای رسیدید که از تمامی گوشههای مجاور خود بهتر بود جواب بهینه است.
برنامهریزی خطی پیشرفته (21715) مطالبی در مورد حالت استاندارد مسالههای برنامه ریزی خطی اگر مسالهای از حالت استاندارد پیروی نکند، مبدا مختصات متعلق به منطقه موجه نیست. نیاز به انجام جستجوی ابتدایی برای پیدا کردن گوشه موجه ابتدایی (تکنیک M بزرگ و تکنیک دو فاز) یکسان بودن منطق تکنیک های M بزرگ و دو فاز ترجیح برای تکنیک دو فاز در مسالههای واقعی (چرا؟) 36 36
برنامهریزی خطی پیشرفته (21715) ضابطههای انتخاب متغیر ورودی روش : انتخاب متغیر با کمترین مقدار سطر صفر روش : محاسبه بیشترین تغییر در مقدار تابع هدف در تکرار بعدی انتخاب اولین متغیر منفی از سمت چپ جدول سیمپلکس روش *LRC: انتخاب متغیر منفی بعدی پس از متغیر ورودی انتخاب شده در مرحله قبلی مطالعه های آماری نشان داده است که روش های سوم و چهارم سریع تر به جواب بهینه می رسند. * مراجع مربوطه در اسلاید بعدی 37 37
برنامهریزی خطی پیشرفته (21715) *Least Recently Considered [1] H.W.Kuhn and R.E.Quandt, An experimental study of the simplex method, In N.C.Metropolis, et al. (Eds.), Eperimental Arithmetic, High-Speed Computing and Mathematics (Proceedings of Symposia in Applied Mathematics XV), American Mathematical Society, Providence, R.I, 107-124, 1953. [2] R.Jeroslow ,The simplex algorithm with the pivot rule of maximizing criterion improvement, Discrete Applied Mathematics, Vol 4 (1973), 367-377. 38 38
برنامهریزی خطی پیشرفته (21715) حالتهای خاص یک مساله برنامهریزی خطی فاقد منطقه موجه (No feasible solution): شناسایی توسط روش دو فاز یا M بزرگ نامحدود (Unbounded): رشد بینهایت مقدار متغیر ورودی جواب بهینه چندگانه (Multiple Optimal Solution): صفر بودن مقدار سطر صفر یک متغیر غیر پایه در جواب بهینه تباهیده(Degenerate) : منطبق بودن چندین گوشه به روی هم 39 39
برنامهریزی خطی پیشرفته (21715) حالت نامحدود (Unbounded) نامحدود بودن فضای منطقه موجه مساله افزایش (کاهش) مقدار بهینه مساله بطور نامحدود شرایط تشخیص: مشکل هنگام انتخاب متغیر خروجی نامحدود بودن منطقه موجه مساله نامحدود بودن جواب بهینه مساله 40 40
برنامهریزی خطی پیشرفته (21715) حالت نامحدود (Unbounded)-ادامه در حالتهای خاصی قبل از حل مساله می توان متوجه نامحدود بودن منطقه موجه مساله شد. شعاع حدی: جهتهایی که مساله در آنها به سمت بینهایت میل میکند. 41 41
برنامهریزی خطی پیشرفته (21715) جواب بهینه چندگانه (Multiple Optimal Solution) یک توجیه: در حالت دو بعدی تابع هدف موازی یکی از معادلات معرف غیر زاید جواب بهینه وجود بینهایت جواب بهینه برای مساله وجود دو گوشه بهینه در صورت نبودن شعاع حدی شرایط تشخیص: وجود متغیرتصمیمی غیرپایه با مقدار سطر صفر برابر با صفر در جدول نهایی جواب بهینه (در صورتی که تبهگن نباشد) 42 42
برنامهریزی خطی پیشرفته (21715) جواب بهینه چندگانه (Multiple Optimal Solution)- ادامه بهینه بودن هر ترکیب محدبی از گوشههای بهینه سوال: آیا ممکن است در حالت غیر بهینه هم با چنین حالتی رو به رو شویم؟ 43 43
برنامهریزی خطی پیشرفته (21715) مساله تباهیده (Degenerate) تلاقی بیش از n محدودیت در یک نقطه منطبق شدن بیش از یک گوشه به روی هم روش تشخیص: هنگام انتخاب متغیر خروجی وجود حداقل دو سطر با مقدار مساوی و حداقل θ در این حالت در تکرار بعدی متغیری تصمیمی که برای خروج از پایه انتخاب نشده در سمت راست مقدار صفر خواهد داشت. 44 44
برنامهریزی خطی پیشرفته (21715) مساله تباهیده (Degenerate)- ادامه جواب تبهگن لزوما بهینه نیست. جواب تبهگن جوابی است که حداقل یکی از متغیرهای پایه آن برابر صفر باشد. تمام گوشههای تبهگن لزوما مجاور هم نیستند. 45 45
برنامهریزی خطی پیشرفته (21715) مساله تباهیده (Degenerate)- ادامه نگرانیهای اولیه در مورد دور افتادن مساله هنگام رسیدن به یک گوشه تبهگن رفع نگرانی در مورد حل این مسالهها با گسترش تحقیقات وجود مسالههای مصنوعی که حل آنها امکان پذیر نیست (هدلی و مورتی) 46 46
برنامهریزی خطی پیشرفته (21715) مساله تباهیده (Degenerate)- ادامه وجود روشهای ابداعی برای رفع قطعی این مشکل انتخاب تصادفی متغیر تصمیم خروجی هنگام حل مساله بصورت دستی نیاز به روشهای ساختار یافته تر برای حل مسالهها به کمک کامپیوتر مانند: انتخاب متغیر تصمیم با مقدار yik بزرگتر انتخاب متغیر تصمیم با مقدار اندیس کوچکتر (روش Indexing) وجود روشهای مطمئن تر برای رفع مشکل 47 47
برنامهریزی خطی پیشرفته (21715) انواع جوابهای مساله برنامهریزی خطی جواب های ممکن برای مساله برنامه ریزی خطی بدون جواب موجه جواب موجه جواب بهینه محدود جواب نامحدود یک جواب بهینه جواب بهینه چندگانه 48 48
برنامهریزی خطی پیشرفته (21715) مثال Max Z= 2X1 - X2 + 3x3 X1 - X2 + 5x3 ≤ 10 2X1 - X2 + 3x3 ≤ 40 Xj ≥ 0 Z X1 X2 X3 S1 S2 b 1 40 -2 -1 30 -7 20 49 49
برنامهریزی خطی پیشرفته (21715) انواع محدودیتها در یک مساله برنامهریزی خطی محدودیت موثر: محدودیتهای موثر در تشکیل منطقه موجه. حذف این محدودیتها موجب افزایش منطقه موجه می شود. محدودیت زاید(Redundant Constraint) : محدودیتی که تاثیری در ایجاد منطقه موجه نداشته و وجود و عدم وجود آن موجب تغییر در منطقه موجه نمیشود. محدودیت الزام آور: محدودیتی که متعلق به معادلات حدی نقطه بهینه باشد. 50 50
برنامهریزی خطی پیشرفته (21715) مثال Max Z= X1 + 10X2 -2X1 + 3X2 ≤ 6 2X1 + X2 ≤ 4 X2 ≤ 4 Xj ≥ 0 51 51
برنامه ریزی خطی پیشرفته (21715) مثال شماره گوشه X1 X2 S1 S2 S3 مقدار تابع هدف 1 3/4 5/2 3/2 103/4 2 10 4 3 6 -3 -6 5 40 7 8 20 9 43 52 52
برنامهریزی خطی پیشرفته (21715) مساله شامل محدودیتهای زاید (Redundancy) یک محدودیت مضربی از محدودیت دیگر یک محدودیت ترکیبی از چندین محدودیت دیگر توجه: اگر متغیر کمکی (مصنوعی) مربوط به یکی از محدودیتها در پایه باشد تمامی مقدارهای آن سطر به جز متغیر پایه آن صفر میشوند. عموما در فاز یک اتفاق میافتد. مشکلی در حل مساله ایجاد نمیشود و نیازی به بررسی آن قبل از حل نیست. 53 53
برنامهریزی خطی پیشرفته (21715) مثال: مساله برنامهریزی خطی زیر را در نظر بگیرید: Max Z= 3x1 + 5x2 x1 + x2 ≤ 6 3x1 - 4x2 ≤ 7 2x1 + 3x2 ≤ 8 x1 + x2 ≤ 4 x1 - 2x2 ≤ 10 x1, x2≥ 0 54 54
برنامهریزی خطی پیشرفته (21715) Z X1 X2 S1 S2 S3 S4 S5 b 1 -3 -5 6 3 -4 7 2 8 4 -2 10 .33 1.67 13.3 -.33 3.33 5.66 1.33 17.67 .67 2.66 2.33 .667 15.33 55 55
برنامهریزی خطی پیشرفته (21715) مثال: فرض کنید مساله برنامهریزی خطی قبلی به حالت زیر تبدیل شود: Max Z = 3x1 + 5x2 x1 + x2 ≤ 1 3x1 - 4x2 ≤ 7 2x1 + 3x2 ≤ 8 x1 + x2 ≤ 4 x1 - 2x2 ≤ 10 x1, x2 ≥ 0 56 56
برنامهریزی خطی پیشرفته (21715) Z X1 X2 S1 S2 S3 S4 S5 b 1 -3 -5 3 -4 7 2 8 4 -2 10 5 11 -1 12 57 57
برنامهریزی خطی پیشرفته (21715) بحث اگر زمان انتخاب متغیر تصمیم ورودی منفیترین متغیر انتخاب نشود چه میشود؟ اگر متغیر تصمیمی با مقدار مثبت و یا صفر برای ورود به پایه انتخاب شود چه میشود؟ اگر هنگام انتخاب متغیر تصمیم خروجی متغیری با کمترین مقدار θ انتخاب نشود چه میشود؟ 58 58
برنامهریزی خطی پیشرفته (21715) بحث – ادامه در مساله برنامهریزی خطی تعداد متغیرهای تصمیم باعث پیچیدگی بیشتر مساله میشود یا تعداد محدودیتها؟ در مساله برنامهریزی خطی عدد صحیح تعداد متغیرهای تصمیم باعث پیچیدگی بیشتر مساله میشود یا تعداد محدودیتها؟ مطالعه تفسیر اقتصادی جدول سیمپلکس بر عهده خودتان رفتار محدودیت های شامل M بزرگ 59 59
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاحشده (Revised Simplex) حفظ حداقل اطلاعات لازم در هر تکرار سیمپلکس در حافظه بازیابی سایر اطلاعات در هر تکرار در صورت لزوم 60 60
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده(Revised Simplex) حالت ماتریسی یک مساله برنامهریزی خطی را بصورت زیر در نظر بگیرید: C 1*n X n*1 A m*n b m*1 مدل I Max Z = CX AX ≤ b X ≥ 0
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده (Revised Simplex) برای حل مساله لازم نیست که n > m باشد. با تبدیل نامعادلهها به معادله تعداد متغیرهای تصمیم افزایش پیدا میکند. با تبدیل نامساویها به مساوی مدل II ایجاد میشود: مدل II Max Z = CX AX+ IS= b X,S ≥ 0 62 62
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده (Revised Simplex) تضمین یکسان بودن مدل های I و II با مثبت بودن مقدار متغیرهای کمکی S فرض میشود بردار X شامل تمامی متغیرهای تصمیم مساله، متغیرهای کمکی و مصنوعی است. فرض می شود ضرایب تمامی این متغیرهای تصمیم در بردار C بصورت متناظر قرار دارند. 63 63
برنامهریزی خطی پیشرفته (21715) بدست آوردن شرایط سیمپلکس محدودیتهای (A, I)X= b را بصورت زیر مینویسیم: BXB + NXN = b لذا: XB = B-1b – B-1 NXN XB = B-1b B: یک پایه شدنی XB بردار پایه ای وابسته به B XN(=0) بردار غیر پایه ای 64 64
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده(Revised Simplex) اگر B پایه فعلی باشد و CB و CN عناصری از C وابسته به XB و XN باشند، مساله بصورت زیر تبدیل می شود: Max Z = CB XB + CN XN BXB + NXN = b XB , XN ≥ 0 در نهایت Z= CBB-1b 65 65
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده (Revised Simplex) شکل ماتریسی مساله را میتوان بصورت زیر نمایش داد: در هر تکرار جواب پایهای فعلی XB و مقدار تابع هدف Z را می توان برحسب ماتریس پایهای فعلی B توسط روابط زیر بدست آورد: BXB = b Z = CBXB 66 66
برنامه ریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده (Revised Simplex) این معادله ها را میتوان بصورت زیر نیز نمایش داد: با استفاده از فرمولهای معکوس یک ماتریس افراز شده جواب فعلی با رابطه زیر نمایش داده میشود: 67 67
برنامهریزی خطی پیشرفته (21715) روش سیمپلکس اصلاح شده (Revised Simplex) لذا جدول کلی متناظر با جواب فعلی رامیتوان به شرح زیر بدست آورد: 68 68
برنامهریزی خطی پیشرفته (21715) الگوریتم حل سیمپلکس اصلاح شده گام یک: انتخاب متغیر ورودی (با استفاده از CBB-1A – C) گام دو: محاسبه ستون متغیر ورودی B-1aj گام سه: محاسبه θ و متغیر خروجی گام چهار: محاسبه B-1 جدید و مقادیر B-1b و CBB-1 69 69
برنامهریزی خطی پیشرفته (21715) روش محاسبه B-1 جدید B-1(new) = E B-1 (old) در این محاسبه E ماتریسی است که قطر اصلی آن برابر یک به جز ستونی که وارد پایه میشود. در آن ستون مقادیر جدول آن ستون را قرار میدهیم یعنی مقادیر زیر(مراجعه شود به صفحه 207 بازارا): 70 70
برنامهریزی خطی پیشرفته (21715) روش محاسبه B-1 جدید 71 71
برنامهریزی خطی پیشرفته (21715) حالت دوگانگی (Duality) وابستگی هر مساله برنامهریزی خطی به یک مساله دیگر مساله اول: مساله اولیه مساله وابسته: مساله ثانویه و یا مساله دوگان وجود خاصیتهای وابسته بسیار نزدیک به هم میان مساله های اولیه و دوگان کسب اطلاعات کامل در مورد جواب بهینه یکی با داشتن جواب بهینه مساله دیگر استفاده از این خاصیت در کاهش حجم عملیات محاسباتی مربوط به حل مسالههای برنامهریزی خطی 72 72
برنامهریزی خطی پیشرفته (21715) مثال i = 1,2,…, m j = 1,2,…, n j = 1,2,…, n i = 1,2,…, m 73 73
برنامهریزی خطی پیشرفته (21715) نکتههای مهم تناظر هر محدودیت در یک مساله با یک متغیر در مساله دوگان برابری تعداد گوشههای مسالههای اولیه و دوگان تناظر هر گوشه از مساله اولیه با گوشهای دیگر در مساله ثانویه ارتباط هر متغیر تصمیم در مساله اولیه با متغیر لنگی محدودیت متناظر در مساله دوگان (برای دو گوشه متناظر حداقل یکی از آنها برابر صفر است). 74 74
برنامهریزی خطی پیشرفته (21715) قضیه لنگی مکمل* اگر x* و y* دو جواب موجه برای مساله اولیه و دوگان آن در حالت کانونی باشند، هر دو جواب های بهینه مساله مربوطه هستند اگر و فقط اگر رابطه های زیر میان اعضای جواب گسترده این دو نقطه برقرار باشد: Xj S′j = 0 Yi Si = 0 * Complementary Slackness Theorem 75 75
برنامهریزی خطی پیشرفته (21715) نتیجه مهم قضیه لنگی مکمل در مورد متغیرهای جواب گسترده هر دو گوشه (نقطه) مرتبط همواره روابط زیر برقرار است. Xj S′j = 0 Yi Si = 0 76 76
برنامهریزی خطی پیشرفته (21715) مثال واضح است که مساله دارای 10 گوشه است. تناظر گوشههای مسالههای اولیه و دوگان در اسلاید بعدی مشخص است. Max Z= 5X1 + 2X2 +3X3 X1 + 2X2 +2X3 ≤ 8 3X1 + 4X2 +X3 ≤ 7 Xj ≥ 0 MIN Y= 8Y1 + 7Y2 Y1 + 3Y2 ≥ 5 2Y1 + 4Y2 ≥ 2 2Y1 + Y2 ≥ 3 YI ≥ 0 77 77
برنامهریزی خطی پیشرفته (21715) مثال (ادامه) مساله دوگان تابع هدف مساله اولیه شماره گوشه Y1 Y2 S′1 S′2 S′3 Y=Z X1 X2 X3 S1 S2 -7 4 -13 -28 -9 8.5 1 -5 -2 -3 8 7 2 1/2 -3/5 -2/5 3.5 7/4 4/5 3 -4 -1 5/3 -1/3 -13/3 11 5 14/3 -4/3 35/3 7/3 17/3 6 1/5 12 7/5 26/5 81/5 6/5 17/5 10 21 -6 9 40 -17 78 78
برنامهریزی خطی پیشرفته (21715) نکتهها جواب بهینه تنها نقطهای است که در آن هر دو گوشه متناظر اولیه و دوگان موجه هستند (گوشه شماره 8). اگر مسالهای دارای جواب بهینه چندگانه باشد چندین نقطه اینچنینی وجود دارند؟ در مساله اولیه تمامی گوشههایی که دارای مقدار تابع هدفی بیش از جواب بهینه باشند غیر موجه هستند. مقدار تابع هدف برای هر گوشه موجه در مساله maxکمتر از مقدار تابع هدف از هر گوشه موجه مساله min است. 79 79
برنامهریزی خطی پیشرفته (21715) رابطه میان جوابهای مساله اولیه و دوگان اگر مساله اولیه دارای جواب بهینه محدود باشد، مساله دوگان هم دارای جواب بهینه محدود است. اگر جواب مساله اولیه بصورت نامحدود باشد مساله دوگان حتما فاقد منطقه موجه است. اگر جواب مساله اولیه فاقد جواب موجه باشد مساله دوگان آن یا نامحدود است است و یا فاقد منطقه موجه اگر مساله اولیه دارای جواب بهینه چندگانه باشد، مساله دوگان آن حتما دارای جواب بهینه تبهگن است ولی عکس مطلب همواره صحیح نیست. 80 80
برنامهریزی خطی پیشرفته (21715) رابطه میان جواب های مساله اولیه و دوگان در حالت تبهگن و یا بهینه چندگانه مساله برنامهریزی خطی زیر و دوگان آن را در نظر بگیرید: Max Z= 3X1 + 9X2 X1 + 4X2 ≤ 8 X1 + 2X2 ≤ 4 Xj ≥ 0 MIN Y= 8w1 + 4w2 w1 + w2 ≥ 3 4w1 + 2w2 ≥ 9 wI ≥ 0 81 81
برنامهریزی خطی پیشرفته (21715) رابطه میان جوابهای مساله اولیه و دوگان در حالت تبهگن و یا بهینه چندگانه-ادامه جدول بهینه مساله اولیه و شکل منطقه موجه آن به قرار زیر است: 82 82
برنامهریزی خطی پیشرفته (21715) در جدول مشخص است که پس از تکرار اول به گوشه تبهگن رسیدهایم. گوشههای تبهگن اول و دوم در تکرارهای سیمپلکس عادی مشخص هستند. گوشه تبهگن سوم در حالی آشکار می شود که در تکرار اول متغیر تصمیم دیگری برای خروج از پایه انتخاب شود. z X1 X2 S1 S2 b Teta 1 -3 -9 0.00 4 8.00 2 4.00 P1 1.00 -0.75 2.25 18.00 0.25 2.00 0.50 -0.50 P2 1.50 -1.00 P3 4.50 -2.00 83 83
برنامهریزی خطی پیشرفته (21715) با توجه به دو بعدی بودن مساله مشخص است که در گوشه تبهگن سه نقطه به روی هم منطبق شدهاند. سه گوشه تبهگن مجاور همدیگر نیستند. به عبارت دیگر فقط یکی از این گوشهها مجاور هر دو گوشه دیگر است. به عبارت دیگر در الگوریتم سیمپلکس از یک گوشه تبهگن تنها با یک حرکت نمیتوان به تمام گوشههای تبهگن دیگر دسترسی داشت. با توجه به یکسان بودن جواب گسترده هر سه نقطه تنها دو مورد از آنها خاصیت بهینگی دارند که هیچکدام مجاور نیستند. 84 84
برنامهریزی خطی پیشرفته (21715) جدول بهینه مساله دوگان و شکل منطقه موجه آن به قرار زیر است: 85 85
برنامهریزی خطی پیشرفته (21715) در مساله دوگان به محض رسیدن به منطقه موجه به جواب بهینه (بهینه چندگانه) رسیدهایم. در اینجا با توجه به موازی بودن تابع هدف با یکی از محدودیت ها دو گوشه بهینه داریم. توجه کنید که گوشه دیگری هم با مقدار تابع هدف 18 وجود دارد که موجه نیست. هر سه این گوشهها مجاور همدیگر هستند. 86 86
برنامهریزی خطی پیشرفته (21715) مقایسه جوابهای گسترده سه گوشه تبهگن مساله اولیه با جواب گسترده گوشه های متناظر آنها در جدول زیر ارایه شده است: شماره گوشه جواب گسترده گوشه مساله اولیه متغیرهای پایه در مساله اولیه مقدار تابع هدف جواب گسترده گوشه مساله دوگان شرح (X1, X2, S1, S2) (w1, w2, S'1, S'2) گوشه 1 (0, 2, 0, 0) X1, X2 18 (1.5, 1.5, 0, 0) هر دو بهینه گوشه 2 X2, S1 (0, 4.5, 1.5,0) گوشه 3 X2, S2 (9/4, 0, -3/4, 0) موجه در یکی، غیر موجه در دیگری 87 87
برنامهریزی خطی پیشرفته (21715) تمرین در مساله برنامهریزی خطی زیر آیا جواب زیر جواب بهینه مساله است؟ Max Z= 2X1 - 13X2 - 3X3 + 2X4 - 5X5 - 5X6 - 10X7 X1 - X2 + 4X4 - X5 - 4X7 =5 X1 + 7X4 - 2X5 + 3X6 - 3X7 ≥ -1 5X2 + X3 – X4 + 2X5 - X6 - 2X7 ≤ 5 3X2 + X3 + X4 + X5 + X6 - X7= 2 Xi ≥ 0 88 88
برنامهریزی خطی پیشرفته (21715) الگوریتم سیمپلکس ثانویه استفاده از مساله دوگان برای حل مساله آغاز حل مساله از گوشهای بهینه ولی غیر موجه (آغاز کار از یکی از گوشههای موجه مساله دوگان) در مراحل حل سعی میشود که از نقاط موجه مساله دوگان خارج نشویم. 89 89
برنامهریزی خطی پیشرفته (21715) تعبیر روش انتخاب متغیر خروجی از دیدگاه مساله اولیه از دیدگاه مساله ثانویه اگر منفی ترین bi انتخاب نشود باز هم به جواب بهینه می رسیم. ایده انتخاب کوچک ترین نسبت منفی به این دلیل است که ها هیچگاه منفی نشوند. 90 90
برنامهریزی خطی پیشرفته (21715) اگر مساله فاقد منطقه موجه باشد، در یکی از تکرارها تمامی مقادیر سطر لولا غیر منفی خواهند شد (تعبیر: مجموع چند عدد مثبت برابر عدد منفی است که غیر ممکن است). در این روش هیچگاه با حالت نامحدود مواجه نمیشویم زیرا که مساله دوگان همواره موجه است. اگر مقدار در یکی از تکرارها برابر صفر شود مساله تبهگن است. اگر مساله اولیه تبهگن باشد مساله ثانویه دارای جوابهای بهینه چندگانه است و برعکس 91 91
برنامهریزی خطی پیشرفته (21715) حالت خاص در مواردی شرایط اولیه برای استفاده از الگوریتم سیمپلکس ثانویه موجود نیست. فرض کنید مقادیر تعدادی از ها منفی باشند. در چنین حالتی روش حل اضافه کردن یک سطر (محدودیت) جدید به مساله بصورت است. در این محدودیت Xj ها شامل کلیه متغیرهای غیر پایه هستند. پایه جدید از روش زیر قابل محاسبه است: پایه جدید = پایه قدیم + (متغیری که دارای منفیترین ضریب در سطر صفر باشد) 92 92
برنامهریزی خطی پیشرفته (21715) حالت خاص (ادامه) در انتهای کار با یکی از سه حالت زیر روبه رو خواهیم شد: الف- برای مساله جواب موجهی پیدا نمیشود. در این حالت مساله اصلی هم غیر موجه خواهد بود. ب- در مساله نهایی متغیر X0 در پایه جواب بهینه نیست. در این حالت رابطه برقرار است و مساله اصلی نامحدود خواهد بود. ج- در مساله نهایی متغیر X0 در پایه جواب بهینه است. در این حالت مساله دارای جواب بهینه (معادل مقدار حاصله) خواهد بود. به ص256 مورتی مراجعه کنید!! 93 93
برنامهریزی خطی پیشرفته (21715) مثال در این حالت برای حل مساله محدودیت زیر را به مساله وارد میکنیم. X0 + X1 + X2 + X3 = M Max Z= 3X1 + 2X2 - X3 X1 + X2 ≤ 5 Xj ≥ 0 94 94
برنامهریزی خطی پیشرفته (21715) مثال در این مساله در جواب بهینه متغیر X0 در پایه بوده لذا مساله اصلی بهینه است. Z X1 X2 X3 S1 X0 b 1 -3 -2 5 M 4 3 3M -1 5-M 15 M-5 95 95