Improved Belgian AI Algorithm for Dynamic Management in Action Role-Playing Games
Abstract
1. Introduction
- The melee-ranged buffer-pursuit (MRBP) ring model with DDA introduced, the grid priority (GP), and real-time induction and distribution (RID) algorithm, as well as attack weight threshold (AWT) and global cooldown (GCD) are suggested to improve the scope and imperfections of BAI.
- Two combat management systems based on BAI and IBAI are implemented in Unreal Engine 4. By testing the adaptability of the two systems in different situations and inviting players to participate in gameplay experiences and questionnaires, the results demonstrate that IBAI owns higher adaptability and player experience than BAI.
- IBAI is able to help game designers and developers achieve combat management systems for action role-playing games with high work efficiency.
2. Belgian Artificial Intelligence Algorithm
| Algorithm 1 BAI | 
| Require: the player’s MGC, CGC, MAC, CAC, the enemy’s GW, AP, each attack type’s AW Ensure: behavior logic, process logic 
 | 
- BAI holds the enemy in the form of eight rectangular grids, each of which can hold only one enemy and cannot be adjusted adaptively according to the specific game mechanism. Additionally, the interaction area between enemies and the player in the four grids at a 45-degree angle to the player is significantly smaller than the ones at a 90-degree angle. Moreover, BAI can only manage melee attacks rather than ranged attacks.
- When multiple enemies register requests to attack the player simultaneously, the stage manager will reject them even if the player’s CGC is large enough and the sum of these enemies’ GW is greater than the player’s CGC. Additionally, when the number or position of enemies that have gained the attack right changes, the position where enemies that have gained the attack right before the change may not be the closest attack position after the change, or the enemy that is not assigned has already been in the grids after the change, but its position conflicts with the position where enemies that have gained the attack right before the change. The enemy may possibly not gain the attack right.
- In case the enemy is authorized by the stage manager to attack the player, it will use an attack type to attack constantly until the number of enemies that have gained the attack right changes. Furthermore, it is impossible to prevent the same type of enemies from attacking the player with the same attack type simultaneously, which will reduce combat diversity and game balance.
3. Improved Belgian Artificial Intelligence Algorithm
3.1. MRBP Ring Model
- Decrease MGC or MAC when the player is dying.
- Increase MGC or MAC when the player has not been damaged for a long time.
- Reset MGC and MAC to the player’s initial value in the current combat after the player completes it.
3.2. GP and RID Algorithm
3.2.1. GP
3.2.2. RID Algorithm
| Algorithm 2 IBAI-RID Algorithm-Change Process | 
| Require: the enemy’s state before the change Ensure: behavior logic 
 | 
| Algorithm 3 IBAI-RID Algorithm-Attack Requests Process | 
| Require: the player’s MGC, CGC, the enemy’s GW, GP, GCOM Ensure: process logic 
 | 
| Algorithm 4 IBAI-RID Algorithm-Pursue Requests Process | 
| Require: the enemy’s GP, the sectors’ state in the Buffer Area Ensure: process logic 
 | 
3.3. AWT and GCD
3.3.1. AWT
3.3.2. GCD
4. Results and Discussion
4.1. System Design and Implementation
- Create the player class and set related variables, functions, events, and interfaces.
- Create the enemy class and complete the creation of EnemyMelee, EnemyRanged, and other classes based on the inheritance relationships. The system has six types of enemies, including three that use melee attacks named EnemyMelee1, EnemyMelee2, and EnemyMelee3, as well as the rest named EnemyRanged1, EnemyRanged2, and EnemyRanged3 that attack from a range. Among them, Skill1 of EnemyMelee2 is the same as EnemyMelee3, Skill1 of EnemyRanged2, and EnemyRanged3 are equivalent as well. The related variables, functions, events, and interfaces are then set.
- Create the stage manager class and set its and all other related variables, functions, events, and interfaces.
- Create meshes, models, weapons, animations, skill effects, and sound effects for the player and enemies.
- Build test levels.
4.2. System Tests
4.2.1. Static Tests
- Enemy type management tests
- Enemy number management tests
- Interaction area tests
4.2.2. Dynamic Tests
- Attack mechanism tests
- Allocation logic tests
- RID algorithm tests
4.2.3. DDA Test
4.3. System Adaptability Analysis
4.4. Player Experience Comparison
5. Conclusions
Author Contributions
Funding
Institutional Review Board Statement
Informed Consent Statement
Data Availability Statement
Acknowledgments
Conflicts of Interest
References
- Heidari, A.; Navimipour, N.J.; Unal, M. Applications of ML/DL in the Management of Smart Cities and Societies Based on New Trends in Information Technologies: A Systematic Literature Review. Sustain. Cities Soc. 2022, 85, 104089. [Google Scholar] [CrossRef]
- Wen, B.J.; Chang, C.R.; Lan, C.W.; Zheng, Y.C. Magnus-Forces Analysis of Pitched-Baseball Trajectories Using YOLOv3-Tiny Deep Learning Algorithm. Appl. Sci. 2022, 12, 5540. [Google Scholar] [CrossRef]
- Heidari, A.; Jabraeil Jamali, M.A.; Jafari Navimipour, N.; Akbarpour, S. Deep Q-Learning Technique for Offloading Offline/Online Computation in Blockchain-Enabled Green IoT-Edge Scenarios. Appl. Sci. 2022, 12, 8232. [Google Scholar] [CrossRef]
- Liu, J.; Togelius, J.; Pérez-Liébana, D.; Lucas, S.M. Evolving Game Skill-Depth Using General Video Game AI Agents. In Proceedings of the 2017 IEEE Congress on Evolutionary Computation (CEC), Donostia, Spain, 5–8 June 2017; pp. 2299–2307. [Google Scholar] [CrossRef]
- Xia, B.; Ye, X.; Abuassba, A.O. Recent Research on AI in Games. In Proceedings of the 2020 International Wireless Communications and Mobile Computing (IWCMC), Limassol, Cyprus, 15–19 June 2020; pp. 505–510. [Google Scholar] [CrossRef]
- Yannakakis, G.N.; Togelius, J. A Panorama of Artificial and Computational Intelligence in Games. IEEE Trans. Comput. Intell. AI Games 2014, 7, 317–335. [Google Scholar] [CrossRef]
- El Rhalibi, A.; Wong, K.W.; Price, M. Artificial Intelligence for Computer Games. Int. J. Comput. Games Technol. 2009, 2009, 251652. [Google Scholar] [CrossRef]
- Jie, J.; Yang, K.; Haihui, S. The Application of AI for the Non Player Character in Computer Games. In Proceedings of the 2011 International Conference on Computational and Information Sciences, Chengdu, China, 21–23 October 2011; pp. 1049–1050. [Google Scholar] [CrossRef]
- Wiemeyer, J.; Nacke, L.; Moser, C.; Floyd’Mueller, F. Player Experience. In Serious Games; Dörner, R., Göbel, S., Effelsberg, S., Wiemeyer, J., Eds.; Springer: Cham, Switzerland, 2016; pp. 243–271. [Google Scholar] [CrossRef]
- Denisova, A.; Nordin, A.I.; Cairns, P. The Convergence of Player Experience Questionnaires. In Proceedings of the 2016 Annual Symposium on Computer-Human Interaction in Play, Austin, TX, USA, 16–19 October 2016; pp. 33–37. [Google Scholar] [CrossRef]
- Nacke, L.; Drachen, A.; Kuikkaniemi, K.; Niesenhaus, J.; Korhonen, H.J.; Hoogen, W.M.; Poels, K.; IJsselsteijn, W.A.; De Kort, Y.A. Playability and Player Experience Research. In Proceedings of the 2009 DiGRA International Conference: Breaking New Ground: Innovation in Games, Play, Practice and Theory, London, UK, 1–4 September 2009. [Google Scholar]
- Köknar, C. Who is at the Center?: Designing Playful Experiences by Using Player-Centered Approach. In Proceedings of the International Conference on Human-Computer Interaction, Orlando, FL, USA, 26–31 July 2019; pp. 11–21. [Google Scholar] [CrossRef]
- Mustač, K.; Bačić, K.; Skorin-Kapov, L.; Sužnjević, M. Predicting Player Churn of a Free-to-Play Mobile Video Game Using Supervised Machine Learning. Appl. Sci. 2022, 12, 2795. [Google Scholar] [CrossRef]
- Karavidas, L.; Apostolidis, H.; Tsiatsos, T. Usability Evaluation of an Adaptive Serious Game Prototype Based on Affective Feedback. Information 2022, 13, 425. [Google Scholar] [CrossRef]
- Zohaib, M. Dynamic Difficulty Adjustment (DDA) in Computer Games: A Review. Adv. Hum. Comput. Interact. 2018, 2018, 5681652. [Google Scholar] [CrossRef]
- Sepulveda, G.K.; Besoain, F.; Barriga, N.A. Exploring Dynamic Difficulty Adjustment in Videogames. In Proceedings of the 2019 IEEE CHILEAN Conference on Electrical, Electronics Engineering, Information and Communication Technologies (CHILECON), Valparaiso, Chile, 13–27 November 2019; pp. 1–6. [Google Scholar] [CrossRef]
- Preuss, M.; Risi, S. A Games Industry Perspective on Recent Game AI Developments. KI Künstl. Intell. 2020, 34, 81–83. [Google Scholar] [CrossRef]
- Williams, J.P.; Hendricks, S.Q.; Winkler, W.K. Gaming as Culture: Essays on Reality, Identity and Experience in Fantasy Games; McFarland: Jefferson, NC, USA, 2014; pp. 1–14. [Google Scholar]
- Van Der Linden, R.; Lopes, R.; Bidarra, R. Procedural generation of dungeons. IEEE Trans. Comput. Intell. AI Games 2013, 6, 78–89. [Google Scholar] [CrossRef]
- Foong, N.W.; On, C.K.; Alfred, R.; Teo, J.; Ibrahim, A.A.A. Interactive Procedural Generation for Items in Role-Playing Game. In Proceedings of the 2017 IEEE 2nd International Conference on Automatic Control and Intelligent Systems (I2CACIS), Kota Kinabalu, Malaysia, 21 October 2017; pp. 150–154. [Google Scholar] [CrossRef]
- Ferreira, L.; Lelis, L.; Whitehead, J. Computer-Generated Music for Tabletop Role-Playing Games. In Proceedings of the AAAI Conference on Artificial Intelligence and Interactive Digital Entertainment, Worchester, MA, USA, 19–23 October 2020; pp. 59–65. [Google Scholar]
- Primanita, A.; Effendi, R.; Hidayat, W. Comparison of A∗ and Iterative Deepening A Algorithms for Non-Player Character in Role Playing Game. In Proceedings of the 2017 International Conference on Electrical Engineering and Computer Science (ICECOS), Palembang, Indonesia, 22–23 August 2017; pp. 202–205. [Google Scholar] [CrossRef]
- Huynh, E.; Nyhout, A.; Ganea, P.; Chevalier, F. Designing Narrative-Focused Role-Playing Games for Visualization Literacy in Young Children. IEEE Trans. Vis. Comput. Graph. 2020, 27, 924–934. [Google Scholar] [CrossRef] [PubMed]
- Wang, J.Y. A Variety Weapons and Armors Design Algorithm for Role-Playing Games. In Proceedings of the 2015 IEEE/ACIS 16th International Conference on Software Engineering, Artificial Intelligence, Networking and Parallel/Distributed Computing (SNPD), Takamatsu, Japan, 1–3 June 2015; pp. 1–5. [Google Scholar] [CrossRef]
- Brown, J.A. Evolved Weapons for RPG Drop Systems. In Proceedings of the 2013 IEEE Conference on Computational Inteligence in Games (CIG), Niagara Falls, ON, Canada, 11–13 August 2013; pp. 1–2. [Google Scholar] [CrossRef][Green Version]
- Hitchens, M.; Drachen, A. The Many Faces of Role-Playing Games. Int. J. Role-Play. 2009, 1, 3–21. [Google Scholar]
- Macklin, C.; Sharp, J. Games, Design and Play: A Detailed Approach to Iterative Game Design; Addison-Wesley Professional: Upper Saddle River, NJ, USA, 2016; pp. 47–76. [Google Scholar]
- Adams, E. Fundamentals of Game Design; Addison-Wesley Professional: Upper Saddle River, NJ, USA, 2014; pp. 255–312. [Google Scholar]
- Dawe, M. Beyond the Kung-Fu Circle: A Flexible System for Managing NPC Attacks. In Game AI Pro: Collected Wisdom of Game AI Professionals; Rabin, S., Ed.; CRC Press: Boca Raton, FL, USA, 2013; pp. 369–375. [Google Scholar]
- Sellers, M. Advanced Game Design: A Systems Approach; Addison-Wesley Professional: Upper Saddle River, NJ, USA, 2017; pp. 267–292. [Google Scholar]
- Thorn, A. Game Development Principles; Cengage Learning: Singapore, 2013; pp. 1–30. [Google Scholar]
- Chen, J. Flow in Games (and Everything Else). Commun. ACM 2007, 50, 31–34. [Google Scholar] [CrossRef]
- Bastos, A.S.; Gomes, R.F.; Dos Santos, C.C.; Maia, J.G.R. Assessing the Experience of Immersion in Electronic Games. In Proceedings of the 2017 19th Symposium on Virtual and Augmented Reality (SVR), Curitiba, Brazil, 1–4 November 2017; pp. 146–154. [Google Scholar] [CrossRef]
- Bachelder, S.; Santhanam, R.; Hayashi, M.; Nakajima, M. Engagement in Computer and Video Games. In Proceedings of the 2013 International Conference on Cyberworlds, Yokohama, Japan, 21–23 October 2013; p. 371. [Google Scholar] [CrossRef]
- Witmer, B.G.; Singer, M.J. Measuring Presence in Virtual Environments: A Presence Questionnaire. Presence 1998, 7, 225–240. [Google Scholar] [CrossRef]
- Bernhaupt, R.; Eckschlager, M.; Tscheligi, M. Methods for Evaluating Games: How to Measure Usability and User Experience in Games? In Proceedings of the International Conference on Advances in Computer Entertainment Technology, Salzburg, Austria, 13–15 June 2007; pp. 309–310. [Google Scholar] [CrossRef]
- Jennett, C.; Cox, A.L.; Cairns, P.; Dhoparee, S.; Epps, A.; Tijs, T.; Walton, A. Measuring and Defining the Experience of Immersion in Games. Int. J. Hum. Comput. Stud. 2008, 66, 641–661. [Google Scholar] [CrossRef]
- Brockmyer, J.H.; Fox, C.M.; Curtiss, K.A.; McBroom, E.; Burkhart, K.M.; Pidruzny, J.N. The Development of the Game Engagement Questionnaire: A Measure of Engagement in Video Game-Playing. J. Exp. Soc. Psychol. 2009, 45, 624–634. [Google Scholar] [CrossRef]












| Player Position | Melee Attacks | Ranged Attacks | 
|---|---|---|
| Within the range | 3 | 2 | 
| Beyond the range | 1 | 1 | 
| Position Before the Change | Melee Area | Ranged Area | Buffer Area | Pursuit Area | Outer Area | 
|---|---|---|---|---|---|
| Not in combat | Case A 1 | Case A | Case B 2 | Case C 3 | Case D 4 | 
| Melee Area (in combat) | Case A | Case A | Case B | Case C | Case E 5 | 
| Ranged Area (in combat) | Case A | Case A | Case B | Case C | Case E | 
| Buffer Area (in combat) | Case A | Case A | Case B | Case C | Case E | 
| Pursuit Area (in combat) | Case A | Case A | Case B | Case F 6 | Case E | 
| Variables | Player | Enemy Melee1 | Enemy Melee2 | Enemy Melee3 | Enemy Ranged1 | Enemy Ranged2 | Enemy Ranged3 | 
|---|---|---|---|---|---|---|---|
| Pawn color | Grey | Red | Orange | Green | Cyan | Blue | Purple | 
| MGC | 10 | - | - | - | - | - | - | 
| MAC | 10 | - | - | - | - | - | - | 
| GW | - | 1 | 2 | 3 | 1 | 2 | 3 | 
| AP | - | 1 | 3 | 5 | 2 | 4 | 6 | 
| Maximum health point | 20 | 3 | 4 | 5 | 3 | 4 | 5 | 
| Number of skills | 0 | 0 | 1 | 2 | 0 | 1 | 2 | 
| Normal attack’s AW | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 
| Normal attack’s damage performed | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 
| Normal attack’s cooldown | 2.00 | 2.00 | 2.00 | 2.00 | 2.00 | 2.00 | 2.00 | 
| Skill1’s AW | - | - | 2 | 2 | - | 2 | 2 | 
| Skill1’s damage performed | - | - | 2 | 2 | - | 3 | 3 | 
| Skill1’s cooldown | - | - | 2.00 | 2.00 | - | 2.00 | 2.00 | 
| Skill1’s T | - | - | 1.10 | 1.10 | - | 1.33 | 1.33 | 
| Skill1’s P | - | - | 0.50 | 0.50 | - | 0.90 | 0.90 | 
| Skill1’s m | - | - | 0.10 | 0.10 | - | 0.10 | 0.10 | 
| Skill2’s AW | - | - | - | 4 | - | - | 4 | 
| Skill2’s damage performed | - | - | - | 3 | - | - | 1–12 | 
| Skill2’s cooldown | - | - | - | 2.00 | - | - | 2.00 | 
| Skill2’s T | - | - | - | 1.13 | - | - | 1.34 | 
| Skill2’s P | - | - | - | 0.75 | - | - | 1.15 | 
| Skill2’s m | - | - | - | 0.10 | - | - | 0.10 | 
| Static Tests | Algorithms | Enemy Melee1 | Enemy Melee2 | Enemy Melee3 | Enemy Ranged1 | Enemy Ranged2 | Enemy Ranged3 | 
|---|---|---|---|---|---|---|---|
| Enemy type management | BAI | 1 | 1 | 1 | 0 | 0 | 0 | 
| IBAI | 1 | 1 | 0 | 1 | 1 | 1 | |
| Enemy number management | BAI | 8 | 1 | 1 | 0 | 0 | 0 | 
| IBAI | 5 | 2 | 2 | 5 | 2 | 2 | |
| Interaction area | BAI | 2 | 0 | 0 | 0 | 0 | 0 | 
| IBAI | 2 | 0 | 0 | 0 | 0 | 0 | 
| Dynamic Tests | Stages | Enemy Melee1 | Enemy Melee2 | Enemy Melee3 | Enemy Ranged1 | Enemy Ranged2 | Enemy Ranged3 | 
|---|---|---|---|---|---|---|---|
| Attack mechanism | First | 0 | 2 | 2 | 0 | 0 | 0 | 
| Second | 1 | 1 | 0 | 0 | 0 | 0 | |
| Third | 1 | 0 | 0 | 0 | 0 | 0 | |
| Allocation logic | First | 1 | 0 | 3 | 0 | 0 | 0 | 
| Second | 0 | 1 | 0 | 0 | 0 | 0 | |
| Third | 2 | 0 | 0 | 0 | 0 | 0 | |
| RID algorithm | First | 1 | 0 | 0 | 0 | 0 | 0 | 
| Second | 1 | 0 | 1 | 1 | 1 | 1 | |
| Third | 0 | 1 | 0 | 0 | 0 | 0 | |
| Fourth | 1 | 0 | 0 | 0 | 0 | 0 | |
| Fifth | 0 | 0 | 0 | 1 | 0 | 0 | |
| Sixth | 0 | 0 | 0 | 1 | 0 | 0 | 
| Algorithms | DDA | Variables | Test 1 | Test 2 | Test 3 | Test 4 | Test 5 | 
|---|---|---|---|---|---|---|---|
| BAI | Without | AHPC | 71.3 | 58.1 | 41.1 | 24.9 | 10.8 | 
| ACET | 9′14″0 | 8′22″6 | 6′59″7 | 5′53″5 | 4′47″9 | ||
| With | AHPC | 54.5 | 48.2 | 36.4 | 21.7 | 12.0 | |
| ACET | 8′31″9 | 7′48″5 | 6′37″0 | 5′44″1 | 4′47″3 | ||
| IBAI | Without | AHPC | 81.3 | 66.9 | 49.7 | 33.2 | 17.5 | 
| ACET | 9′25″8 | 8′11″7 | 6′56″1 | 5′42″0 | 4′26″4 | ||
| With | AHPC | 63.0 | 55.6 | 48.5 | 39.6 | 31.3 | |
| ACET | 8′18″2 | 7′35″8 | 6′52″9 | 6′02″2 | 5′15″1 | 
| Parameters | BAI | IBAI | 
|---|---|---|
| Suitable for action role playing games | Yes | Yes | 
| Set the relationship of enemy types and attack types effectively | Yes | Yes | 
| Enemy types can be managed | Melee | Melee and ranged | 
| The number of enemies can be held | No more than 8 | Adaptive based on the game mechanism | 
| The interaction area between enemies and the player | Differ by grid position | All the same | 
| Attack types of enemies can switch automatically | No | Yes | 
| The possibility of the same type of enemies attack the player with the same attack type simultaneously | High | Low | 
| The assigned position of enemies may not be the closest to the player | Yes | No | 
| The assigned position of enemies may be conflicted | Yes | No | 
| Enemies should gain the attack right, but they may not gain it | Yes | No | 
| Multiple enemies may not attack the player while simultaneously registering requests | Yes | No | 
| Effectiveness of DDA | Low | High | 
| ID | Items | 
|---|---|
| Q1 | I felt that I really empathized/felt for with the game. | 
| Q2 | I was interested in seeing how the game’s events would progress. | 
| Q3 | I sometimes found myself to become so involved with the game that I wanted to speak to the game directly. | 
| Q4 | I enjoyed playing the game. | 
| Q5 | I was unaware of what was happening around me. | 
| Q6 | I felt detached from the outside world. | 
| Q7 | At the time the game was my only concern. | 
| Q8 | I did not feel the urge at any point to stop playing and see what was going on around me. | 
| Q9 | I did not feel like I was in the real world but the game world. | 
| Q10 | To me it felt like only a very short amount of time had passed. | 
| Q11 | I lost track of time. | 
| Q12 | Things seemed to happen automatically. | 
| Q13 | If someone talked to me, I did not hear them. | 
| Q14 | I got wound up. | 
| Q15 | Time seemed to kind of standstill or stop. | 
| Q16 | I felt spaced out. | 
| Q17 | I did not answer when someone talked to me. | 
| Q18 | I could not tell that I was getting tired. | 
| Q19 | My thoughts went fast. | 
| Q20 | I lost track of where I was. | 
| Q21 | I played without thinking about how to play. | 
| Q22 | Playing made me feel calm. | 
| Q23 | I played longer than I meant to. | 
| Q24 | I really got into the game. | 
| Q25 | I felt like I just could not stop playing. | 
| Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations. | 
© 2022 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https://creativecommons.org/licenses/by/4.0/).
Share and Cite
Mi, Q.; Gao, T. Improved Belgian AI Algorithm for Dynamic Management in Action Role-Playing Games. Appl. Sci. 2022, 12, 11860. https://doi.org/10.3390/app122211860
Mi Q, Gao T. Improved Belgian AI Algorithm for Dynamic Management in Action Role-Playing Games. Applied Sciences. 2022; 12(22):11860. https://doi.org/10.3390/app122211860
Chicago/Turabian StyleMi, Qingwei, and Tianhan Gao. 2022. "Improved Belgian AI Algorithm for Dynamic Management in Action Role-Playing Games" Applied Sciences 12, no. 22: 11860. https://doi.org/10.3390/app122211860
APA StyleMi, Q., & Gao, T. (2022). Improved Belgian AI Algorithm for Dynamic Management in Action Role-Playing Games. Applied Sciences, 12(22), 11860. https://doi.org/10.3390/app122211860
 
        




 
       