type C a; function f(C a) returns (int); //axiom (forall x:C a :: {f(x)} (exists y:C a :: f(y) == 42)); function g(C a) returns (C a); axiom (forall x:C a :: f(g(x)) == 42); procedure P() returns () { var z : C int; assume g(z) == z; assert (exists x : C int :: f(x) == 42); }