الگوریتم *IDA چیست؟ – به زبان ساده

۲۲۵۷ بازدید
آخرین به‌روزرسانی: ۱۸ بهمن ۱۴۰۲
زمان مطالعه: ۱۲ دقیقه
دانلود PDF مقاله
الگوریتم *IDA چیست؟ – به زبان سادهالگوریتم *IDA چیست؟ – به زبان ساده

اگر الگوریتم‌های جست و جو را بررسی کنید، حتما با الگوریتم *A روبه‌رو خواهید شد. اگر بیشتر در قلمرو این دسته از الگوریتم‌ها بررسی داشته باشید، ممکن است به الگوریتمی با نام (Iterative Deepening A*‎ | ‎IDA*‎) برخورد کنید. اگرچه این الگوریتم‌ها برای افراد ناآشنا با الگوریتم‌های جست و جو، پیچیده به نظر می‌رسند، اما با صرف زمان و بررسی چند مثال به‌همراه پیاده‌سازی، درک این الگوریتم‌های قدرتمند به طرز شگفت‌آوری ساده می‌شوند. در این مطلب از مجله فرادرس می‌خواهیم به یکی از الگوریتم‌های جست و جوی آگاهانه به نام الگوریتم *IDA بپردازیم که زیرمجموعه‌ای از الگوریتم‌های پیمایش گراف و جستوی مسیر به‌ شمار می‌آید.

997696

الگوریتم *IDA هم مانند سایر الگوریتم‌های جست و جو وظیفه یافتن کوتاه‌ترین مسیر بین یک «گره» (Node) ‌مشخص از گراف به هر یک از گره‌های هدف موجود در یک گراف وزن‌دار را بر عهده دارد. IDA*‎ یک الگوریتم جست و جوی عمقی تکرار شونده است که یکی از زیر شاخه‌های الگوریتم A*‎ است و مشکل پیچیدگی فضایی الگوریتم A*‎‎ را تا حدی حل کرده است. ما ابتدا نگاه مختصری به مفهوم الگوریتم جست و جو، انواع و ویژگی‌های اصلی آن خواهیم داشت و در ادامه مروری بر الگوریتم A*‎‎‎ خواهیم داشت و سپس ‎IDA*‎ را به‌طور کامل معرفی و با A*‎ مقایسه می‌کنیم.

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

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

الگوریتم‌های جست و جو به ۲ دسته کلی تقسیم می‌شوند که در ادامه آورده‌ایم.

  •  الگوریتم‌های آگاهانه: شامل الگوریتم‌های هیوریستیک یا «ابتکاری» (Heuristic) هستند که برای به دست آوردن گره هدف از یک سری اطلاعات استفاده می‌کنند. می‌توان گفت که این دسته از روش‌ها در حل مسائل پیچیده بهتر عمل می‌کنند. البته پیش‌تر نیز در مجله فرادرس راجع به جست و جوی هیوریستیک مطالبی را ارائه کرده‌ایم.
  •  الگوریتم‌های ناآگاهانه: این دسته از الگوریتم‌ها که «الگوریتم‌های نابینا» (Blind Algorithms) نیز نامیده می‌شوند برای انتخاب حالت بعدی، از معیار ارزیابی استفاده نمی‌کنند.
«انواع الگوریتم‌های جست و جو» - برای مشاهده تصویر در اندازه اصلی، روی آن کلیک کنید.

لازم به یادآوری است که الگوریتم «هیورستیک» (ابتکاری | Heuristic)، روشی را به‌کار می‌برد که در آن نسبت به الگوریتم‌های کلاسیک عملکرد سریع‌تری دارد. همچنین در موارد زیر می‌توانند جایگزین مناسبی برای این دسته از الگوریتم‌ها باشند.

  • هنگامی‌که الگوریتم‌های کلاسیک توانایی یافتن را‌ه‌حل در زمانی معقول را ندارند.
  • زمانی‌که پیدا کردن جواب دقیق در فضای جست و جو برای الگوریتم‌های کلاسیک امکان‌پذیر نیست.

خصوصیات اصلی الگوریتم جست‌ و جو

به‌طو‌ر کلی، استاندارد بودن یک الگوریتم جست‌ و جو با ۵ ویژگی اصلی بیان شده در زیر معنا پیدا می‌کند.

  • «کامل بودن» (Completeness): الگوریتم جست و جو در صورتی کامل است که - در صورت وجود یک راه‌حل - تضمین کند راه‌حلی را در زمانی محدود پیدا می‌کند.
  • «بهینگی» ‌(Optimality): یک الگوریتم را در صورتی بهینه می‌دانیم که تضمین کند بهترین یا مقرون به صرفه‌ترین راه‌حل را در صورت وجود پیدا می‌کند.
  • «مقبولیت» (Admissibility): در «جستجوی آگاهانه» (Informed Search)، مقبولیت به ویژگی یک تابع هیوریستیک اشاره دارد که هرگز هزینه دست‌یابی به هدف را بیش از مقدار واقعی تخمین نزند. تابع هیوریستیک دارای مقبولیت، تضمین می‌کند که الگوریتم جستجوی آگاهانه، راه‌حل بهینه را پیدا خواهد کرد.
  • «پیچیدگی زمانی» (ُTime Complexity): این ویژگی، بیشینه زمان مورد نیاز برای حل مسئله را بیان می‌کند.
  • «پیچیدگی مکانی» (Space Complexity): این خصوصیت بیان‌گر حداکثر حافظه یا فضای ذخیره‌سازی مورد نیاز هنگام انجام عملیات جست و جو است.

 معرفی الگوریتم A*‎

الگوریتم A*‎، الگوریتمی هیوریستیک به‌شمار می‌رود که با تلاشی مؤثر به‌دنبال پیدا کردن گره «مقصد» (Goal) است. این الگوریتم در هر مرحله از مسیر خود ۳ معیار مختلف فهرست شده در ادامه را اندازه‌گیری می‌کند.

  • هزینه G
  • هزینه H
  • هزینه F

هزینه G

هزینه‌ای که نیاز است تا الگوریتم از گره شروع به گره فعلی برسد، «هزینه G» نامیده می‌شود. به زبان ساده این هزینه، میزان دور بودن گره جاری از گره شروع را نشان می‌دهد. برای مثال اگر برای رسیدن از گره شروع به گره جاری ۵ واحد نیاز باشد، مقدار هزینه G برابر با ۵ خواهد شد. اما توجه داشته باشید که مقدار این هزینه همیشه برابر با فاصله ۲ گره نخواهد بود چون گاهی ممکن است موانعی در مسیر موجود باشند که نیاز است تا در نظر گرفته شوند.

هزینه H

هزینه تخمینی برای رسیدن از گره جاری به گره هدف «هزینه H» نامیده می‌شود. تخمین و محاسبه این معیار در مسیریابی‌های پیچیده‌تر ممکن است سختی بیشتری به‌دنبال داشته باشد. اما به‌طور کلی این معیار نیز میزان دور بودن گره جاری از مقصد را نشان می‌دهد. برای مثال، اگر در این مورد هم گره جاری تا گره هدف ۷ واحد فاصله داشته باشد - حتی در صورت وجود مانعی بر سر راه - می‌توان هزینه H را برابر با مقدار ۷ در نظر گرفت. به‌طور کلی، این معیار  به عنوان حداقل فاصله گره جاری تا گره هدف در نظر گرفته‌ می‌شود.

 هزینه F

این معیار در واقع، هر ۲ هزینه G و H را به منظور دستیابی به هزینه کلی رسیدن از گره جاری به گره هدف، با هم جمع می‌کند.

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

الگوریتم در ابتدا و در گره شروع، هر ۳ هزینه را برای گره‌های مجاور محاسبه می‌کند. در ادامه،‌ گره‌‌ای انتخاب می‌شود که کمترین مقدار هزینه F را داشته باشد و این فرایند دوباره تکرار می‌شود. هنگامی‌که الگوریتم به گره‌ای با هزینه H صفر رسید،‌ آنگاه یعنی به گره مقصد رسیده است. با دستیابی به گره هدف، الگوریتم A*‎ با انجام عمل «بازگشت به عقب» (Back Tracking) مسیر مبدا تا مقصد را پیدا می‌کند.

تصویر آورده شده در ادامه، نحوه عملکرد الگوریتم A*‎ را نشان داده است. در این تصویر، گره‌های سبزرنگ «گره‌‌های باز» نیز نامیده می‌شوند، به این معنا که مقدار هزینه برای این دسته از گره‌ها محاسبه شده است اما چون در تمامی گره‌های باقی‌مانده، گره‌هایی با هزینه F کمتری هم وجود دارند، تا این لحظه گسترش پیدا نکرده‌اند. لازم است توجه داشته باشیم که گره‌های قرمزرنگ یا «گره‌های بسته» گسترش یافته‌اند اما به‌عنوان گره هدف تشخیص داده نشده‌اند.

پیمایش الگوریتم A* در مسیری پیچیده تر
نحوه پیمایش در الگوریتم A*‎

الگوریتم *IDA‎ چیست؟

الگوریتم *IDA برای یافتن مسیر بهینه از روش «تکرارشونده عمقی» (Iterative Deepening) استفاده می‌کند که که این سیاست باعث می‌شود تا نسبت به الگوریتم A*‎ برای ردیابی مسیرها از میزان حافظه کمتری استفاده کند. این استفاده از حافظه کمتر به ویژه زمانی به وجود می‌آید که تعداد گر‌ه‌های باز بیشتری برای بررسی داشته باشیم. در روش A*‎‎‎‎، کل فضای جست و جوی بررسی‌ شده، در حافظه نگهداری می‌شود که این مورد در فضای‌های جست و جوی بزرگ ممکن است با چالش همراه باشد. این الگوریتم به‌جای نگهداری کل فضای جست و جوی بررسی‌شده، در هر تکرار، تنها به ذخیره مسیر طی شده تا گره جاری و هم‌چنین هزینه‌های مربوط به آن می‌پردازد و به منظور پیمایش در فضای جست‌ و‌ جو از روش «اول عمق» (Depth First) استفاده می‌کند.

با این حال، روش IDA*‎ به‌دلیل رویکرد جست و جوی مورد استفاده، نسبت به A*‎، کند‌تر عمل می‌کند. مهم‌ترین دلیلی که برای کند بودن سرعت این الگوریتم می‌توان بیان کرد این است که IDA*‎ نیاز دارد تا به‌صورت مکرر گره‌های مشابه را در فضای جست و جو گسترش دهد. این الگوریتم در هر تکرار، فضای جست و جو را با در نظر گرفتن محدودیت تعیین شده به‌صورت عمقی جست و جو می‌کند و ممکن است گره‌ها را به دفعات بازبینی کرده و گسترش دهد که این نیز پیچیدگی زمانی را بیشتر می‌کند.

مراحل اجرای الگوریتم *IDA به این شکل است که ابتدا هزینه H را برای گره شروع محاسبه می‌کند و آن را به‌عنوان مقدار «آستانه» (Threshold) در نظر می‌گیرد. در ادامه نیز، تنها گره‌های دارای هزینه F کمتر یا مساوی با مقدار آستانه را از طریق پیمایش عمقی گسترش می‌دهد. به بیان دیگر، IDA*‎، جست و جوی عمقی را به گونه‌ای انجام می‌دهد که در هر مرحله، گره‌هایی با مقادیری بیش از مقدار آستانه تعیین‌شده، هرس شوند.

بدین‌ترتیب در IDA*‎ با رسیدن به گره هدف می‌توان گفت که بهترین پاسخ پیدا شده است. در ادامه کار، این الگوریتم، مسیر بهینه را در همان «پشته» (Stack) فعلی - که شامل همه گره‌های مسیر فعلی است - پیدا می‌کند. در غیر این صورت، مقدار آستانه را به میزان کمترین هزینه گره‌های گسترش‌نیافته، افزایش می‌دهد. سپس این روند را تا هنگام پایان الگوریتم‎ یا هنگام بروز شکست - عدم یافتن راه‌حل - تکرار می‌کند. تصویری که در ادامه آورده شده، نحوه کار الگوریتم *IDA را به‌خوبی نشان می‌دهد.

پیمایش الگوریتم IDA*‎ در مسیر پیچیده‌ تر
پیمایش الگوریتم *IDA‎ در مسیر پیچیده‌تر

در این مثال، عملکرد کند الگوریتم *IDA را به‌وضوح می‌توان مشاهده کرد. همان‌طور که پیش‌تر هم بیان کردیم، این الگوریتم در مقایسه با A*‎ سرعت پایین‌تری دارد. چون الگوریتم A*‎ هر گره باز را تنها یک مرتبه بررسی می‌کند و سپس آن گره بسته می‌شود. در حالی‌که IDA*‎ ممکن است همان گره را تعداد دفعات بیشتری - هزار، ده‌هزار یک‌میلیون بار یا حتی بیشتر - پیش از رسیدن به راه‌حل بررسی کند. با این وجود، همان‌طور که پیش‌تر هم بیان شد، به‌کارگیری بهینه حافظه، یکی از دلایلی است که در برخی موارد باعث برتری این الگوریتم نسبت به A*‎ می‌شود.

پیمایش الگوریتم IDA*‎ در مسیر ساده تر
پیمایش الگوریتم *IDA در مسیر ساده‌تر

هنگامی‌که A*‎ گره‌ای را گسترش می‌دهد، به‌طور معمول، گره‌های بیشتری را به فهرست گره‌های باز اضافه می‌کند. بنابراین به‌کارگیری الگوریتم A*‎ در «فضا‌های جست‌ و جوی بزرگ» (Massive mazes) - به‌خصوص هنگام محدود بودن حافظه - می‌تواند بسیار چالش برانگیز باشد. این در حالی است که در «فضاهای جست‌ و جوی محدودتر ولی با مسیری پیچیده‌تر» (Confined or Roundabout mazes)، استفاده از A*‎ انتخاب بهتری محسوب می‌شود زیرا در این نوع مسیرها عملکرد IDA*‎ به شدت کند می‌شود. در وب‌سایت PathFinding.js «+» می‌توانیم آزمایش‌های بیشتری را در این مورد بررسی کنیم. به این صورت که مسیرهای دلخواه - از نظر پیچیدگی - را ایجاد و الگوریتم‌های جستجو مانند IDA*‎ را روی آن اجرا کنیم.

مراحل گام به گام اجرای الگوریتم *IDA

در ادامه، گام‌های اجرای الگوریتم جست و جوی IDA*‎ را آورده‌ایم.

  1. تعیین مقدار «آستانه» (Threshold): ابتدا مقدار آستانه‌ای برابر با هزینه هیوریستیک تخمینی از گره شروع تا هدف، تعیین می‌شود.
  2. جست و جوی اول عمق با در نظر گرفتن مقدار آستانه: از گره شروع و با در نظر گرفتن محدودیت آستانه، جست‌و‌جوی اول عمق انجام می‌شود. به بیان دیگر، هر گره‌ای که هزینه F  آن بیشتر از مقدار آستانه باشد، هرس می‌شود.
  3. بررسی گره هدف: در صورت پیدا شدن گره هدف در حین فرایند جست و جو، مسیر بهینه تا هدف را به عنوان خروجی برمی‌گرداند.
  4. به روز رسانی مقدار آستانه: در صورت پیدا نشدن گره هدف در حین فرایند جست و جو، IDA*‎، مقدار آستانه را به میزان کمترین هزینه در میان گره‌های هرس شده افزایش می‌دهد.
  5. تکرار مراحل تا دستیابی گره هدف: الگوریتم، مراحل پیشین را تکرار و تا یافتن گره هدف، مقدار آستانه را به‌روز‌رسانی می‌کند.

مثالی از پیمایش الگوریتم *IDA‎‎ در یک گراف

در مثالی که آورده‌ایم، مراحل گام به گام اجرای الگوریتم *IDA‎‎ را در یک گراف نشان داده‌ایم.

مقادیر نوشته شده روی هر گره بیان‌گر هزینه F مرتبط به آن‌ است. در این مثال، ابتدا مقدار «آستانه» (Threshold) را ۳ در نظر می‌گیریم و گام‌های الگوریتم را طبق مراحل گفته‌شده طی می‌کنیم. در هر شاخه، عمق درخت را تا زمانی‌که هزینه F گره‌ها از مقدار آستانه بزرگتر نباشد، پیموده و هزینه F هر گره‌ای که از مقدار آستانه بزرگ‌تر باشد را نگه می‌داریم. این مرحله تا زمانی ادامه می‌یابد که تمامی گره‌های دارای هزینه FF، گسترش یابند. سپس پیمایش الگوریتم دوباره از گره ریشه، شروع می‌شود با این تفاوت که این بار کم‌ترین هزینهF - که در تکرار قبلی حفظ شده است - به‌عنوان مقدار آستانه انتخاب می‌شود. به این ترتیب، مراحل الگوریتم تا هنگام دستیابی به هدف یا گسترش تمامی گره‌ها ادامه می‌یابد.

نحوه پیمایش گراف در الگوریتم IDA*‎
پیمایش یک گراف با الگوریتم *IDA‎

مزایا و معایب الگوریتم *IDA

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

مزایای الگوریتم *IDA

در فهرست زیر، مزایای این الگوریتم را آورده‌ایم.

بر اساس رای ۷ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
MediumalgorithmsinsightAlgorithms & TechnologiesGeeksforGeeksjavaTpointwikipedia
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *