AI in games Roger Crawfis/Eric Fosler-Lussier CSE 786 Game Design AI vs. AI for games AI for games poses a number of unique design challenges Traditional AI: Made to handle unseen inputs, large state space Too many options possible to compute an exact optimal solution Engineering criteria: best possible performance Game AI: The game world is known, though it can still be large In a known world, optimal solutions can be precomputed Entertainment criteria: smart enough to pose a challenge, but not smart enough to be undefeatible Injecting AI into a Game Friend: Foe: autonomous, intelligent NPC helpmates Configurable (scripted) behaviors: different characters solve a problem in different ways Player may trade places with NPC: automation Opponents get better with time Opponents are less predictable because the individuals’ behavior is not uniform Scene Clutter Provides a richness to your environment. Animals grazing, birds flying, people milling about, automobiles driving, etc. Goals for your games Prepare you for entertainment and ‘serious’ games You must implement at least one of these features Improve over time Goal-driven action decomposition A* search for path planning, with varying cost functions for different agents (different agents have different heuristics) Game tree search Emergent group behavior (flocking or formations) “Intelligent” interaction (e.g. speech/language) Your game AI must be data-driven, i.e. it must tune itself or otherwise interoperate with an arbitrary map/level loaded at runtime Warning: AI is not an afterthought AI elements need to be designed in from the start Configurable/scripted behavior Data-driven map/level layouts AI isn’t time-consuming to create, if coded from the start Improving over time Agent behavior needs to be composed from small, modular, context-sensitive actions Evade-right if angle >90 and < 180 Reward good performance/punish bad Each re-spawn can modify control strategy See good discussion in Buckland online book You can either perform training and freeze optimal play, or let the agent adapt to each user Improving over time Example from Buckland (online) Ch 10: brainy aliens Map sensory input to behavior with a hidden layer The time it stayed alive is fitness function When alien dies, replace it with an evolved one Goal-driven behavior Multiple steps required to achieve a desired effect Useful in Action-adventure type games -puzzles to solve RPG - task underlings with a multi-step job Good discussion in Buckland PGAIE ch. 9 Each ‘goal’ is an instance of a composite class Many different goals can be created with minimal coding Goal-driven agents Different classes of agents solve problem in different ways, based on their abilities “Block door”: Strong trolls move boulders in the way Small hobbits shovel sand into the opening Each agent’s response to the goal depends on his abilities, available tools, etc. Goal object contains alternative recipes One goal at a time is active for each agent In more complex games, might have goal queue A* path planning Smart path planning/locomotion using waypoints/grabpoints built into the world Board/card games like chess/poker are impossible to completely search, heuristics are required and search cutoffs flocking/formation Agents have small goals to balance that result in emergent behavior Flocking: stay close, navigate toward centroid of flock, avoid collision Results in a ‘crowd’ behavior look Formations: flanking/center/right wing, etc. Individuals stay evenly spaced within their group Each agent chooses a position within the formation One agent or central planner selects formation Results in a more disciplined/organized look (Orcs) Depends on how organized you want the agents to appear Flocking demos See Craig Reynold’s Steering behaviors: http://www.red3d.com/cwr/steer/ “Intelligent” interaction NPCs might communicate state via language E.g. Wii Fit, “All your bases belong to us” Complete job is WAAAAY too hard Input: probably beyond scope of project Output: May be able to do simple state-conditional things (mocking, encouragement) Scripting languages can be used for rapid deployment Other AI principles: observability Don’t let the agents have perfect knowledge: they have to operate in the environment like the players do Sense and remember events in their sensory horizon, memories can have a TTL Perhaps in more advanced levels, they can communicate with each other about what they know See article on “adding stupidity to AI”
© Copyright 2026 Paperzz