الگوریتم هلد-کارپ

از ویکی‌پدیا، دانشنامهٔ آزاد

الگوریتم HELD-Karp که همچنین الگوریتم Bellman-Held-Karpet نامیده می‌شود، الگوریتم برنامه‌نویسی پویا در سال ۱۹۶۲ به‌طور مستقل توسط بلمن و توسط هلد و کارپ برای حل مسئله فروشنده دوره گرد (TSP) پیشنهاد شده‌است.

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

TSP یک فرمت از مساله مدار همیلتونی است. این مساله می‌تواند به عنوان توضیح: پیدا کردن یک تور ازN شهرستانها در یک کشور (با فرض تمام شهرستانها برای بازدید قابل دسترسی هستند)، درتور باید (الف) بازدید هر شهرستان فقط یک بارباشد، (ب) به نقطه شروع بازگردیم، (ج) فاصله حداقل باشد. دیدگاه کلی تر، TSP به عنوان مسئله فروشنده دوره گرد متقارن (sTSP)، مشکل نامتقارن فروشنده دوره گرد (aTSP)، و مسئله فروشنده دوره گرد چند سفر (mTSP) طبقه‌بندی شده‌است.mTSPبه‌طور کلی به عنوان پاسخ مساله آرام مسیریابی وسائل نقلیه می‌باشد.

مدل گراف[ویرایش]

sTSP: Let V= {v1 ,... , vn} مجموعه‌ای از شهرستانها می‌شود E= {(R,S):R,S∈V } لبه تنظیم می‌شود، وdrs = dsrیک اندازه‌گیری هزینه‌های مرتبط با لبه می‌باشد(r, s) ∈ E. aTSP:اگرdrs ≠ dsr برای حداقل یک(r, s)سپسsTSP می‌شود یک aTSP . .aTSP و sTSP در نمودارهای مختلف تعریف شده - کامل جهت دار و بدون جهت. sTSP می‌تواند در بسیاری از موارد، به عنوان یک مسئله از aTSP در نظر گرفته شود. mTSP: mTSPتعریف می‌شود به عنوان یک مجموعه داده از گره‌ها، اجازه وجودm فروشند واقع در یک گره انبارواحد وجود دارد. گره باقی‌مانده (شهرستانها) که توسط گره‌های میانی بازدید شده‌اند. سپس، mTSP شامل پیدا کردن تور برای همه m فروشنده، که همه شروع و پایان در انبار، به طوری که هر گره میانی است دقیقاً یک بار بازدید و کل هزینه بازدید از تمام گره به حداقل برسد.

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

شرح در زیر روش برنامه‌نویسی پویا است: یک مشخصه بهینه‌سازی برای TSP وجود دارد: هرزیرمسیر از یک مسیر حداقل فاصله آن از خود حداقل فاصله است. محاسبه راه حل تمام زیر مسئله با شروع از کوچکترین است. هر گاه یک راه حل محاسبه نیاز به راه حل برای مشکلات کوچکتر با استفاده از معادلات بازگشتی بالا، نگاه کردن به این راه حل که در حال حاضر محاسبه می‌شود. برای محاسبه یک تور حداقل فاصله، استفاده از معادله نهایی برای تولید گره LST، و تکرار برای گره‌های دیگراست. برای این مشکل ما نمی‌توانند بفهمند که زیر مسئله ما نیاز به حل دارد، بنابراین ما همه آن‌ها را حل می‌کنیم. شماره شهرستانها ۱، ۲،، N و فرض کنیم که ما در شهرستان ۱ شروع، و فاصله بین شهرستان iو شهرستانj,dij است. زیر مجموعه S را در نظر بگیرید S⊆ {۲،، N} از شهرستانها و برای C ∈ S, let D(S, c) باشد حداقل فاصله، با شروع در شهرستان ۱، بازدید از تمام شهرستانها در S و در پایان در شهرستان ج است. مرحله اول:اگر S = {c}سپس D(S, c) = d1,cدرغیر اینصورت D(S, c) = minx∈S−c (D(S − c, x) + dx,c) مرحله دوم: حداقل فاصله برای یک تور کامل از تمام شهرستانها M = minc∈{2,... ,N} (D({2, . . . , N}, c) + dc,۱) یک تور n1 , . . . , nN است از حداقل فاصله فقط زمانی که آن را برآورده شود M = D({2, . . . , N}, nN) + dnN,1

به عنوان مثال[ویرایش]

ماتریس فاصله:

توابع توضیحات: g (X، S) - با شروع از ۱، مسیر مینیمم هزینهٔ به پایان می‌رسد در راس X، عبور راس در مجموعه S دقیقاً یک بار cxy - هزینه لبه به پایان می‌رسد در x از Y P(X,S) - راس دوم به گذشته به x از مجموعه S. مورد استفاده برای ساخت مسیر TSP برگشت به آخر..

k = 0, null set:
Set ∅:
  g(2, ∅) = c21 = ۱
  g(3, ∅) = c31 = ۱۵
  g(4, ∅) = c41 = ۶
k = 1, consider sets of 1 element:
Set {2}:
  g(3,{2}) = c32 + g(2, ∅) = c32 + c21 = ۷ + ۱ = 8 p(۳,{۲}) = ۲
  g(4,{2}) = c42 + g(2, ∅) = c42 + c21 = ۳ + ۱ = 4 p(۴,{۲}) = ۲
Set {3}:
  g(2,{3}) = c23 + g(3, ∅) = c23 + c31 = ۶ + ۱۵ = 21 p(۲,{۳}) = ۳
  g(4,{3}) = c43 + g(3, ∅) = c43 + c31 = ۱۲ + ۱۵ = 27 p(۴,{۳}) = ۳
Set {4}:
  g(2,{4}) = c24 + g(4, ∅) = c24 + c41 = ۴ + ۶ = 10 p(۲,{۴}) = ۴
  g(3,{4}) = c34 + g(4, ∅) = c34 + c41 = ۸ + ۶ = 14 p(۳,{۴}) = ۴
k = 2, consider sets of 2 elements:
Set {2,3}:
  g(4,{2,3}) = min {c42 + g(2,{3}), c43 + g(3,{2})} = min {3+21, 12+8}= min {24, 20}= ۲۰
  p(4,{2,3}) = ۳
Set {2,4}:
  g(3,{2,4}) = min {c32 + g(2,{4}), c34 + g(4,{2})} = min {7+10, 8+4}= min {17, 12} = ۱۲
  p(3,{2,4}) = ۴
Set {3,4}:
  g(2,{3,4}) = min {c23 + g(3,{4}), c24 + g(4,{3})} = min {6+14, 4+27}= min {20, 31}= ۲۰
  p(2,{3,4}) = ۳
Length of an optimal tour:
 f = g(1,{2,3,4}) = min { c12 + g(2,{3,4}), c13 + g(3,{2,4}), c14 + g(4,{2,3}) }
= min {2 + 20, 9 + 12, 10 + 20} = min {22, 21, 30} = ۲۱
Successor of node 1: p(1,{2,3,4}) = ۳
Successor of node 3: p(3, {2,4}) = ۴
Successor of node 4: p(4, {2}) = ۲
Backtracking the optimal TSP tour reaches: 1 → ۲ → ۴ → ۳ → ۱

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

function algorithm TSP (G, n)
  for k := 2 to n do
  C({1, k}, k) := d1,k
  end for
  for s := 3 to n do
  for all S ⊆ {1, 2, . . . , n}, |S| = s do
  for all k ∈ S do
  {C(S, k) = minm≠1,m≠k,m∈S [C(S − {k}, m) + dm,k ]}
  end for
  end for
  end for
  opt := mink≠1 [C({1, 2, 3, . . . , n}, k) + d1,k]
  return (opt)
  end

[۱]

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