Finite-state machines
A finite-state machine (FSM) is a mathematical model of computation that can be used to represent a sequential logic of state transitions. We use FSMs to describe systems that have a finite number of states and can transition from one state to another due to some event. At any given time the FSM can be in exactly one particular state, and the reception of this event will make the application to transit to a new state. FSMs will be a central part to define the FSM App in an AI agent (because we express the business logic of such AI agents as FSMs).
The rules to transition from one state of the FSM to another are governed by the so-called transition function. The transition function takes as input the current state and the received event and outputs the next state where the FSM will transit. A compact way of visualizing an FSM and its transition function is through a multi digraph with a finite number of nodes, depicting the possible states of the system, and a finite number of labelled arcs, representing the transitions from one state to another.
Example
Consider an FSM describing a simplified vending machine with three different states:
- Idle: the machine is waiting for a customer to insert a coin.
- Ready: a coin has been inserted, and the machine is waiting for the customer to select a product, or request a refund.
- Release: the machine releases the selected product.
Therefore, the four self-explanatory events of this FSM are:
- COIN_INSERTED
- PRODUCT_SELECTED
- REFUND_REQUEST
- PRODUCT_RELEASED
We can represent the FSM as a multi digraph as follows:
Or alternatively, using its transition function:
| Input | Output | 
|---|---|
| (Idle, COIN_INSERTED) | Ready | 
| (Ready, REFUND_REQUESTED) | Idle | 
| (Ready, PRODUCT_SELECTED) | Release | 
| (Release, PRODUCT_RELEASED) | Idle | 
FSMs let us define all the steps that an application of an AI agent must follow, or in other words, the application logic. Roughly speaking, the FSM App defining an AI agent is essentially an FSM replicated across the number of AEAs that compose the AI agent, including additional proactive functionalities. Although it is not stritly necessary to understand how FSM Apps work, you can read more about FSM replication here.