IC3 for Proving Protocol Properties
Copyright (c) 2018 - Present Aman Goel (amangoel@umich.edu) and Karem Sakallah (karem@umich.edu) , University of Michigan
Reads a parameterized distributed protocol and performs property checking
- [YouTube] Proving Paxos with IC3PO presented at FMCAD'21
- [YouTube] IC3PO presented at NFM'21
- [YouTube] IC3PO presented at Simons Institute
Clone the repository and:
- run
git submodule update --init --recursive
to clone submodules - run
./build.sh
from the project folder to install dependencies
python2 ic3po.py -o <output-path> -n <test-name> <path>/<file>.ivy
(check the output in <output-path>/<test-name>)
Example: python2 ic3po.py -o foo -n bar ivybench/ex/ivy/toy_consensus.ivy
(check the output in foo/bar)
IC3PO creates a directory <output-path>/<test-name>
which contains results, statistics and logs relating to the run
<output-path>
└── <test-name>
├── <test-name>.ivy [input Ivy file]
├── <test-name>.vmt [input converted to SMT-LIB compatible VMT file]
├── bar.inv [unbounded inductive invariant (if proved safe)]
├── <test-name>.results [statistics file]
└── <test-name>.log [IC3PO log]
As a quick summary relating to the run, IC3PO produces certain key information as output.
For example, running python2 ic3po.py -o foo -n bar ivybench/ex/ivy/toy_consensus.ivy --size node=3,quorum=3,value=3
produces the following output:
(output dir: foo/bar)
(frontend: ivy)
(converting: ivy -> vmt)
(mode: ic3po)
(reuse: 1)
(opt: 1)
(const: 1)
(wires: 1)
(using z3 4.8.9.0 with seed 1)
(using yices 2.6.2 with seed 1)
(found #4 definitions)
(epr: True)
(gen: fe)
(found #2 actions)
Finitize node ? 3
(setting |node| to 3)
Finitize quorum ? 3
(setting |quorum| to 3)
Finitize value ? 3
(setting |value| to 3)
Finite sorts: #3
|node| = 3
|quorum| = 3
|value| = 3
(input is in epr)
@ 1s 0: 1 :1
@ 2s 1: 1 1 :2
@ 2s 2: 1 1 2 :4
@ 2s 3: 1 1 0 2 :4
@ 2s Proof certificate (finite) of size 3.
@ 2s (finite convergence checks)
@ 2s |node| = 4 : pass
@ 2s |value| = 4 : pass
@ 2s |quorum| = 4 : pass
@ 2s (all finite convergence checks passed)
@ 2s (unbounded induction checks skipped)
Finite sorts (final): #3
|quorum| = 3
|node| = 3
|value| = 3
(invariant file: foo/bar/bar.inv)
@ 2s Property proved. Proof certificate of size 3
(with inv: epr: True)
":" separated numbers indicate the following:
<max IC3 frame> : <# of added clauses in each frame> s: <total # of clauses learnt>
Copyright (c) 2018 - Present Aman Goel and Karem Sakallah, University of Michigan. All rights reserved.
IC3PO is provided as is, without any warranty. Any usage of IC3PO needs to comply with the usage terms as detailed in the file LICENSE.
We would be glad to hear from you and help you in the case you are having a difficulty in using IC3PO
Please report bugs and share your usage experience on github (https://github.com/aman-goel/ic3po)