- Unity 2017 Game AI Programming(Third Edition)
- Ray Barrera Aung Sithu Kyaw Thet Naing Swe
- 260字
- 2021-07-02 19:14:11
Finite State Machines
Finite State Machines (FSM) can be considered one of the simplest AI models, and they are commonly used in games. A state machine basically consists of a set number of states that are connected in a graph by the transitions between them. A game entity starts with an initial state and then looks out for the events and rules that will trigger a transition to another state. A game entity can only be in exactly one state at any given time.
For example, let's take a look at an AI guard character in a typical shooting game. Its states could be as simple as patrolling, chasing, and shooting:
There are basically four components in a simple FSM:
- States: This component defines a set of distinct states that a game entity or an NPC can choose from (patrol, chase, and shoot)
- Transitions: This component defines relations between different states
- Rules: This component is used to trigger a state transition (player on sight, close enough to attack, and lost/killed player)
- Events: This is the component that will trigger to check the rules (guard's visible area, distance to the player, and so on)
FSMs are commonly used go-to AI patterns in game development because they are relatively easy to implement, visualize, and understand. Using simple if/else statements or switch statements, we can easily implement an FSM. It can get messy as we start to have more states and more transitions. We'll look at how to manage a simple FSM more in depth in Chapter 2, Finite State Machines and You.
- Visual FoxPro 程序設計
- Flask Web開發入門、進階與實戰
- MySQL 8 DBA基礎教程
- Python程序設計案例教程
- Full-Stack Vue.js 2 and Laravel 5
- Unity Game Development Scripting
- Mastering Android Development with Kotlin
- 大數據分析與應用實戰:統計機器學習之數據導向編程
- Python深度學習:模型、方法與實現
- HTML5從入門到精通(第4版)
- Python:Deeper Insights into Machine Learning
- Java核心編程
- 軟件設計模式(Java版)
- Visual C#(學習筆記)
- Mobile Test Automation with Appium