module type S =sig
..end
SMT formulas
type
t
The type of atomic formulas.
type
proof
An abstract type for proofs
val equal : t -> t -> bool
Equality over formulas.
val hash : t -> int
Hashing function for formulas. Should be such that two formulas equal according
to Expr_intf.S.equal
have the same hash.
val print : Format.formatter -> t -> unit
Printing function used among other thing for debugging.
val dummy : t
Formula constant. A valid formula should never be physically equal to dummy
val neg : t -> t
Formula negation. Should be an involution, i.e. equal a (neg neg a)
should
always hold.
val norm : t -> t * Formula_intf.negated
Returns a 'normalized' form of the formula, possibly negated
(in which case return Negated
). This function is used to recognize
the link between a formula a
and its negation neg a
, so the goal is
that a
and neg a
normalise to the same formula,
but one returns Same_sign
and the other one returns Negated