آزادسازی در برنامهریزی خطی
این مقاله به هیچ منبع و مرجعی استناد نمیکند. |
به نظر میرسد متن اخیرتان به طور افراطی سرهنویسی شده باشد. معیار انتخاب واژگان در ویکیپدیای فارسی رواج استفادهٔ آنها در منابع معتبر فارسی و وضوح واژگان برای اکثریت خوانندگان است. لطفاً متن اخیرتان را به شکلی که با واژگانی که در منابع معتبر رایجتر است، بازنویسی کنید. برای راهنمایی بیشتر صفحهٔ ویکیپدیا:سرهنویسی و ویکیپدیا:قواعد نامگذاری را ببینید. شاید در بحث همین صفحه توضیحی دراینباره نوشته شده باشد. |
در ریاضی و دانش رایانه، واهِلِش به برنامهنویسی خطی برنامهای دُرُست (integer program) را به برنامهای خطی میترادیساند. در این ترادیسی، هر متغیر در برنامهٔ درست با متغیری خطی جایگزین میشود. این واهلش پرسمانی انپی سخت را به پرسمانی خطی که در زمانی چند جملهای حل میشود میترادیساند. پاسخ به برنامهٔ خطی به دست آمده، اطلاعهای سودمندی را دربارهٔ برنامهٔ درست اصلی فراهم میآورد.
نمونه
ویرایشبرای نمونه، به پرسمان پوشش مجموعه میپردازیم. مجموعهای مانند و زیرمجموعههای از این مجموعه داده شدهاند. این پرسمان شماری از ها را میجوید که یکایش (اجتماع) این زیرمجموعهها مجموعه خواهد بود.
در برنامهٔ درست برای پوشش مجموعه، برای هر زیرمجموعهٔ متغیری بولی داریم.
یکایش زیرمجموعههای گزینش شده باید برابر با باشد. به سخنی دیگر، هر باید در این یکایش باشد: . این پاوند را پاوند یکایش مینامیم.
همچنین، پاوندِ برای هر متغیر نشان میدهد که آیا زیرمجموعه در پاسخ خواهد بود یا نه. به سخنی دیگرِ، ارزش یک/صفر برای نشان میدهد که زیرمجموعهٔ در پوشش هست/نیست. این پاوند را پاوند بولی مینامیم.
پرسمان کمترین شمار زیرمجموعهها را میجوید: .
واهلش به برنامهٔ خطی هر پاوند بولی را با پاوند جایگزین میکند. برنامهٔ خطی به دست آمده وزنی را برای هر زیرمجموعه فرضیده است؛ ولی، پاوند یکایش یکسان میماند. در پاسخ به این برنامهٔ خطی، جمع وزن همهٔ زیرمجموعههایی چون که دربردارندهٔ عضو برابر با یک خواهند بود.
به این نمونه از پوشش مجموعهای بنگرید: مجموعهٔ و زیرمجموعههای را داریم. در برنامهٔ درست، سه متغیر خواهیم داشت. برای هر کدام از یک پاوند یکایش هست. برای نمونه، برای پاوندِ را داریم. همچنین، برای هر یک پاوند بولی داریم.
گزینش هر جفت از زیرمجموعههای پاسخی بهین است. به سخنی دیگر، هر یک از ، یا یک پوشش مجموعهای کمینه است؛ بنابراین پاسخ کمینه برای برنامهٔ درست برابر است با .
ولی، پاسخی بهین به برنامهٔ خطی است. در این پاسخ، هر دارای ارزش است. این پاسخ پاوندهای یکایش را برآورده میکند.
همسنجی پاسخ واهلش و برنامهی درست
ویرایشاگر در پاسخ بهین به برنامهی خطی، هر متغیر ارزشی صفر یا یک بگیرد، این پاسخ پاسخی بهین برای برنامهی درست نیز خواهد بود. با این همه، ما پرسمانهای اندکی با چینن پاسخهایی داریم.
چون هر برنامهی درست زیرمجموعهای از برنامهای خطی است، پاسخها به برنامهی درست نیز زیرمجموعهای از پاسخها به برنامهی خطیاند. اگر برنامهی درست بیشینهسازی باشد، پاسخ بهین به برنامهی خطی همواره بزرگتر از پاسخ بهین به برنامهی اصلی است. به همین سان، اگر برنامهی درست کمینهسازی باشد، پاسخ به برنامه ی خطی همواره کوچکتر از برنامهی اصلی است. به سخنی دیگر، پاسخ به برنامهی خطی واهلیده همواره کرانی بالا (پایین) برای برنامهای درست بیشینهسازی (کمینهسازی) است.
در نمونهی بالا برای پوشش مجموعهی، پاسخ بهین خطی برابر بود با . چون پرسمان پوشش مجموعه، پرسمانی کمینهسازی است، پاسخ بهین برای برنامهی درست همواره بزرگتر یا برابر با خواهد بود. افزون بر این، چون هر متغیر در برنامهی درست میتواند ارزش صفر یا یک داشته باشد، دست کم باید دو متغیر با ارزش یک در پاسخ بهین باشند. بنابراین، میتوان کران پایین برای برنامهی درست را به کرانی تنگتر بهبود داد. این کران برابر با ۲ است.
تقریبزنی و گاف درستالی
ویرایشواهلش به برنامهی خطی، شیوهای استاندارد برای طراحی الگوریتمهای تقریبی است. گاف درستالی (integral gap) مفهومی کلیدی در این زمینه است. در واهلش، گاف درستالی نسبت بیشینه میان برنامهی درست و برنامهی خطی را نشان میدهد. اگر پاسخ بهین برای برنامهی درست و اگر پاسخ بهین برای برنامهی خطی باشند، گاف درستالی در کمینهسازی به دیسهی تعریف میشود و در بیشینهسازی برابر است با . بنابراین، گاف درستالی همواره بزرگتر از یک است. در نمونهی بالا چون پرسمان کمینهسازی،گاف درستالی برابر است با .
گاف درستالی کاربرد فراوانی برای یافتن نسبت تقریب در الگوریتمهای تقریبی دارد. برخی الگوریتمهای تقریبی این روش گِردسازی را به کار میبرند: برای هر واسخ واهلیدهی پاسخی درست را مییابند که کوچکتر از است ( همان نسبت گردسازی (rounding ratio) است).