Module Polynomial.LinPoly
type t
= Vect.t
module MonT : sig ... end
val of_monomial : Monomial.t -> t
of_monomial m
@returns 1.x where x is the variable (index) for monomial m
val of_vect : Vect.t -> t
of_vect v
@returns a1.x1 + ... + an.xn This is not the identity because xi is the variable index of xi^1
val variables : t -> Micromega_plugin.Mutils.ISet.t
variables p
- returns
the set of variables of the polynomial p interpreted as a multi-variate polynomial
val is_linear : t -> bool
is_linear p
- returns
whether the multi-variate polynomial is linear.
val is_linear_for : var -> t -> bool
is_linear_for x p
- returns
true if the polynomial is linear in x i.e can be written c*x+r where c is a constant and r is independent from x
val constant : NumCompat.Q.t -> t
constant c
- returns
the constant polynomial c
val search_all_linear : (NumCompat.Q.t -> bool) -> t -> var list
search_all_linear pred p
- returns
all the variables x such p = a.x + b such that p is linear in x i.e x does not occur in b and a is a constant such that
pred a
val collect_square : t -> Monomial.t MonMap.t
collect_square p
- returns
a mapping m such that m
s
= s^2 for every s^2 that is a monomial ofp
val monomials : t -> Micromega_plugin.Mutils.ISet.t
monomials p
- returns
the set of monomials.
val pp_var : Stdlib.out_channel -> var -> unit
pp_var o v
pretty-prints a monomial indexed by v.
val pp : Stdlib.out_channel -> t -> unit
pp o p
pretty-prints a polynomial.