官术网_书友最值得收藏!

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.

主站蜘蛛池模板: 滁州市| 华容县| 慈溪市| 万源市| 景德镇市| 漳平市| 依兰县| 湾仔区| 车险| 镇坪县| 修文县| 龙泉市| 兴和县| 铁力市| 潞西市| 高邑县| 鄢陵县| 铜川市| 柘城县| 宜宾县| 西乡县| 西藏| 普陀区| 滦南县| 岫岩| 临颍县| 竹溪县| 泸定县| 玛曲县| 清水县| 波密县| 江孜县| 瓮安县| 淳化县| 双流县| 宁明县| 汕头市| 敦化市| 游戏| 旌德县| 达拉特旗|