الگوریتم کارمارکار

از ویکی‌پدیا، دانشنامهٔ آزاد
پرش به: ناوبری، جستجو

الگوریتم کارمارکار توسط نراندرا کارمارکار در سال ۱۹۸۴ برای حل مسایلبرنامه ریزی خطی ارائه شد. این الگوریتم اولین الگوریتم کارا برای حل این مسایل در زمان چندجمله‌ای بود.روش بیضی نیز زمان اجرای چندجمله‌ای دارد،
ولی روش کارایی نیست.

اگر تعداد متغیرها و تعداد بیت‌های ورودی به الگوریتم باشد، الگوریتم کارمارکار به عمل روی اعداد رقمی احتیاج دارد، درحالی که در روش بیضی به عمل نیاز است.
زمان اجرای الگوریتم کارمارکار به صورت زیر است

که در آن از ضرب به روش تبدیل سریع فوریه استفاده می‌کند.

الگوریتم کارمارکار از جمله روش‌های نقطه‌ی داخلی است: حدس فعلی شرایط مجموعه‌ی ممکن را برخلاف روش سیمپلکس رعایت نمی‌کند و با استفاده از کسر معین در هر تکرار، دقت جواب بهینه را بهبود می‌دهد.[۱]

الگوریتم[ویرایش]

یک مسئله‌ی برنامه‌ریزی خطی را در شکل ماتریسی در نظر بگیرید :

maximize cTx
subject to Ax ≤ b.

کﻪ ﺩﺭ ﺁﻥ c ﺑﺮﺩﺍﺭی n ﺑﻌﺪی و b ﺑﺮﺩﺍﺭی m ﺑﻌﺪی و ﻣﺎﺗﺮﯾﺲ m × n) ، A) ﺑﻌﺪی است.
الگوریتم کارماکار کمی پیچیده است. یک مدل ساده‌تر که به آن روش affine-scaling گفته می‌شود، که به طور مختصر به شرح زیر است. دقت داشته باشید که این الگوریتم در حالی که در عمل کارا است ولی الگوریتم با زمان چندجمله‌ای نیست.[۲]

Algorithm Affine-Scalling
  Input:  A, b, c, , stopping criterion, .
  
  do while stopping criterion not satisfied
     
     
     
     
     if  then
        return unbounded
     end if
     
     
     
  end do

منابع[ویرایش]

  1. Strang, Gilbert (1 June 1987). "Karmarkar’s algorithm and its place in applied mathematics". The Mathematical Intelligencer (New York: Springer) 9 (2): 4–10. doi:10.1007/BF03025891. ISSN 0343-6993. MR '''883185'''. 
  2. Robert J. Vanderbei; Meketon, Marc, Freedman, Barry (1986). "A Modification of Karmarkar's Linear Programming Algorithm". Algorithmica 1: 395–407. doi:10.1007/BF01840454.