MN-maryam
چهارشنبه 30 اردیبهشت 1394, 17:00 عصر
بچه ها شبه کد الگوریتم دایجسترا - A-Star - سرمایش تدریجی (SA) - جستجوی عمقی - جستجوی حریصانه رو میخواستم . فقط شبه کد
هر کی میدونه لطفابگه
ebrahim.rayatparvar
چهارشنبه 30 اردیبهشت 1394, 17:37 عصر
سلام.
الگوریتم جستجوی A*
در علوم کامپیوتر، الگوریتم A* یک الگوریتم کامپیوتری است که به طور وسیع در پیمایش گراف و یافتن مسیر بین دو نقطه که گره نامیده میشوند، مورد استفاده قرار میگیرد. به علت عملکرد و دقت بالای این الگوریتم استفاده گستردهای از آن میشود. پیتر ای هارت (به انگلیسی: Peter E. Hart)، نیلز نیلسون (به انگلیسی: Nils Nilsson) و برترام رافائل (به انگلیسی: Bertram Raphael) اولین کسانی بودند که آن را در سال ۱۹۶۸ میلادی شرح دادند. این الگوریتم درواقع تعمیمی از الگوریتم دیکسترا میباشد. A* با استفاده از آروین(heuristic) عملکرد بهتری نسبت به زمان به دست میآورد.
توضیح
از جستجوی اولین بهترین استفاده میکند و کوتاه ترین مسیر را بین دو گره مبدا و مقصد داده شده به وسیله گرههای دیگر مییابد.
این روش با ترکیب g(n) هزینه رسیدن به گره n و h(n) هزینه رسیدن از گره nم تا هدف گرهها را ارزیابی میکند:
f(n)= g(n) + h(n)
از آنجایی که g(n) هزینه مسیر از گره شروع به گره n و h(n) هزینه تخمینی ارزان ترین مسیر از n به هدف است، داریم:
f(n) = هزینه برآورد ارزان ترین راه حل از طریق n
بنابراین اگر به دنبال ارزان ترین راه حل هستیم، اولین کار معقول امتحان گرهای است که کمترین مقدار h(n)+g(n) را داراست. مشخص میشود که این راهبرد کاملا معقولانهاست. اگر تابع آروین h(n) شرایط خاصی داشته باشد. جستجوی A* هم کامل و هم بهینهاست.
اگر A* همراه با الگوریتم جستجوی درخت استفاده شود، آنگاه تحلیل بهینگی آن بسیار ساده و سر راست میشود. A* بهینهاست اگر h(n) یک آروین قابل قبول باشد. یعنی h(n) هرگز هزینه رسیدن به هدف را بیش از اندازه واقعی برآورد نکند. این آروینها ذاتا بهینه هستند زیرا آنها فکر میکنند که هزینه راه حل مسئله کمتر از مقدار واقعی آن است. از آنجا که g(n) هزینه رسیدن به n را به طور دقیق نشان میدهد، میتوان بلافاصله نتیجه گرفت که f(n) هرگز هزینه واقعی راه حلی که از n میگذرد را اضافه برآورد نمیکند.
شبه کد زیر الگوریتم را توصیف میکند:
function A*(start,goal)
closedset:= the empty set // The set of nodes already evaluated.
openset:= {start} // The set of tentative nodes to be evaluated,
// initially containing the start node
came_from:= the empty map // The map of navigated nodes.
g_score[start]:= 0 // Cost from start along best known path.
h_score[start]:= heuristic_cost_estimate(start, goal)
f_score[start]:= g_score[start] + h_score[start] // Estimated total cost
// from start to goal through y.
while openset is not empty
x:= the node in openset having the lowest f_score[] value
if x = goal
return reconstruct_path(came_from, came_from[goal])
remove x from openset
add x to closedset
foreach y in neighbor_nodes(x)
if y in closedset
continue
tentative_g_score:= g_score[x] + dist_between(x,y)
if y not in openset
add y to openset
tentative_is_better:= true
else if tentative_g_score <g_score[y]
tentative_is_better:= true
else
tentative_is_better:= false
if tentative_is_better = true
came_from[y]:= x
g_score[y]:= tentative_g_score
h_score[y]:= heuristic_cost_estimate(y, goal)
f_score[y]:= g_score[y] + h_score[y]
return failure
function reconstruct_path(came_from, current_node)
if came_from[current_node] is set
p:= reconstruct_path(came_from, came_from[current_node])
return (p + current_node)
else
return current_node
پیچیدگی زمان الگوریتم A* به آرگومان آن بستگی دارد. در بدترین حالت، تعداد گرههای فضای جستجوی درون تراز هدف، نسبت به طول راه حل، نمایی میباشد. در صورتی که خطای تابع آروین سریع تر از لگاریتم هزینه واقعی رشد کند رشد نمایی اتفاق میافتد. به عبارت دیگر شرط رشد به صورت نمایی جزئی به این صورت است که:
|h(x) - h^*(x)| \le O(\log{h^*(x)})
که در آن h^*(x) هزینه واقعی رسیدن از گره n به هدف است.
زمان محاسبه، نقطه ضعف اصلی A* نیست. از آنجا که این الگوریتم، تمامی گرههای تولید شده را در حافظه نگهداری میکند معمولا بیشتر از آنکه وقت کم بیاورد، حافظه کم میآورد. به همین دلیل A* در مورد بسیاری از مسائل بزرگ، عملی نیست.
vBulletin® v4.2.5, Copyright ©2000-1403, Jelsoft Enterprises Ltd.