Syntheos is a tool for checking the realizability of specifications expressed in Linear Temporal Logic with theories (LTLt). The atomic propositions in the specification are Z3 predicates, which can refer to the previous value of a quantitative variable x with y(x).
To install Syntheos, clone this repository and install the required dependencies:
git clone https://github.com/imdea-software/syntheos.git
cd syntheos
python3 -m venv .venv
source .venv/bin/activate
python3 -m pip install -r requirements.txtAdditionally, ensure that the Strix tool is in the same folder as Syntheos, as it is required for execution.
To check the realizability of an LTL specification, activate the virtual environment, run the following command:
python3 syntheos.py --yaml <yaml_file>Remember to activate the virtual environment with:
source .venv/bin/activatewhen you start a new session.
The YAML file should contain:
property: The LTLt specification, where the z3 expressions are enclosed in square brackets.variables: A list of variables, each specifying itsname,type, andowner(eithersystemorenvironment).
property: "XXG([x>y(y(x))])"
variables:
- name: "x"
type: "Int"
owner: "system"Given a YAML file spec.yaml:
python syntheos.py --yaml spec.yamlWill check the realizability of the specificaiton in spec.yaml.
If the --yaml flag is not provided, the specification will be read from standard input in YAML format.
You can provide a filename to save the mealy machine in case the specification is realizable with the flag --save-mealy and a filename. The output file will also be a YAML.
python syntheos.py --save-mealy controller.yaml --yaml spec.yaml- Python 3.13
- Strix (must be placed in the same folder as Syntheos)
You can build and run a Docker image of Syntheos using Podman:
Build the image with tag syntheos using:
podman build --platform linux/amd64 -t syntheos .You can run the image and provide the content of a YAML specification file via standard input:
podman run --platform linux/amd64 -i syntheos < spec.yamlYou can execute a controller that interprets the mealy machine that has been saved with --save-mealy controller.yaml with the program shield.py in this repository.
python shield.py --mealy controller.yamlThis controller will read lines from stdin, where each line is a list of two elements.
The first element is a dictionary that maps each input variable to a concrete value. This represents the values provided by the environment at a specific time step.
The second element is a dictionary that maps output variables to proposed values determined by the system. This entry can contain only a subset of the system variables, indicating that the rest can be any value that the controller finds suitable.
If the proposed output values do not constitute a valid system response, the shield will provide a safe move to play instead.