type C _; function f(C a) returns (int); axiom (forall x : C int :: f(x) == 3); axiom (forall x : C bool :: f(x) == 7); procedure P() returns () { var a : C int, b : C bool, c : C ref; start: assert f(a) == 3; assert f(b) == 7; assert f(b) == 8; // should not be provable } procedure Q() returns () { var c : C ref; start: assert f(c) == 7; // should not be provable } procedure R(c : C a) returns () { start: assert f(c) == 7; // should not be provable } type ref;