First-order logic with integer arithmetics in Rust
This Rust crate provides an abstract syntax tree for first-order formulas with integer arithmetics.
- Booleans values (
true
andfalse
) - predicates
- negated formulas
- comparisons of terms (<, โค, >, โฅ, =, โ )
- implications and biconditionals
- conjunctions and disjunctions of formulas
- existentially and universally quantified formulas
- Boolean values (
true
andfalse
) - integers
- strings
- special integers (infimum and supremum)
- symbolic functions
- variables
- binary operations (addition, subtraction, multiplication, division, modulo, exponentiation)
- unary operations (absolute value, numeric negation)