Skip to content
Go to file

Latest commit


Git stats


Failed to load latest commit information.
Latest commit message
Commit time


Symbolic execution for verification of stateful data planes made easy and fast.

Setup (*nix machine)

  1. JDK 8 (in case a different one is used the ScalaZ3 jar needs to be rebuilt against this, different, JDK)
  2. sbt - The simple build tool for Scala projects

See for a concrete setup script (it was tested on 64bit Ubuntu 12.04, 14.04 and 15.10).

Then from project root issue sbt sample.

Setup (Vagrant)

There is also a Vagrantfile if you prefer this option. This also uses for provisioning.

If you choose to use (or Vagrantfile + you should only grab those files since this includes the cloning of the repo.

Setup (Docker)

There is a Dockerfile if you prefer Docker over Vagrant. The Dockerfile has no dependency to the

If you want to use Docker to build/use symnet run the following commands:

docker build -t johscheuer/symnet .
docker run -ti johscheuer/symnet

# Run example
sbt sample

SEFL sample

See src/main/scala/change/v2/runners/experiments/SEFLRunner.scala to start experimenting with SEFL. sbt sample will run that code.

Click models in Symnet

Look at the description of the instructions method in src/main/scala/org/change/v2/Template.scala; try to understand what the instructions attatched to input port 0 do. Check src/main/resources/click_test_files/ in order to get the complete picture.

From the project root issue sbt click which performs the symbolic execution of file.

You should find the output in template.output.

Play with the code, check the output. Loop.


No description, website, or topics provided.



No releases published


No packages published
You can’t perform that action at this time.