استدلال استراتژی بر اساس نقشه نفوذ

تغییرات پروژه از تاریخ 1394/11/05 تا حالا
نقشه نفوذ (Influence Map) یک نوع نمایش دانش ایجنت‌ها از جهان خود برای بدست آوردن استراتژی بهینه است. در بازی‌های رایانه ای نقشه نفوذ مشخص می‌کند، نیروهای بازیکن درچه مکان‌هایی مستقر شده‌اند، نیروهای دشمن کجا هستند و یا در چه مکان‌هایی ممکن است وجود داشته باشند، مرز میان نیروهای بازیکن و دشمن چه مکانهایی است، بزرگترین نبردها در چه مکان‌هایی اتفاق افتاده است، چه مکان‌هایی هنوز تجسس نشده است، دشمن در آینده به احتمال زیاد از چه مکان‌هایی نفوذ می‌کند، مناطقی که دارای موقعیت استراتژیک هستند را معرفی میکند، نقاط ضعف دفاعی دشمن و مناطق آسیب‌پذیر را مشخص میکند، مناطق مسدود[^Choke points] بر روی زمین را پیدا کند و ویژگی‌های بامعنی دیگری را - که انسان به کمک بصیرت و تمرین آنها را کشف می‌کند - عرضه می‌کند. در این روش یک ایجنت از تمامی این اطلاعات استفاده می‌کند و به صورت بهنگام [^Real-Time]  اطلاعات را از محیط بازی دریافت می‌کند و بر اساس آنها بهترین استراتژی را انتخاب می‌کند[1]. 
![شکل الف - تکنیک نقشه نفوذ اولین بار در سری بازی‌های KillZone استفاده شده‌اند.](https://boute.s3.amazonaws.com/222-killzone-2-multiplayer-bots-57-728.png)

# **مقدمه**

----------

سبک بازی‌‌های استراتژیک بهنگام [^Real-tiem strategic (RTS)] ژانری است که در آن بازیکن به منظور فائق آمدن بر دشمن نیاز به ساختن یک زیربنای اقتصادی (بدست آوردن منابع و ساختن پایگاه) و یک پایگاه نظامی (برای آموزش واحدهای نظامی) و به طور کلی انتخاب استراتژی بهینه می‌باشد. بازی‌های RTS محیطی نامعین دارند، تقریبا قابل مشاهده هستند و دارای فضای حالتی بسیار عظیم هستند. بنابراین در مقایسه با بازی‌های تخته‌ای، چالش‌های بیشتری برای هوش مصنوعی ایجاد می‌کنند. یکی از این چالش‌ها کنترل گروه می‌باشد. چگونه می‌توان به صورت بهینه یک جوخه را کنترل کرد و یا رفتارهای استراتژیک و تاکتیکال پیچیده را در محیطی بهنگام شبیه‌سازی کرد. اینها هنوز هم مسائلی باز در تحقیقات هوش مصنوعی هستند[4]. 
تجربه نشان داده است کلید اساسی انجام یک تصمیم‌گیری کارا تنها داشتن بهترین داده‌ها نیست، بلکه نحوه ارائه داده‌ها به روش درست نیز اهمیت دارد. داده‌های خام تا زمانی که به اطلاعات طبقه‌بندی شده تقسیم نشوند، غیرقابل استفاده خواهند بود. یک نقشه نفوذ یک نمایش فضائی از دانش یک عامل درباره جهان خود می‌باشد. کامپیوتر با استفاده از این امکان می‌تواند یک دید استراتژیک از وضعیت فعلی جهان خود داشته باشد. نقشه نفوذ یک تکنیک پرارزش و اثبات شده برای انجام ارزیابی استراتژی می‌باشد. نقشه نفوذ اکثرا در بازی‌های استراتژیک مورد استفاده قرار می‌گیرد، اما برای ژانرهای دیگری نیز که نیازمند آنالیز تکنیکال می‌باشد می تواند سودمند واقع شود[1].
در عمل نقشه نفوذ سه نوع اطلاعات سودمند برای تصمیم‌گیری را میتواند فراهم کند: 
+ *موقعیت فعلی:* نقشه نفوذ به طور خلاصه اطلاعات مفید و موثر در جهان را برای ما مهیا می‌سازد و می‌تواند دیدی کلی و آسان برای فهم محیط به ما بدهد.
+ *اطلاعات آماری گذشته:* علاوه بر ذخیره اطلاعات مربوط به موقعیت فعلی نقشه نفوذ رویدادهایی را نیز که در یک دوره معین اتفاق افتاده را به خاطر می‌سپارد. به طور مثال می‌توان فهمید که آیا این مکان قبلا مورد حمله قرار گرفته است؟ نتایج حمله قبلی چگونه بوده است؟
+  *پیش‌بینی آینده:* جنبه‌ای که کمتر به آن پرداخته شده‌ است پیش بینی آینده با استفاده از نقشه نفوذ و نقشه زمین [^terrain map] می‌باشد. میتوان فهمید که دشمن در آینده احتمالا به چه مناطقی خواهد رفت و تأثیر آن چگونه خواهد بود.
بدیهی است که هر یک از خصوصیت‌های نقشه نفوذ می‌تواند به ایجنت کمک کند تا تحلیل و محاسباتی به مراتب هوشمندانه‌تر انجام دهد. 

# **اساس و اجزای نقشه نفوذ**

----------

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

## بازنمایش سطوح بازی
به منظور تحلیل تاکتیکال ما نیاز به تقسیم سطوح بازی به قطعه‌هایی به هم پیوسته داریم. مناطقی که در یک قطعه هستند باید از لحاظ خصوصیاتی که ما برای آنها تعریف کرده‌‌ایم تقریبا یکسان باشند. به عنوان مثال اگر ما می‌خواهیم نقشه‌ای برای میزان تاریکی در مناطق بازی داشته باشیم، همه مناطقی که در میان یک قطعه هستند باید تقریبا میزان روشنایی یکسانی داشته باشند. 
به طور کلی دو انتظار از بازنمایش نقشه نفوذ وجود دارد:
+ تقسیم‌بندی محیط[^Spatial partition] : نقشه نفوذ باید یک روش ساده و کارا برای تقسیم‌بندی و ذخیره اطلاعات (اثرات) برای هر قسمت ارائه دهد. این تقسیم‌بندی به ایجنت این امکان را خواهد داد که بتواند اطلاعات گذشته را ذخیره کند و در هر لحظه به صورت کارا آمار و اطلاعات جدید را بدست آورد.
+ اتصال[^Connectivity] : نحوه اتصال قسمت‌های مختلف باید به سادگی در نقشه نفوذ مشخص باشد. بر اساس این ارتباطات الگوریتم حاکم بر نقشه نفوذ می‌تواند پیش‌بینی کند که هر رویداد تا چه اندازه می‌تواند در سطوح بازی نفوذ پیدا کند و در آینده ممکن است چه اتفاقاتی بیافتد.

انواع مختلفی از روش‌های بازنمایش نقشه نفوذ وجود دارد که در ادامه به چند مورد اشاره می‌شود.
1. شبکه دو بعدی[^2D Grid] : این روش بهترین روش برای بازی‌هایی است که بتوان آنها را به یک جهان تقریبا دوبعدی تشبیه کرد. پردازش این نوع نمایش بسیار سریع است و پیاده‌سازی آن ساده است. عیب این روش مصرف زیاد حافظه می‌باشد. اگر محیط بازی یک محیط پراکنده می‌باشد بهتر است از این روش استفاده نشود. این روش بر اساس یک شبکه ماتریسی می‌باشد که هر سلول آن یک قسمت از فضا را نشان می‌دهد و اطلاعات مربوط به آن قسمت در آن ذخیره شده است. ذکر این نکته قابل اهمیت است که اگرچه امروزه اکثر بازی‌های استراتژیک در فضایی سه‌بعدی هستند اما در بیشتر موارد ما می‌توانیم یک شبکه دو‌بعدی بر محیط بازی تحمیل کنیم و از آن برای تحلیل تاکنیکال استفاده کنیم. در ادامه این پروژه نیز از این روش برای بازنمایش اطلاعات استفاده می‌شود. 
2. گراف‌های محیط[^Area Graphs] : اگر در بازی یک شبکه ناوبری[^Navigation mesh] برای رفت و آمد عامل‌های NPC [^Non-player characters] وجود داشته باشد، اساس نقشه نفوذ می‌تواند بر روی همین شبکه پیاده‌سازی شود. مزیت این روش این است که تغییرات گسترده‌ای نیاز ندارد. عیب آن نیز این است که در برخی موارد که به جزئیات زیاد برای تصمیم گیری نیاز است این روش دقت کافی را در اختیار ما قرار نمی‌دهد. 
3. شبکه هوایی[^Waypoint Network] : استفاده از یک شبکه فضایی کامل در سطح سه‌بعد می‌تواند برخی از مشکلاتی که در محیط‌های سه‌بعدی وجود دارد را مرتفع سازد. شما به راحتی می‌توانید گره‌های گراف شبکه هوایی خود را در یک ساختمان با چند طبقه قرار دهید و تمام فضا‌ها را پوشش دهید. عیب اینگونه باز‌نمایش محیط هزینه سنگین محاسبات و پزدازش است که از دو روش قبلی بیشتر است. 
![شکل ۲-۱: شبکه دو بعدی](https://boute.s3.amazonaws.com/222-IM_2DGrid.huge.png)
![شکل ۲-۲: گراف‌های محیط](https://boute.s3.amazonaws.com/222-IM_AreaGraph.huge.png)
![شکل ۲-۳: شبکه هوایی](https://boute.s3.amazonaws.com/222-IM_WaypointNetwork.huge.png)

## نفوذ و نحوه انتشار آن
اگر چهار سرباز خط آتش در مکانی بیرون از میدان نبرد اردو زده باشند، آن مکان تحت نفوذ آنها است اما احتمالا نه به صورت خیلی قوی. حتی یک جوخه کوچک هم می‌تواند به راحتی آن اردوگاه را تصاحب کند. اگر به جای آن یک هلیکوپتر مسلح بر بالای این اردوگاه در حال پرواز باشد، آن منطقه به مراتب بیشتر تحت کنترل آنهاست. اگر یک ضدهوایی در این منطقه قرار گرفته باشد آنگاه نفوذ آنها چیزی مابین دو حالت قبلی است (ضدهوایی ها در مقابل پیاده‌نظام‌ها آنچنان سودمند نیستند). 
میزان نفوذ و اثر با فاصله گرفتن افت می‌کند. اگر ما به قدرت نفوذ به عنوان یک کمیت نگاه کنیم، آنگاه قدرت نفوذ با فاصله گرفتن کمتر و کمتر می‌شود. هرچه از واحد (در اینجا واحد به معنای یک واحد نظامی است، مانند سرباز، مسلسل، تانک و ...) دورتر باشیم میزان اثر آن کمتر است. در نهایت تأثیر آنها آنچنان کوچک خواهد شد که دیگر در نقشه انتشار نمی‌یابد. 
برای مدل کردن این موضوع ما می‌توانیم افت نفوذ را خطی در نظر بگیریم. با دو برابر شدن فاصله تأثیر نصف می‌شود. میزان تأثیر با فرمول زیر بدست می‌آید که در آن ${ I }_{ d }$ میزان اثر در فاصله $d$ و ${ I }_{ 0 }$ میزان اثر در فاصله صفر (اثر اولیه) است. 
$${ I }_{ d } = \frac { { I }_{ 0 } }{ 1+d }  $$
ما همچنین می‌توانیم میزان برد نفوذ را افزایش دهیم. با این منظور می‌توانیم از فرمول زیر استفاده کنیم.
$${ I }_{ d }=\frac { { I }_{ 0 } }{ \sqrt { 1+d }  } $$
یا می‌توانیم برای کاهش برد و افت شدید اثر، میزان اثر را با عکس مجذور فاصله تناسب دهیم.
$${ I }_{ d }=\frac { { I }_{ 0 } }{ { (1+d) }^{ 2 } } $$
افت خطی علاوه بر پردازش سریع تأثیر کاملا منطقی است و تجربه نشان داده که نتایج خوبی حاصل می‌شود.
برای انجام تحلیل باید برای هر واحد مقدار تأثیر نظامی اولیه در نظر گرفت. این مقدار چیزی متفاوت با قدرت حمله یا دفاع واحد می‌باشد. به عنوان مثال یک واحد شناسایی که می‌تواند به توپ‌خانه دستور آتش بدهد دارای تأثیر وسیعی است در حالی که توان جنگیدن این واحد به این اندازه نمی‌باشد. این مقادیر در عملکرد هوش مصنوعی تأثیر به‌سزایی دارند و معمولا همیشه قدری میزان‌سازی [^Tunning] برای رسیدن به یک حالت تعادل نیاز است. به این ترتیب با استفاده از فرمول افت و میزان قدرت ذاتی هر واحد، می‌توان نفوذ هر جناح را در هر منطقه از بازی بدست آورد: چه کسی آن منطقه را کنترل می‌کند و این کنترل چقدر است؟ میزان نفوذ هر جناح در منطقه‌ای خاص به سادگی با جمع نفوذ هر واحدی در آن منطقه که به آن جناح نعلق دارد بدست می‌آید. درجه کنترل به راحتی با استفاده از تفاضل میزان نفوذ طرفین بدست می‌آید. اگر این مقدار منفی باشد یعنی این منطقه تحت کنترل دشمن است و میزان این کنترل با قدرمطلق این مقدار بدست می‌آید. اگر تفاضل نفوذ طرفین (نفوذ ایجنت - نفوذ دشمن) مثبت باشد و میزان این تفاوت بسیار زیاد باشد، این نتیجه گرفته می‌شود که آن منطقه امن می‌باشد. نتیجه نهایی یک نقشه نفوذ می‌باشد: مجموعه‌ای از مقادیر که کنترل و میزان نفوذ طرفین (و معمولا میزان امنیت) را در هر مکان از بازی مشخص می‌کند[2]. 

![شکل ۲-۴: یک نقشه نفوذ که برای تمامی مکان‌ها محاسبه شده است.  دو جناج سفید (W) و سیاه (B) با تعداد کمی نیرو وجود دارند و نفوذ نظامی هر واحد با عددی نشان داده شده است. هر مکان هرچه تیره‌تر باشد، نفوذ در آن مکان بیشتر است. مرز میان مناطقی که طرفین تحت کنترل دارند نیز مشخص شده است.](http://uupload.ir/files/pbbz_simple_influence_map.png)

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

+ **توانایی رزم:** نشان‌دهنده این است که میزان قدرت و پتانسیل تخمینی واحدهای موجود در سلول به چه میزان است. این مقادیر باید با استفاده از فاکتورهایی مانند میزان قدرت هجومی یا دفاعی، میزان سلامتی نیروها[^Hit point]، برد حمله، سرعت آتش و از این قبیل موارد محاسبه و شمارش شوند. دسته‌بندی مناسب نیروها هم در این زمینه می‌تواند مفید واقع شود. به عنوان مثال می‌توان قدرت تیراندازان را در مقابل نیزه‌اندازان، پیاده‌نظامان در مقابل سواره‌نظامان، نیروهای هوایی در مقابل نیروهای دریایی و نیروهای زمینی را به طور نسبی سنجید و داده‌های منطقی‌تری ایجاد نمود.
+ **سرمایه‌های آسیب‌پذیر:** این یک مقدار تخمینی از وسایل گران‌بها و حیاتی‌ای است که بازیکن در این سلول دارد، مانند تکه‌ای از دهکده بازیکن و یا پایگاه نظامی بازیکن.
+ **میدان دید منطقه:** عددی ک نشان‌دهنده این است در این مکان تا چه مسافتی قابل دید یا غیر قابل مشاهده برای بازیکن است. به عنوان مثال سلولی که در آن یک دکل قرار داده شده است میدان دید به مراتب بهتری از مناطق درون یک جنگل دارد.
+ **شمار اجساد:** مشخص می‌کند که چه تعداد از واحد‌ها در این مکان در گذشته کشته شده‌اند و در چه زمانی.
+ **منابع:** میزان کلی منابعی که هنوز برای بهره‌برداری در دسترس هستند، منابعی نظیر طلا، الوار و ...
+ **قابلیت عبور:** تخمینی از میزان دشواری عبور از این مکان که بهتر است برای انواع مختلف واحدها نظیر هوایی، پیاده و ماشینی به طور جداگانه نگهداری و تحلیل شوند. ایده مناسب دیگر این است که این میزان برای ۸ جهت مختلف نگهداری شود.

یک نقشه نفوذ می‌تواند تمامی این مقادیر به طور جداگانه برای هر ایجنت هوش مصنوعی ثبت و تحلیل کند. اما داشتن چند نقشه نفوذ موازی نیز ایده‌ای جالب است. تصور کنید که هر ایجنت علاوه بر اینکه نقشه نفوذ مخصوص به خود، یک نقشه نفوذ دیگری که دانش او را از بقیه بازیکنان نشان می‌دهد را بهنگام می‌کند. این کار به شما این اجازه را می‌دهد که نقاط قوت یا ضعف خاصی از دشمن را که منجر به رسیدن هدفی خاص می‌شود را به صورت گروهی دنبال کنیم. به عنوان مثال فرض کنید که می‌خواهیم بمبی را که در مکانی وسیع کار گذاشته شده است پیدا کنیم و آن را خنثی سازیم. بدون استفاده از چنین راهکاری رسیدن به این هدف برای ایجنت‌های انفرادی بسیار دشوار می‌باشد[1]. 


# **کارهای مرتبط**

----------

تاکنون کارهای و تلاش‌های زیادی بر روی بازسازی حرکات معقول برای دسته‌‌ها انجام شده است. رفتار دسته‌ای پرنگان که در سال ۱۹۸۷ توسط Reynolds معرفی شد[5]، پس از آن مسیریابی بهینه با استفاده از نقشه نفوذ[1] و در نهایت در سال ۲۰۱۱ تلفیقی از این دو تکنیک برای بازی‌های RTS ارائه شد[6].

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

## محاسبه میزان نفوذ
برای محاسبه نقشه ما نیاز به پردازش تأثیر هر واحد در هر مکان از بازی هستیم. در عمل اگر تعداد واحدها $n$  و تعداد سلول‌های نقشه $m$ باشد، زمان محاسبه از پیچیدگی $O(nm)$ و میزان فضای مورد نیاز حافظه از پیچیدگی $O(m)$ می‌باشد. مسلما این کار یک تکلیف سنگینی است. برای مثال در بازی‌های استراتژیک فعلی که در یک صحنه هزاران واحد و میلیون‌ها مکان وجود دارد، میلیارد‌ها محاسبه در هر دوره  را می‌طلبد. به این منظور سه رویکرد برای بهبود این امر وجود دارد که در ادامه به طور خلاصه به آنها می‌پردازیم.

### محدود کردن شعاع تأثیر
اولین رویکرد این است که شعاع تأثیر را برای هر واحد محدود کنیم. فراتر از این شعاع واحد نمی‌تواند تأثیری داشته باشد، هر چند که می‌تواند تأثیر کوچکی داشته باشد. حداکثر شعاع می‌تواند به صورت دستی تعیین شود، یا می‌توان از یک حد آستانه استفاده کرد. اگر ما از یک فرمول افت خطی برای اعمال تأثیر استفاده می‌کنیم، میزان شعاع نفوذ می‌تواند از فرمول زیر بدست آید که در آن ${ I }_{ t }$ حد آستانه می‌باشد. 
$$r = \frac { { I }_{ 0 } }{ { I }_{ t } -1}  $$
این رویکرد این امکان را به ما می‌دهد که با یک پیمایش[^Iterate] بر روی واحد‌ها، میزان اثر واحد را بر روی مکان‌های که در شعاع آن وجود دارند اعمال کنیم. پیچیدگی این روش $O(nr)$ و میزان فضای مورد نیاز برای حافظه $O(m)$ می‌باشد. عیب این رویکرد این است که تأثیر‌های کوچک نمی‌توانند تا شعاع زیادی نفوذ کنند و عملا در نطفه خفه می‌شوند. به عنوان مثال سه سربازی که در کنار یکدیگر در یک منطقه حضور دارند می‌توانند میزان معقولی از نفوذ در آن منطقه ایجاد کنند، اما هنگامی که این سه سرباز پراکنده می‌شوند، هر کدام به صورت انفرادی نفوذ کمتری خواهند داشت.
### فیلترهای کانولوشن[^Convolution Filters]
در این رویکرد در ابتدا با یک نقشه نفوذ‌ی شروع خواهیم کرد که در آن تنها مکان‌هایی مقدار دارند که در آنها یک واحد وجود دارد. شما می‌توانید این را اینگونه تصور کنید که لکه‌هایی از نفوذ در دل نقشه بدون هیچ تأثیری وجود دارند.  سپس الگوریتم بر تمامی سلول‌های نقشه عمل می‌کند و مقادیر آنها را بگونه‌ای تغییر می‌دهد که در آنها علاوه بر اثر واحد‌های موجود در همان سلول، نفوذ همسایگانش نیز جا داده شده است. این یک روش مرسوم در کاربردهای گرافیکی می‌باشد که در آن نتیجه مات کردن[^Blurring] لکه‌های اولیه حاصل می‌شود. هرچه مقادیر اولیه بزرگتر باشند، مات کردن (اعمال نفوذ) آن در سطح وسیعتری انجام می‌شود.
این رویکرد از یک فیلتر استفاده می‌کند: یک قاعده که می‌گوید مقدار یک مکان تحت تأثیر همسایگانش چگونه است. بسته به این که ما از چه نوع فیلتری استفاده کنیم، می‌توانیم انواع مختلفی از مات کردن را اعمال کنیم. فیلتری که بیش از همه مورد استفاده قرار می‌گیرد «فیلتر Gaussian» نام دارد و بدلیل اینکه دارای خصوصیت‌های ریاضی‌ای است که به راحتی قابل محاسبه است بسیار مفید می‌باشد. 
به منظور انجام فیلترینگ، هر مکان موجود در نقشه باید به وسیله این قاعده بهنگام شوند. برای اینکه مطمئن شویم نفوذ واحد‌ها به میزان قابل قبولی در نقشه گسترش داده شده‌اند، باید برای هر دوره چند مرتبه فیلترینگ انجام داد. اگر تراکم واحد‌ها در بازی کم باشد، این رویکرد پرهزینه‌تر از حتی الگوریتم خام اولیه می‌باشد.
### سرریز مقادیر در نقشه[^Map Flooding]
در آخرین رویکرد ما از یک فرض بسیار ساده استفاده می‌کنیم: نفوذ در هر مکان برابر تأثیری است که قوی‌ترین (مؤثرترین) واحد در آن مکان دارد. با این فرض اگر یک تانک یک خیابان را پوشش دهد، نفوذ آن به اندازه زمانی است که ۲۰ سرباز هم در کنار تانک در حال پوشش خیابان باشند. واضحا این رویکرد منجر به ایجاد برخی خطاها می‌شود؛ ایجنت فرض می‌کند که یک واحد قدرتمند می‌تواند بر تعداد زیادی از سربازان فائق آید. 
در نیمه پر لیوان، یک الگوریتم بسیار سریع است که می‌تواند مقادیر نفوذ را بر اساس الگوریتم دایجسرا[^Dijkstra algorithm]  محاسبه کند. الگوریتم به سرعت نقشه را با مقادیر پر می‌کند، به سراغ هر واحد می‌رود و نفوذ آن را در نقشه منتشر می‌کند. این رویکرد از نظر پیچیدگی زمانی حوالی $O(min[nr, m])$ است و از نظر حافظه از مرتبه $O(m)$ می‌باشد. به خاطر اینکه این الگوریتم از نظر پیاده‌سازی است و در عمل بسیار سریع عمل می‌کند، این الگوریتم در موارد بسیاری می‌تواند مورد استفاده قرار گیرد. 

نکته ای که در اینجا باید به آن اشاره کرد این است که ما میتوانیم برای اتخاذ تاکتیک دفاعی یا هجومی از مقادیر وزن‌دار برای نفوذها استفاده کنیم. با افزایش وزن نفوذ نیرو‌های دشمن (استفاده از ضریب بزرگتر از یک برای نفوذ اولیه هر کدام از واحدهای دشمن)، مرز میان جناحین به ما نزدیک‌تر می‌شود و ژست دفاعی در نیروها گرفته می‌شود. برعکس اگر وزن نیروهای ایجنت بیشتر باشد مرز‌ها به سمت دشمن رانده می‌شوند و نیرو‌ها آرایش هجومی به خود می‌گیرند[1]. 
نکته‌ دیگری که در اینجا حائز اهمیت است این است که تعادل قدرت در سطح بازی معمولا فریم به فریم تغییر نمی‌کند، پس اگر الگوریتم نقشه نفود در دوره‌ای به اندازه تعداد زیادی فریم اجرا شود اتفاق ناخوشایندی نخواهد افتاد. همه الگوریتم‌ها به راحتی می‌توانند متوقف شوند. اگرچه نقشه نفوذ فعلی ممکن است اطلاعات کاملا به‌روزی داشته باشد اما حتی اگر نرخ بهنگام‌سازی ۱۰ ثانیه هم باشد، اطلاعات به اندازه‌ای کافی هستند که ایجنت معقول عمل کند[2].

## ساختار تحلیل تاکتیکال[2]
می‌توان انواع مختلفی از تحلیل تاکتیکال را بر اساس زمان و چگونگی به‌روز رسانی متصور شد. شکل زیر این تفاوت‌ها را نشان می‌دهد. 
![شکل ۳-۱: لایه‌های مختلف ساختار تحلیل تاکتیکال ](https://boute.s3.amazonaws.com/222-indluence-map-structure.png)
در لایه اول آن دسته از تحلیل‌هایی وجود دارند که بر اساس ویژگی‌های ثابتی در سطح بازی انجام می‌شوند. این تحلیل‌ها می‌توانند به صورت آفلاین قبل از شروع بازی انجام شوند و نتایج آنها در جایی ذخیره شود. به عنوان مثال شیب زمین و میزان تاریکی مناطق (در صورتی که نورپردازی پویا وجود نداشته باشد و اجسام ساکن باشند) در طول بازی تغییری نمی‌کنند و می‌توانند به صورت آفلاین محاسبه شوند.
لایه دوم مربوط به مقادیری است که به آرامی و به تدریج در طول بازی تغییر می‌کنند. این تحلیل‌ها می‌تواند در یک دوره زمانی بهنگام شوند. نفوذ نظامی می‌تواند از این طریق به‌روزرسانی شود. پوشش پلیس در یک بازی شبیه‌سازی نیز بدین صورت می‌تواند تغییر کند.
لایه سوم مربوط به خصوصیت‌هایی است که به سرعت تغییر می‌کنند. برای به‌روز بودن تقریبا نیاز است که سطح بازی در هر فریم بهنگام شود، اما این حجم از محاسبات در هر فریم غیرممکن می‌باشد. هیچگونه بهینه‌سازی‌ای نیز نمی‌تواند ما را از این مخلصه نجات دهد، این یک محدودیت اساسی است که غیر قابل چشم‌پوشی است. راهکارهایی برای این چالش ارائه شده است.
سرراست‌ترین راه محدود کردن میزان محاسبات است. به جای آن که کل سطح بازی را بهنگام کنیم تنها مناطقی را که ما قصد استفاده از آنها را داریم و برای ما بیشترین اهمیت را داند به‌روز رسانی کنیم. تصمیم گیری درباره اینکه چه مکان‌هایی دارای اهمیت بیشتری هستند به سیستم تحلیل ما بستگی دارد. مناطقی که در همسایگی کاراکتری که در ایجنت در حال کنترل آن است از جمله مناطق مهم به شمار می‌آیند. 

**تحلیل چندلایه**
همانطور که قبلا اشاره شد، نقشه‌های نفوذ مجموعه‌ای از داده‌ها هستند که اطلاعات مربوط به هر مکان را در خود نگهداری می‌کنند. نقشه‌های نفوذ میزان کنترل واحد‌ها بر مناطق، امنیت مناطق، میزان غلظت تاریکی مکان‌ها، شیب زمین در ناحیه‌های مختلف، میزان سختی در عبور از مکان‌های مختلف و اطلاعات متنوع دیگری را در اختیار ما قرار می‌دهد. اما به منظور انجام تحلیل ما نیاز داریم که فاکتور‌های مختلف را با یکدیگر ترکیب کنیم که به آن تحلیل چندلایه می‌گویند. 
فرض کنید در یک بازی RTS مکان قرارگیری یک رادار نقشی حیاتی در موفقیت ما دارد. ما نیاز داریم تا بهترین مکان برای قرار گیری رادار را پیدا کنیم و رادار را در آن مکان قرار دهیم. بهترین مکان برای نصب یک رادار مکانی است که ویژگی‌های زیر را داشته باشد: 
+ برد وسیعی از میدان دید (برای بدست آوردن حداکثر اطلاعات)
+ منطقه‌ای امن (رادارها به راحتی قابل نابودی‌اند)
+ دور بودن از بقیه رادارها (به منظور استفاده بهینه از تجهیزات)

این سه فاکتور نهایتا در یک مقدار خلاصه می‌شوند که نشان می‌دهد یک مکان تا چه اندازه برای این منظور مناسب است. این ترکیب می‌تواند به فرم زیر باشد:
$$Quality=Security*Visibility*Distance  $$
این پروسه در شکل زیر نشان داده شده است.
![شکل ۳-۲: تحلیل‌های جداگانه بر اساس نقشه‌های نفوذ مختلف و نحوه ترکیب آنها در یک مقدار](https://boute.s3.amazonaws.com/222-multi-layer-analysis.png)

پس بدین ترتیب به جای استفاده مستقیم از آمار و ارقام هر سلول به منظور تصمیم گیری،باید آنها را با هم ترکیب کرد تا بتوان مقادیری با معنا بدست آورد که ارزش‌های مطلوب[^Desirability Values] نام دارند. ارزش‌ مطلوب مقداری است که به منظور یک تصمیم معین برای هر مکان محاسبه می‌شود. با مقایسه مقادیر مطلوب سلول‌های مختلف و رتبه‌بندی آنها می‌توان بهترین مکان برای انجام عملی خاص را انتخاب نمود. 
بهترین فرمول برای محاسبه مقدار مطلوب همانطور که ارائه شد، یک جمع وزن‌دار ساده می‌باشد. مقادیر نفوذ هر سلول که به آن تصمیم خاص مرتبط هستند جمع‌آوری می‌شود و هر کدام در یک ضریبی که اهمیت آن فاکتور را در آن تصمیم نشان می‌دهد ضرب می‌شوند و در نهایت همه جمع شده و نتیجه نهایی مقدار مطلوب را مشخص می‌سازد. در ادامه به چند نمونه از این مقادیر اشاره می‌کنیم[1].
+ **قابلیت حمله و دفاع:** می‌توان مقداری برای میزان آسیب‌پذیری در یک مکان اختصاص داد که توانایی حمله یا دفاع برای ایجنت و دشمن را نشان می‌دهد. مناطق آسیب‌پذیر مناطقی هستند که در آنها تجهیزات و منابعی کلیدی وجود دارد در حالی که تعداد واحد‌های نظامی در نزدیکی آنها کم است. آسیب‌پذیری بالا در منطقه‌ای تحت نفوذ دشمن به این معناست که ما باید حمله به دشمن در آن مکان را در نظر داشته باشیم. آسیب پذیری بالا در منطقه تحت نفوذ ایجنت به این معناست که ما میزان قابل توجهی منابع در اختیار داریم که در معرض حمله می‌باشند و ما باید از آنها با مراقبت بیشتری دفاع کنیم.
+ **قابلیت اکتشاف:**در بازی‌های RTS یک ایجنت باهوش برای بروز کردن دیدش از میدان جنگ جاسوسانی را به مناطق مختلف اعزام می‌کند. راهکاری مناسب به منظور انتخاب بهترین مکان برای اکتشاف،  انتخاب سلول‌هایی از نقشه نفوذ است که به مدت طولانی‌ای دیده نشده‌اند. فاکتورهای خوب دیگر می‌توانند میزان نفوذ دشمن در آن مکان‌ها و توانایی عبور باشد (تا جاسوس شما در صورت حمله دشمن بتواند فرار کند).
+ **قراردادن تجهیزات دفاعی:** ادوات دفاعی باید در مکان‌هایی قرار گیرند که میزان آسیب‌پذیری در آن مناطق بیشتر است. مکان‌های مسدود و کور نیز مکان‌هایی مناسب برای استقرار واحد‌های دفاعی هستند. مناطق مسدود مکان‌هایی هستند که قابلیت عبور[^Passability] کمی دارند اما دو منطقه با قابلیت عبور بالا را به هم متصل کرده است.
+ **قرار دادن مراکز تولید منابع:** باید در مکان‌هایی قرار گیرند که به واحد‌هایی دفاعی نزدیک باشند و تا حد امکان در نزدیکی مکان‌هایی باشند که پتانسیل بالایی برای اکتشاف و استخراج منابع دارند. 
+ **قرار دادن ادوات آسیب پذیر:** این ادوات باید در مکان‌هایی قرار گیرند که نفوذ دفاعی در آن منطقه بسیار بالاست. مکان‌هایی که سخت‌تر قابل دسترسی هستند نیز برای این منظور مناسب‌اند. 

# **پیاده‌سازی**

----------

همانطور که مشخص است دامنه اجرا و پیاده‌سازی این روش بیسیار وسیع است. در هر پروژه‌ای به مقتضای حال آن می‌توان انواع مختلفی از این تکنیک را پیاده‌سازی کرد. در این بخش قصد داریم نمونه‌ای از یک نقشه نفوذ ساده ارائه دهیم. پیاده‌سازی با استفاده از موتور بازی‌سازی [Unity3D](http://unity3d.com) انجام شده است. نتیجه پروژه در نهایت می‌تواند یک افزونه برای این موتور محسوب شود و در بازی‌های استراتژیک مورد استفاده قرار گیرد.
به منظور درک بهتر این تکنیک یک صحنه طراحی شده است که میدان نبردی می‌باشد که در آن موانع مختلفی قرار دارد. دو جناح وجود دارد که هر کدام واحد‌هایی را دارا می‌باشند. طرفین نبرد با رنگ‌های گرم و سرد متمایز شده‌اند. تعداد واحد‌ها، مشخصات جنگی واحد‌ها (قدرت، برد، سرعت حمله، میزان سلامتی و …)، پارامتر‌های نقشه نفوذ، فرمول‌های بدست آوردن ارزش‌های مطلوب و … همگی مواردی هستند که می‌توانند مورد آزمایش قرار گیرند. ابتدا به بیان محیط و مشخصات صحنه می‌پردازیم، سپس پارامتر‌های نقشه نفوذ را معرفی می‌کنیم.
![شکل ۴-۱: محیط صحنه نبرد](http://uupload.ir/files/d96o_game_enviroment.png)

## معرفی مشخصات بازی
هر یک از  واحد‌ها برای مسیر‌یابی نیز از یک شبکه ناوبری استفاده می‌کنند که قبل از شروع بازی آماده شده است. هر جوخه شامل سه نوع واحد می‌باشد:
+ *سرباز:* سرباز‌ها دارای سرعت حرکت بالا و قدرت متوسطی هستند.
+  *دفاعی:* واحد‌های دفاعی دارای سرعت حرکت پایین و قدرت بیشتری هستند، همچنین میزان سلامتی آنها نیز بیشتر است.
+  *منابع:* منابع ساکن هستند و می‌توانند توسط نیرو‌های دشمن از بین بروند.

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

## معرفی مشخصات نقشه نفوذ
برای بازنمایش نقشه نفوذ از شبکه دوبعدی استفاده شده است. این شبکه دوبعدی بر روی نقشه بازی قرار می‌گیرد و اطلاعات لازم را در خود ذخیره می‌کند. همچنین برای انتشار نفوذ نیز از الگوریتم فیلترهای کانولوشن استفاده شده است. این الگوریتم در اکثر موارد به صورت بهینه عمل می‌کند. اما متناسب با شرایط می‌توان از الگوریتم‌های دیگری که قبلا معرفی شده‌اند استفاده کرد. فیلتری نیز که برای انتشار استفاده شده فیلتر Gaussian است که در بسیاری از ابزار‌های گرافیکی نیز مورد استفاده قرار می‌گیرد. 
مقادیر که در هر یک از سلول‌های نقشه نفوذ ذخیره می‌شوند، مقداری در بازه $ [-1, +1] $ می‌باشند. علامت مقادیر نشان‌دهنده جناحی که آن منطقه را در اختیار دارد می‌باشد و مقدار آن میزان تأثیر این جناح را نشان می‌دهد. اطلاعاتی که در هر سلول از نقشه ذخیره می‌شود شامل موارد زیر می‌باشد:
+ **مقدار نفوذ:** نشان دهنده این است که در هر لحظه این مکان در کنترل چه طرفی قرار دارد.
+ **مقدار نیروی دفاعی:** کنترل نیرو‌های دفاعی در این مکان چه مقدار است.
+ **مقدار منابع:** تأثیر منابع طرفین در این مکان چقدر می‌باشد.

همچنین برای هر سلول ارزش‌های مطلوبی نیز در نظر گرفته شده است. این مقادیر را می‌توان بر اساس فرمول‌ها و پارامترهای متعددی بدست آورد. یکی از ساده‌ترین روش‌ها استفاده از معدل ضریب‌دار می‌باشد. به این صورت که هر پارامتر ضریبی دارد که میزان تأثیرگذاری آن در نتیجه را مشخص می‌کند.  هنگامی که ضریبی منفی باشد به این معناست که تأثیر دشمن مورد نظر است. ارزش‌های مطلوبی که در این پروژه در نظر گرفته شده است عبارتند از:
+ *امنیت:*
$$ Security = \frac {(1 * Soldier) + (3 * Defence)} {(1 + 3)} $$
+ *پتانسیل حمله:*
$$ Attack = \frac {(-3 * Security) + (-5 * Resource)} {(3 + 5)} $$
+ *پتانسیل دفاع:*
$$ Defence = \frac {(5 * Resource) + (2 * Reverse(Securiry)) } {(5 + 2)} $$

تابع Reverse تابعی است که برای معکوس کردن مقادیر بکار می‌رود. به طور مثال هر چه مقداری به ۱ نزدیکتر باشد معکوس آن به ۰ نزدیکتر است. برای مشاهده هر یک از این مقادیر در نقشه باید دکمه مورد نظر را از منو‌ پایین صفحه انتخاب کرد. مقادیر نقشه به صورت رنگ‌های گرم و سرد نمایش داده شده‌اند.
![شکل ۴-۲: مقدار امنیت در مناطق مختلف بازی](http://uupload.ir/files/da3g_simple_security_view.png)

نقشه نفوذی که در این پروژه استفاده شده است دارای پارامتر‌هایی می‌باشد که با کم و زیاد کردن آنها می‌توان به حالتی مناسب برای هر موقعیت رسید. مهم‌ترین این پارامتر‌ها موارد زیر می‌باشند.

+ **اندازه سلول‌های نقشه:** هرچه اندازه‌ سلول‌های نقشه بزرگ‌تر باشد، به‌روزرسانی نقشه سبک‌تر و دقت آن کمتر می‌شود و برعکس.
+ **ضریب تنزل:** [^Decay] نشان می‌دهد که سرعت تنزل نفوذ با افزایش مسافت چگونه می‌باشد. در کد برای تنزل از تابع نمایی $}e}^{x}$ استفاده شده است که توان از حاصل‌ضرب Decay در فاصله بدست می‌آید. بدین ترتیب با تغییر این پارامتر می‌توان مشخص کرد که محو شدن نفوذ با چه سرعتی انجام شود. 
+ **تکانه نفوذ:** [^Momentum] زمانی که قرار است نقشه نفوذ به‌روزرسانی شود، با پیچ و تاب این پارامتر می‌توان تعیین کرد که مقدار جدید نفوذ تا چه میزان به مقدار جدید و مقدار قدیمی نزدیک تر است. در کد از یک تابع خطی برای ایجاد مقداری از ترکیب مقدار فعلی و مقدار قبلی استفاده شده است. نتیجه بر اساس این پارامتر کنترل می‌شود. 
+ **فرکانس به‌روز‌رسانی:** [^Update Frequency] مقدار این پارامتر بسته به این است که چه میزان منابع سخت‌افزاری در دسترس می‌باشد. یکی از مزایای نقشه نفوذ این است که با طولانی شدن زمان به‌روز رسانی‌ها نیز می‌توانند به خوبی عمل کنند اما مسلما مقداری محاسبات برای بدست آوردن اطلاعات معتبر نیاز است. نقشه‌های نفوذ سطح بالا به ندرت به‌روزرسانی می‌شوند مثلا با فرکانس 1Hz و یا 0.5Hz، اما نقشه‌های نفوذ سطح پایین نیازمند به‌روزرسانی بیشتری هستند که معمولا 2Hz تا 5Hz مناسب است. آنچه که مسلم است این است که نیازی نیست نقشه‌ها در هر فریم به‌روز رسانی شوند.
![شکل ۴-۳: Component نقشه نفوذ و پارامتر‌های آن](https://boute.s3.amazonaws.com/222-Influence_map_component.png)

+ [لینک پروژه در گیت‌هاب](https://github.com/AliKarimi74/InfluenceMap) 
تذکر: برای اجرای پروژه موتور بازی سازی Unity3d نسخه ۴.۶ یا بالاتر باید نصب شده باشد. اما کدها را می‌توان در پوشه Scripts مشاهده کرد.

# **بهینه‌سازی و آزمایش‌ها**

----------

## آزمایش اول - تغییر پارامتر‌ها و مشاهده نتایج:
در آزمایش اول قصد داریم پارامتر‌های نقشه نفوذ را کمی پیچ و تاب داده و حاصل کار را مشاهده کنیم. از آنجا که تأثیر تغییر دو پارامتر اندازه سلول و فرکانس به‌روزرسانی کاملا مشخص می‌باشد تنها دو پارامتر ضریب تنزل و تکانه نفوذ را مورد آزمایش قرار می‌دهیم.
### ضریب تنزل:
معمولا مقادیر مختلف برای ضریب تنزل بر اساس اندازه نقشه انتخاب می‌شوند. در این قسمت سه مقدار ۰.۵، ۰.۱ و ۰.۰۲ برای این ضریب در نظر می‌گیریم و تغییرات نقشه نفوذ را مشاهده می‌کنیم.

| ۰.۵    | ۰.۱ | ۰.۰۲  |
|:------------------:|:------------------:|:------------------:|
|  ![](https://boute.s3.amazonaws.com/222-decay0.5.png)  |    ![](http://uupload.ir/files/3s3e_decay0.1.png)   |    ![](http://uupload.ir/files/k9pr_dacay0.03.png)  |

نتیجه می‌گیریم که ضریب تنزل کوچکتر برای نقشه‌های استراتژیک وسیع‌تر و ضریب تنزل بزرگتر برای زمانی که نقشه کوچک است یا کوچک شده است.
### تکانه نفوذ:
این پارامتر یکی از پارامتر‌های اصلی می‌باشد که تا حدود زیادی مشخص کننده نوع و سطح نقشه می‌باشد. در این آزمایش برای تکانه نفوذ سه مقدار ۱، ۰.۵ و ۰.۱ را در نظر می‌گیریم. مشاهدات زیر حاصل می‌شوند.

| ۱    | ۰.۵ | ۰.۱  |
|:------------------:|:------------------:|:------------------:|
|  ![](http://uupload.ir/files/asb9_momentum1.png)  |   ![](http://uupload.ir/files/upn_momentum0.5.png)    |   ![](http://uupload.ir/files/mqwv_momentum0.1.png)   |

هرچه Momentum کوچکتر باشد (به ۰ نزدیکتر باشد) الگوریتم بیشتر به سمت مقادیر سابق کشش پیدا می‌کند که برای ذخیره اطلاعات آماری همچون تاریخچه حمله‌ها مناسب می‌باشد. در این حالت مقادیر نفوذ همچون مسیری است که مقادیر در آن مسیر در طول زمان بیشتر بوده‌اند. بهتر است برای نقشه‌های استراتژیک سطح بالا این‌چنین باشد. برعکس، هرچه این پارامتر بزرگتر باشد (به ۱ نزدیکتر باشد) الگوریتم به سمت نگه‌داری مقادیر آنی کشیده می‌شود و در نتیجه انتشار سریع‌تر اتفاق می‌افتد و پیش‌بینی دقیق‌تر می‌شود. در این حالت مقادیر همچون هاله‌ای در اطراف واحد می‌باشد. برای نقشه‌های سطح پایین بهتر است مقدار این پارامتر کمتر باشد.

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

![شکل ۵-۱: مقادیر حمله و ناهنجاری‌های آن](http://uupload.ir/files/36ks_attack_sc_belady.png)

همانطور که در تصویر مشخص است، در قسمتی که با فلش مشخص شده است مقدار امتیاز حمله در آن منطقه باعث گمراهی عامل خواهد شد. علاوه بر آن هنگامی که یکی از نیرو‌ها (به عنوان مثال سربازی که با دایره مشخص شده است) با توجه به امتیاز حمله به سمت منابع دشمن می‌رود مقدار امتیاز حمله در آن مناطق کاهش می‌یابد. این باعث می‌شود نیرو‌های دیگر نتوانند به سمت منابع دشمن حرکت کنند و به سمت مناطق دیگری گمراه شوند. 
راهکاری که جهت بهبود نتایج و رفع این قیبل ناهنجاری‌ها در نظر گرفته شده است تفکیک نقشه‌های نفوذ می‌باشد. مشکل اصلی‌ای که در نقشه‌های نفوذ نسخه قبلی وجود دارد این بود که امکان تشخیص اینکه چه جناجی قصد گرفتن اطلاعات [^Querring] دارد وجود ندارد. همه از یک نقشه واحد استفاده می‌کنند و به همین دلیل تمییز جناحین از یکدیگر امکان پذیر نمی‌باشد. نتیجه این می‌شود که مثلا هنگامی که واحدی به منابع طرف مقابل نزدیک می‌شود امتیاز حمله [^Attack Score] در آن منطقه به شدت کاهش می‌باید در صورتی که نباید تغییر چندانی بکند. این تفاوت و ناهنجاری‌ها همانظور که دیدیم در نقشه‌های مقادیر مطلوب هویداست.
به همین منظور قصد داریم برای هر جناح نقشه نفوذ جداگانه‌ای جهت نگهداری و محاسبه مقادیر در نظر بگیریم. حسن بسیار کاربردی دیگر این کار این است که می‌توان برای نقشه‌های نفوذ مختلف پارامتر‌های مختلفی در نظر گرفت. مثلا در نقشه‌های نفوذ مخصوص مقادیر مطلوب که کمی سطح بالاتر می‌باشند تکانه نفوذ باید کمتر از نقشه‌های نفوذ دیگر باشد. نتیجه پس از تغییر معماری سیستم بسیار خوشایند بود. تصویر زیر نمونه‌ای از همان نقشه امتیاز حمله می‌باشد.

![شکل ۵-۲: مقادیر حمله پس از بهبود نتایج](http://uupload.ir/files/1fkf_attack_sc_afterchanges.png)

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

# **جمع‌بندی و کارهای آینده**

----------

در این پروژه سعی داشتیم راهی برای آگاه‌سازی ایجنت‌ها از جهان اطراف خود ارائه دهیم. راهی که مبنای تصمیم‌گیری یعنی آگاهی می‌باشد. نکته اصلی نقشه نفوذ جمع‌آوری بسیاری از اطلاعات از منابع بسیار و رمزگشایی آن به شکلی است که بتوان به سادگی طبق آن تصمیم‌گیری نمود. بیشترین کاربرد این تکنیک در هدایت کردن می‌باشد، عامل به سمتی می‌رود که مقدار آن - بسته به چیزی که می‌خواهد - حداکثر باشد. نقشه نفوذ در اکثر بازی‌های تیمی استفاده می‌شود مثل بازی‌های استراتژیک نظامی، بازی‌های ورزشی تیمی و … . حاصل این پروژه می‌تواند بخشی از اصلی‌ترین قسمت‌های هوش‌ مصنوعی بازی‌های رایانه‌ای استراتژیک باشد و قابلیت انعطاف آن در حد مقبولی می‌باشد.
زمینه هوش مصنوعی در بازی‌های رایانه‌ای بسیار گسترده است که بسیاری از مباحث آن باز می‌باشد. ایجاد عامل‌هایی هوشمند در بازی‌های استراتژیک و تیمی کاری بسیار دشوار است که طی چندین مرحله و توسط الگوریتم‌های هوش مصنوعی مختلف ایجاد می‌شوند. گاهی در تولید بازی‌های رایانه‌ای توسعه موتور هوش مصنوعی بسیار بیشتر از بقیه موارد همچون تولید محتوای هنری بازی زمان لازم داشته باشد، به همین دلیل است که تقابل انسان با انسان بسیار ایده بهتری است که امروزه تقریبا بیشتر سازندگان بازی‌های مطرح تمرکز اصلی خود را بر روی این قسمت قرار می‌دهند. در هر صورت کار‌هایی که در برنامه‌ آتی در اولویت‌اند موارد زیر هستند:
۱- اضافه کردن مقدار مطلوبی به نام قدرت نظامی که بتواند بر اساس میزان سلامتی، قدرت حمله، برد، سرعت حمله و … مقداری که بیانگر قدرت نظامی یک منطقه است را نشان دهد.
۲- تمییز بین مناطق شناخته‌شده و مناطق ناشناخته، گاهی اوقات تیمی هنوز نتوانسته است به مناطق مختلف بازی برود و در واقع قابلیت اکتشاف در آن منابع بیشتر است. این مناطق باید به عنوان مناطق ناشناخته تلقی شوند و ایجنت نباید اطلاعاتی از آن داشته باشد. 
۳- تعیین کردن یک شرط برد و ایجاد یک سرور تصمیم‌گیر که بر اساس موقعیت بازی بتواند استراتژی‌های مختلف تعیین کنید و آنها را عملی سازد. این سرور باید مقاصد نیرو‌ها را مشخص کند. این مرحله خود پروسه‌ای طولانی دارد و باید تلاش‌های بیشتری در آن صورت گیرد.


# *مراجع*
[1] Mark DeLoura. "Games programming gems 2", Charles River Media; 1 edition (July 26, 2001)
[2] Ian Millington. "Artificial Intelligence for games", George Morrison
[3] Jang, Su-Hyung, and Sung-Bae Cho. "Evolving neural NPCs with layered influence map in the real-time simulation game ‘Conqueror’." Computational Intelligence and Games, 2008. CIG'08. IEEE Symposium On. IEEE, 2008.
[4] Alberto Uriarte and Santiago Ontanon. "Kiting in RTS Games Using Influence Maps", 2012 AIIDE Workshop
AAAI Technical Report WS-12-15
[5] Craig W. Reynolds. "Flocks, Herds, and Schools: A Distributed Behavioral Model", Computer Graphics, 21(4), July 1987
[6] M. Preuss, N. Beume, H. Danielsiek, T. Hein, N. B, N. Piatkowski, R. Stuer, A. Thom, and S. Wessing, “Towards Intelligent Team Composition and Maneuvering in Real-Time Strategy Games” IEEE Transactions on Computational Intelligence and AI in Games, pp. 82–98, 2010.