// S : tags c sym $TAGS // S : expect --result valid // S : cc -o test.bc $CC_OPT $file // S : verify --symbolic --solver $solver $V_OPT test.bc // N : V : CC_OPT : V_OPT : TAGS : RESULT // V : big.1000 : -DNUM=1000 : : big : valid // V : big.100000 : -DNUM=100000 : : big : valid // V : small.5 : -DNUM=5 : : : valid // V : big.100 : -DNUM=100 : : big : valid // V : small.10 : -DNUM=10 : : big : valid // Source: Dirk Beyer, Thomas A. Henzinger, Rupak Majumdar, Andrey // Rybalchenko: "Path Invariants", PLDI 2007. extern void __VERIFIER_error(void); extern void __VERIFIER_assume(int); void __VERIFIER_assert(int cond) { if (!(cond)) { ERROR: __VERIFIER_error(); } return; } extern int __VERIFIER_nondet_int(void); int main() { int i, n, a, b; i = 0; a = 0; b = 0; n = __VERIFIER_nondet_int(); if (!(n >= 0 && n <= NUM)) return 0; while (i < n) { if (__VERIFIER_nondet_int()) { a = a + 1; b = b + 2; } else { a = a + 2; b = b + 1; } i = i + 1; } __VERIFIER_assert(a + b == 3*n); return 0; }