Skip to content

TACAS 2020 Artifacts for "Verifying Array Manipulating Programs with Full-program Induction"

License

Notifications You must be signed in to change notification settings

rupashreeh/VAJRA

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

VAJRA

https://doi.org/10.6084/m9.figshare.11875428.v1

VAJRA is the implementation that accompanies our paper: "Verifying Array Manipulating Programs with Full-program Induction". Supratik Chakraborty, Ashutosh Gupta, Divyesh Unadkat. In TACAS 2020.

Vajra accepts a c program annotated with an assertion as input and checks if the assertion holds or not using the full-program induction technique.

Pre-compiled vajra binary

VAJRA/bin folder contains the vajra binary compiled on Ubuntu 18.04 LTS as well as the libraries that it depends on. Following the instructions in VAJRA/bin/Readme.txt for installing and using the pre-compiled binary.

Building on Ubuntu 18.04 LTS

Install the following dependencies:

sudo apt-get -y install git g++ cmake libboost-regex-dev libboost-program-options-dev libboost-filesystem-dev libboost-system-dev flex bison

sudo apt-get install clang-6.0 clang-6.0-doc clang-6.0-examples clang-format-6.0 clang-tidy-6.0 clang-tools-6.0 cups-browsed libclang-6.0-dev libclang-common-6.0-dev libclang1-6.0 libllvm6.0 llvm-6.0 llvm-6.0-dev llvm-6.0-runtime python-clang-6.0 clang++-6.0

Some package names may not be exact.

Compilation requires an active internet connection as it fetches the latest Z3 sources.

Compiling

To compile, navigate to the VAJRA folder and run

make

which will result in the file vajra in the VAJRA folder.

Executing Vajra

A C program file annotated with an assertion is to be given as input.

./vajra [file]

Example:

./vajra ../tacas2020-benchmarks/brs1.c

Vajra help:

./vajra --help

OUTPUT

Outputs VAJRA_VERIFICATION_SUCCESSFUL for safe programs

Outputs VAJRA_VERIFICATION_FAILED for unsafe programs

Outputs VAJRA_UNKNOWN when the result cannot be determined

Contact

Kindly write to divyesh@cse.iitb.ac.in for any feedback, suggestions, queries and issues.

About

TACAS 2020 Artifacts for "Verifying Array Manipulating Programs with Full-program Induction"

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • SMT 50.7%
  • C++ 32.1%
  • C 14.0%
  • Yacc 1.3%
  • Java 1.1%
  • Makefile 0.4%
  • Other 0.4%