Skip to main content

A flexible state machine for Python

Project description

## Installing

```python
pip install flexsm
```

## Importing, creating states and state machine

Creating states and state machines is pretty straightforward:

```python
from flexsm import *

root = State("root")
state1 = State("state 1")
state2 = State("state 2")

sm = StateMachine(root)
```

## Transitions and input variables

Transitions are responsible for getting from one state to another. They usually start in one state and end in another. If the next state is only known at runtime, e.g. if it depends on an input variable "x", then you can override the transition method *getNextState*:

```python
@addTransition(state=root)
class WaitForSomeValueToBecomeSmall(Transition):
def getNextState(self, x):
if x>15:
return state2
else:
return state1
```

This piece of code allows us to transition from state *root* to *state 1* if x is smaller than 15, for example by calling ```python sm.update("x", 10)``` or to *state 2* if x is 15 or bigger.

There is also an input variable *time_in_state*, which contains the amount of time we've been in the current state in seconds. The minimal guaranteed resolution for time_in_state is 0.1 seconds, which can be changed in the StateMachine construction:

```python
sm = StateMachine(root, time_resolution=0.01)
```

By overriding the *check* method, we can transition if we are in the state 5 seconds or longer:

```python
@addTransition(state=state1, next=state2)
class WaitAMoment(Transition):
def check(self, time_in_state, x):
return time_in_state > 5

def onTrigger(self, time_in_state, x):
print("""We are in this boring
state since {:.2f} seconds,
with x being {}""".format(time_in_state, x))
```

We also override *onTrigger*, which is called when the transition is triggered. Note how the parameters for onTrigger and check are equal. The parameters for all transition methods are name sensitive. So you can't simply use the parameter y instead of x and expect y to be 100 if you run sm.update("x", 100). For the same transition, the parameters for getNextState, check and onTrigger even have to be equal!

Transition.check will only be called if the value of one of its parameters changed. Thus, if your code in the check method takes a lot of time, try to avoid frequently changing parameters like time_in_state.

## Parent states

Consider the following example:

```python
airbourne = State("Airbourne")
doing360spin = State("Spin 360", parent=airbourne)

sm = StateMachine(doing360spin)
```

In this case, we are not only in the state *doing360spin*, but also in the state *airbourne*. Thus, any transitions defined on *airbourne* will be considered as well. For example, an airplane could go into an emergency state if its fuel is getting low. Such emergency transitions would be interesting for all states in the air.

## Parent states

Consider the following example:

```python
airbourne = State("Airbourne")
doing360spin = State("Spin 360", parent=airbourne)

sm = StateMachine(doing360spin)
```
In this case, we are not only in the state *doing360spin*, but also in the state *airbourne*. Thus, any transitions defined on *airbourne* will be considered as well. For example, an airplane could go into an emergency state if its fuel is getting low. Such emergency transitions would be interesting for all states in the air.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flexsm-0.0.9-py3-none-any.whl (3.9 kB view details)

Uploaded Python 3

File details

Details for the file flexsm-0.0.9-py3-none-any.whl.

File metadata

File hashes

Hashes for flexsm-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 5e1ee6d77684ed66fd84b80296b5109ff5abaa569c0ca2a4836d1e41808da988
MD5 a1d4267f45ef6c236222ed3df1a4eac3
BLAKE2b-256 f71c3e6994df91c0d985d0274fa22472aec8b80c3d05cacc4801ce6ec54bd4a7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page