پرش به محتوا

اکتشاف قابل قبول

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

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

این مفهوم مرتبط با اکتشاف سازگار (یکنوا) است. همه اکتشاف‌های سازگار قابل قبول هستند، در حالی که همه اکتشافی های قابل قبول، سازگار نیستند.

الگوریتم های جستجو

[ویرایش]

الگوریتم‌های جستجو می‌توانند آگاهانه و نا آگاهانه باشند در الگوریتم جستجوی آگاهانه از هیوریستیک قابل قبول برای تخمین هزینه‌ رسیدن به گره هدف استفاده می‌ شود . این الگوریتم‌ از این مفهوم برای یافتن یک مسیر بهینه تخمینی از گره فعلی به گره هدف استفاده می کند. مثلا در الگوریتم جستجوی A* که مبنای آن بر اجتناب از گسترش مسیر‌هایی است که هم‌ اکنون گران هستند، تابع ارزیابی (از گره‌ n ام تا گره هدف) برابر است:

به‌طوری که:

= تابع ارزیابی
= هزینه‌ ای که تاکنون برای رسیدن به n صرف شده
= هزینه تخمینی از گره فعلی تا هدف

با استفاده از تابع هیوریستیک محاسبه می شود. با یک تخمین خوب می‌ توان به طرز چشمگیری هزینه جستجو را کاهش داد. همین‌ طور با یک هیوریستیک غیر قابل قبول، الگوریتم A* می‌ تواند راه حل بهینه برای یک مسئله جستجو را به دلیل برآورد بیش از حد در ، با چالش روبرو کند.

فرموله کردن

[ویرایش]
را یک گره در نظر می‌ گیریم
یک هیوریستیک (اکتشاف) است
هزینه تخمینی برای رسیدن به هدف از
هزینه بهینه برای رسیدن به هدف است
قابل قبول است اگر

یافتن مسأله هیوریستیک

[ویرایش]

یک مسئله هیوریستیک قابل قبول می تواند از یک نسخه ساده از مسئله، یا با توجه به اطلاعاتی از پایگاه داده‌ الگو که راه حل‌ های دقیق برای مسائل فرعی را ذخیره می‌ کنند، یا با استفاده از روش های یادگیری استقرایی به دست آید.

مثال‌

[ویرایش]

مسئله پازل پانزده‌تایی را در نظر بیاورید. می‌ خواهیم یک هیوریستیک قابل قبول برای این مسئله پیدا کنیم

فاصله هامینگ تعداد کل کاشی هایی است که در جای خود قرار ندارند. از آنجا که هر کاشی نابجا در جای خود حداقل یکبار جابجا می شود بنابراین تعداد کل حرکات برای رسیدن به کاشی‌ های مرتب شده، به تعداد حداقل کاشی‌ های نابجا فعلی است. واضح است که این یک هیوریستیک قابل قبول است یعنی می‌ توان تابع هزینه (تعداد حرکت) را برای رسیدن به هدف (یک پازل مرتب شده)، مینیمم فاصله هامینگ پازل دانست.

فاصله منهتن یک پازل نیز مجموع فاصله کاشی با موقعیت صحیح آن است و به صورت زیر تعریف می شود:

پازل زیر را در نظر بگیرید که در آن بازیکن می خواهد هر کاشی را طوری جابجا کند که اعداد به ترتیب شمارش عناصر ستونی مرتب شوند. فاصله منهتن در این مسئله یک هیوریستیک قابل قبول است زیرا هر کاشی می‌ بایست حداقل به تعداد نقاط بین خود و موقعیت صحیح خود جابجا شود.[۲]

43 61 30 81
72 123 93 144
153 132 14 54
24 101 111

در جدول فوق زیرنویس‌ ها، فاصله منهتن را برای هر کاشی نشان می دهند. مجموع مسافت منهتن برای پازل را می‌ توان به صورت زیر نوشت:

مثال‌

اثبات بهینگی

[ویرایش]

هر گاه برای رسیدن به گره هدف از اکتشاف قابل قبول استفاده شود، چون در هر تکرار، فقط مسیر کمترین تخمین (هزینه تا گره فعلی + هزینه اکتشاف تا گره هدف) از میان چندین مسیر نامزد را پی می‌ گیرد، در واقع وقتی کاوش به هدف می‌ رسد، ارزیابی مسیر‌ها نیز پایان می‌یابد و مهم‌تر اینکه، هرگز تمام مسیرهای بهینه را قبل از آن مرحله نمی‌ بندد (این چیزی است که با الگوریتم جستجوی A* امکان پذیر است اگر دقت خاصی صورت نگیرد [۳] )، پس این الگوریتم فقط می تواند در یک مسیر بهینه خاتمه یابد. برای اینکه بفهمید چرا؟ برهان خلف زیر را در نظر بگیرید:

فرض کنید چنین الگوریتمی در مسیر T با هزینه واقعی Ttrue بیشتر از مسیر بهینه S با هزینه واقعی Strue خاتمه یافته است. این به این معناست که قبل از خاتمه، هزینه ارزیابی شده T کمتر (یا برابر) با هزینه ارزیابی شده S بوده است (در غیر این صورت می‌ بایست S انتخاب می‌شد). این هزینه‌ های ارزیابی شده را به ترتیب Teval و Seval نشان می‌ دهیم. موارد فوق را می توان به صورت زیر خلاصه کرد.

S true < T true
T evalS eval

اکتشاف قابل قبول، بدین معناست که در مرحله ما قبل آخر   T_eval = T_true درست باشد زیرا هر گونه افزایش هزینه واقعی توسط اکتشاف در T غیر قابل قبول است و اکتشاف نمی تواند منفی باشد. از سوی دیگر، یک اکتشاف قابل قبول مستلزم آن است که S_eval  ≤  S_true باشد که ترکیب با نابرابری های فوق به ما T_eval < T_true و به‌طور خاص‌تر  T_eval ≠ T_true می‌ دهد. از آنجایی که T_eval و T_true نمی توانند با هم مساوی و هم نابرابر باشند، فرض ما باید نادرست بوده باشد و بنابراین پایان یافتن الگوریتم در مسیری پرهزینه تر از بهینه باید غیر ممکن باشد.

به عنوان مثال [۴]  فرضی تصور کنید هزینه‌ های زیر را داریم: (هزینه بالا/زیر گره، اکتشافی است، هزینه در لبه هزینه واقعی است)

 0     10   0   100   0
START ----  O  ----- GOAL
 |                   |
0|                   |100
 |                   | 
 O ------- O  ------ O
100   1    100   1   100

ابتدا شروع به بازدید از گره میانی بالا می‌کنیم، هزینه کل مورد انتظار، یعنی f(n) برابر ۱۰ است. و هدف تنها یک کاندید است، با f(n) برابر با 110 سپس گره‌های دیگر را نیز بررسی می‌کنیم و به دنبال آن هدف‌های بروز شده را نیز در نظر می‌گیریم و f(n) همه آنها کمتر از f(n) هدف فعلی است ، یعنی f(n) آنها 100, 101, 102, 102 است. بنابراین اگرچه هدف در مرحله اول یک کاندید بود، اما نتوانستیم آن را انتخاب کنیم زیرا با بررسی دیگر مسیر‌ها فهمیدیم هنوز مسیرهای بهتری وجود دارد. به این ترتیب، یک اکتشاف قابل قبول می‌تواند بهینه بودن مسیر را نیز تضمین کند.

با این حال، باید توجه داشت که هرچند یک اکتشاف قابل قبول می تواند بهینگی نهایی را تضمین کند، اما لزوما نمی‌ تواند کارآمد باشد.

منابع

[ویرایش]
  1. Russell, S.J.; Norvig, P. (2002). Artificial Intelligence: A Modern Approach. Prentice Hall. ISBN 0-13-790395-2.
  2. Korf, Richard E. (2000). "Recent progress in the design and analysis of admissible heuristic functions" (PDF). In Choueiry, Berthe Y.; Walsh, Toby (eds.). Abstraction, Reformulation, and Approximation: 4th International Symposium, SARA 2000 Horseshoe Bay, USA, July 26-29, 2000 Proceedings. Vol. 1864. Springer. pp. 45–55. CiteSeerX 10.1.1.124.817. doi:10.1007/3-540-44914-0_3. ISBN 978-3-540-67839-7. Retrieved 2010-04-26.
  3. Holte, Robert (2005). "Common Misconceptions Concerning Heuristic Search". Proceedings of the Third Annual Symposium on Combinatorial Search (SoCS). Archived from the original on 1 August 2022. Retrieved 21 November 2022.
  4. "Why do admissable [کذا] heuristics guarantee optimality?". algorithm. Stack Overflow. Retrieved 2018-12-11.

همچنین ببینید

[ویرایش]