package bitwuzla
Legend:
Library
Module
Module type
Parameter
Class
Class type
Library
Module
Module type
Parameter
Class
Class type
type 'a t = 'a term
constraint
'a =
[< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ]
A term of 'a
kind.
module Bl : sig ... end
Boolean
module Bv : sig ... end
Bit-vector
module Rm : sig ... end
Rounding-mode
module Fp : sig ... end
Floating-point
module Ar : sig ... end
Array
module Uf : sig ... end
Uninterpreted function
const sort symbol
create a (first-order) constant of given sort with given symbol.
This creates a 0-arity function symbol.
val equal :
[< `Ar of
[< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ] & [< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ]
| `Bv
| `Fp
| `Rm ] as 'a
t ->
'a t ->
bv t
equal t0 t1
create an equality term.
val distinct :
[< `Ar of
[< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ] & [< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ]
| `Bv
| `Fp
| `Rm ] as 'a
t ->
'a t ->
bv t
distinct t0 t1
create an disequality term.
val ite :
bv t ->
[< `Ar of
[< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ] & [< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ] & [< `Bv | `Fp | `Rm ] ->
[< `Bv | `Fp | `Rm ]
| `Bv
| `Fp
| `Rm ] as 'a
t ->
'a t ->
'a t
ite t0 t1 t2
create an if-then-else term.
val hash :
[< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ] t ->
int
hash t
compute the hash value for a term.
val sort :
[< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ] as 'a
t ->
'a sort
sort t
get the sort of a term.
val pp : Stdlib.Format.formatter -> 'a term -> unit
pp formatter t
pretty print term.
type !'a5 view =
| Value : 'a value -> 'a view
| Const : 'a0 sort * string -> 'a0 view
| Var : [< `Bv | `Fp | `Rm ] as 'd sort -> 'd view
| Lambda : 'a1 variadic * [< bv ] as 'e term -> ('a1, 'e) fn view
| Equal : [< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ] as 'f term * 'f term -> bv view
| Distinct : [< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ] as 'g term * 'g term -> bv view
| Ite : bv term * [< `Ar of [< `Bv | `Fp | `Rm ] -> [< `Bv | `Fp | `Rm ] | `Bv | `Fp | `Rm ] as 'h term * 'h term -> 'h view
| Bv : ('a2, 'b) Bv.operator * 'b -> bv view
| Fp : ('a3, 'b0, 'c) Fp.operator * 'b0 -> 'c view
| Select : ([< `Bv | `Fp | `Rm ] as 'i, [< `Bv | `Fp | `Rm ] as 'j) ar term * 'i term -> 'j view
| Store : ([< `Bv | `Fp | `Rm ] as 'k, [< `Bv | `Fp | `Rm ] as 'l) ar term * 'k term * 'l term -> ('k, 'l) ar view
| Apply : ('a4, [< bv ] as 'm) fn term * 'a4 variadic -> 'm view
Algebraic view of formula terms.
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>