Skip to content

verivital/behaverify

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BehaVerify

BehaVerify is a tool for turning specifications of Behavior Trees into nuXmv models for verification as well as generating Python and Haskell implementations of the specified trees.

To recreate tests, see REPRODUCIBILITY.

Older versions can be found in subfolders of /src/versions/. The documentation for older versions may not be accurate.

References

Serena S. Serbinowska, Preston Robinette, Gabor Karsai, Taylor T. Johnson, Formalizing Stateful Behavior Trees, Proceedings Sixth International Workshop on Formal Methods for Autonomous Systems (FMAS2024), Manchester, UK, 11th and 12th of November 2024, Electronic Proceedings in Theoretical Computer Science 411, pp. 201–218. https://dx.doi.org/10.4204/EPTCS.411.14

Serena S. Serbinowska, Nicholas Potteiger, Anne M. Tumlin, Taylor T. Johnson, Verification of Behavior Trees with Contingency Monitors, Proceedings Sixth International Workshop on Formal Methods for Autonomous Systems (FMAS2024), Manchester, UK, 11th and 12th of November 2024, Electronic Proceedings in Theoretical Computer Science 411, pp. 56–72. https://dx.doi.org/10.4204/EPTCS.411.4

Serbinowska, S.S., Johnson, T.T. (2022). BehaVerify: Verifying Temporal Logic Specifications for Behavior Trees. In: Schlingloff, BH., Chai, M. (eds) Software Engineering and Formal Methods. SEFM 2022. Lecture Notes in Computer Science, vol 13550. Springer, Cham. https://doi.org/10.1007/978-3-031-17108-6_19

READMEs and Instructions

There are several README files placed throughout this repository, each serving a unique purpose. We suggest using BehaVerify through Docker.

  • behaverify/README.md -> This README provides information about how to install and run BehaVerify directly on your machine.
  • behaverify/Docker_BehaVerify/README.md -> This README provides information about how to use BehaVerify through Docker.
  • behaverify/metamodel/README.md -> This README provides details about the implementation of the BehaVerify Language. It is not a good source of information about how to use the BehaVerify Language. For that, see behaverify/examples/tutorial.tree.
  • behaverify/REPRODUCIBILITY/*/README.md -> This README provides details about running the tests for the relevant paper (regardless of if the submission was accepted).

Layout of this README

  • nuXmv -> Instructions regarding nuXmv.
  • Concise Installation Instructions
  • Verbose Installation Instructions
  • Running BehaVerify Locally

nuXmv

Per the licensing agreement of nuXmv (see https://nuxmv.fbk.eu/downloads/LICENSE.txt ), we may not re-distribute the software in any form for any purpose. Thank you for understanding.

To aquire nuXmv, see https://nuxmv.fbk.eu/download.html or https://nuxmv.fbk.eu/theme/download.php?file=nuXmv-2.0.0-linux64.tar.gz . You only need to download nuXmv. There should be no installation. Please make sure you download the appropriate version for your Operating System.

For the Linux version, please ensure you download the Linux 64-bit x86 version 2.0.0 (October 14, 2019). The executable will be located in nuXmv-2.0.0-linux64/nuXmv-2.0.0-Linux/bin/nuXmv. There should be NO FILE EXTENSION.


Concise Installation Instructions.

The instructions are for Linux (and more specifically Ubuntu). We have not tested this on any other systems. Please adapt commands as necessary (e.g., changing python3 to python).

This section is intentionally conscise. If you are interested in the details, please scroll down.

Download nuXmv

sudo apt update -y
sudo apt upgrade -y
sudo apt install python3 git -y
sudo apt install pip -y
git clone https://github.com/verivital/behaverify
cd behaverify
python3 -m pip install -r behaverify/requirements/core.txt
sudo apt install build-essential curl libffi-dev libffi8ubuntu1 libgmp-dev libgmp10 libncurses-dev libncurses5 libtinfo5 -y
sudo apt install libgmp3-dev -y

Please follow the instructions at https://www.haskell.org/ghcup/ to install GHCUP, Haskell, and cabal. These are used to run generated Haskell code. Please preappend (or append) your path when asked.

ghcup upgrade
ghcup install cabal 3.6.2.0
ghcup set cabal 3.6.2.0
ghcup install ghc 9.2.8
ghcup set ghc 9.2.8
sudo chmod +x /path/to/nuXmv

Verbose Installation Instructions.

The instructions are for Linux (and more specifically Ubuntu). We have not tested this on any other systems. Please adapt commands as necessary (e.g., changing python3 to python).

This section is intentionally lengthy. If you are not interested in the details and just want the commands, please scroll up.

  1. (OPTIONAL) nuXmv
    Please download nuXmv (see https://nuxmv.fbk.eu/ ). You only need to download nuXmv. There should be no installation. Download the relevant version for your system. It should be version 2.0.0. The download will include many files. You only need the executable (no file extension). See above for more information. You only need to execute this step if you are interested in verifying the generated models with nuXmv.
  2. Updating
    We suggest running the following commands.
sudo apt update
sudo apt upgrade
  1. Python3
    Python3 is used to run BehaVerify. As such, it is necessary. If you already have python3 installed, skip the following step. If not, run
sudo apt install python3
  1. pip
    pip is used to install other python packages. If you already have pip installed (for python3), skip the following step. If not, run
sudo apt install pip
  1. git
    git is used to download our repository. If you would prefer to manually download our repository, you can skip this step.
sudo apt install git
  1. BehaVerify
    Download our repository. If you did not install git, please download manually. If you installed git
git clone https://github.com/verivital/behaverify
  1. Change Directory
    Move into the repository.
cd behaverify
  1. Installing Python Packages.
    You may install the packages manually, or utilize the requirements file. Subsequent steps will explain what each of the Python packages does. The command for using the requirements file is (command assumes you are at the top level of the repository)
python3 -m pip install -r behaverify/requirements/core.txt

8a. (OPTIONAL) PyTrees
PyTrees is used in the generated python code. If you do not wish to run generated python code, you may skip this step.

python3 -m pip install py_trees

8b. textX
textX is used by BehaVerify for parsing. It is necessary for BehaVerify to run in any capacity

python3 -m pip install textX

8c. (OPTIONAL) onnxruntime
onnxruntime is used when handling neural networks in leaf nodes. If you do not plan to use neural networks in leaf nodes, you may skip this step.

python3 -m pip install onnxruntime

8d. (OPTIONAL) onnx
onnx is used when handling neural networks in leaf nodes. If you do not plan to use neural networks in leaf nodes, you may skip this step.

python3 -m pip install onnx
  1. (OPTIONAL) Haskell prerequisites
    These are prerequisites required by Haskell.
sudo apt install build-essential curl libffi-dev libffi8ubuntu1 libgmp-dev libgmp10 libncurses-dev libncurses5 libtinfo5 libgmp3-dev
  1. (OPTIONAL) GHCUP
    Please follow the instructions at https://www.haskell.org/ghcup/ to install GHCUP, Haskell, and cabal. These are used to run generated Haskell code. Please preappend (or append) your path when asked.
  2. (OPTIONAL) GHCUP upgrade
    This will upgrade GHCUP.
ghcup upgrade
  1. (OPTIONAL) Cabal
    This will install and set the specific version of cabal we used. Most likely, everything will work with a different version.
ghcup install cabal 3.6.2.0
ghcup set cabal 3.6.2.0
  1. (OPTIONAL) GHC
    This will install and set the specific version of ghc we used. Most likely, everything will work with a different version.
ghcup install ghc 9.2.8
ghcup set ghc 9.2.8
  1. (OPTIONAL) Enable nuXmv
    If you plan to use nuXmv, please ensure you can run nuXmv as an executable
sudo chmod +x /path/to/nuXmv

Running BehaVerify Locally

This section will be structured as follows

  • General Layout and Information
  • Generating .smv files for nuXmv
  • Generating .py files for Python
  • Generating .hs files for Haskell

General Layout and Information

File extensions are not mandatory. This documentation will use the following convention for them

  • .smv -> a file for use with nuXmv
  • .tree -> a specification file that follows the rules in behaverify/metamodel/behaverify.tx (a textx file)
  • .tx -> a metamodel file.
  • .py -> a Python file (either generated by BehaVerify, or a source file for BehaVerify)
  • .hs -> a Haskell file (generated by BehaVerify)

The following files are relevant to the user. They assume they are in the in behaverify/src and may not work correctly if moved or if other files are missing from that directory.

  • dsl_to_nuxmv.py -> Converts .tree files to .smv files
  • dsl_to_haskell.py -> Converts .tree files to Haskell
  • dsl_to_python.py -> Converts .tree files to Python (py_trees)

Generating .smv files for nuXmv

.smv files can be used with nuXmv for model verification. You can generate .smv using the following command:

python3 ./src/dsl_to_behaverify.py ./metamodel/behaverify.tx /path/to/tree.tree /path/to/smv.smv

We assume you are running this command from the top level of the repository. If not, please adjust paths as necessary.

Arguments

  • ./metamodel/behaverify.tx -> this argument must point to the metamodel file.
  • /path/to/tree.tree -> this argument must point to a specification file. It does not need to have the .tree extension.
  • /path/to/smv.smv -> the output will be written to the file location provided. You do not need to make this a .smv file.

Additional Optional Arguments

Additional arguments are listed below. You must preface them with --

  • --keep_stage_0 -> Flag option (no additional information required). This disables the stage_0 pruning optimization.
  • --keep_last_stage -> Flag option (no additional information required). This disables the last_stage pruning optimization.
  • --do_not_trim -> Flag option (no additional information required). This disables node pruning. BehaVerify will not restructure your tree to remove unreachable nodes.

Using nuXmv for verification

Please run the following command

/path/to/nuXmv --int /path/to/smv.smv

Here --int will turn this into interactive mode. Now, run the following commands

go
check_ctlspec
check_ltlspec
check_invar
quit

go is a command which runs several commands in preparation of model checking. The check commands check the relevant specifications. If a specification is False, a counterexample will be produced.


Generating Python Files

Python files can be generated using the following command:

python3 ./src/dsl_to_pytree.py ./metamodel/behaverify.tx /path/to/tree.tree /path/to/output/folder/ fileName 

We assume you are running this command from the top level of the repository. If not, please adjust paths as necessary.

Arguments

  • ./metamodel/behaverify.tx -> this argument must point to the metamodel file.
  • /path/to/tree.tree -> this argument must point to a specification file. It does not need to have the .tree extension.
  • /path/to/output/folder/ -> this argument must point to a folder. This is where the python files will be written.
  • fileName -> this should not include any extension. fileName.py, fileName_environment.py, and fileName_runner.py will depend upon this name.

Note that various other files will also be created.

Additional Optional Arguments

Additional arguments are listed below. You must preface them with --

  • --max_iter -> Requires an integer. Defaults to 100. This dictates how many iterations fileName_runner.py will execute.
  • --no_var_print -> Flag option (no additional information required). This disables the printing of variables.
  • --serene_print -> Flag option (no additional information required). This enables the printing of the status of the tree after each tick.
  • --py_tree_print -> Flag option (no additional information required). This enables the use of PyTree visualizers to print information about the status of the tree (warning: this does not reflect the status the nodes returned when running, as those nodes are sometimes reset).

Utilizing the Generated Files

Run

python3 /path/to/folder/fileName_runner.py

Generating Haskell Files

Haskell Files are slightly more irritating to generate and use. First, create a folder where you wish to store your Haskell files. Then use the following command

mkdir /path/to/output/folder
mkdir /path/to/output/folder/app

This will cause cabal to initiate a project in the current folder. Next, run the following command:

python ./src/dsl_to_pytree.py ./metamodel/behaverify.tx /path/to/tree.tree /path/to/output/folder/ fileName 

We assume you are running this command from the top level of the repository. If not, please adjust paths as necessary.

Arguments

  • ./metamodel/behaverify.tx -> this argument must point to the metamodel file.
  • /path/to/tree.tree -> this argument must point to a specification file. It does not need to have the .tree extension.
  • /path/to/output/folder/ -> this argument must point to a folder. The haskell files will be written to /path/to/folder/output/app/.
  • fileName -> this should not include any extension. fileName.hs will depend upon this name.

Note that various other files will also be created.

NOTE: cabal is currently utilized because non-determinism depends on the System.Random package, and cabal is the easiest way we found to quickly deal with this.

Additional Optional Arguments

Additional arguments are listed below. You must preface them with --

  • --max_iter -> Requires an integer as well. Defaults to 100. This dictates how many iterations Main.hs will execute.

Utilizing the Generated Files

In /path/to/output/folder/, run

cabal run

If you wish to change the randomized starting seeds, use

cabal run fileName -- seed1 seed2

(seed1 controls the initial seed for the blackboard, while seed2 controls the initial seed for the environment).