constructive-algebra-0.3.0: A library of constructive algebra.




class Ring a => StronglyDiscrete a whereSource

Strongly discrete rings

A ring is called strongly discrete if ideal membership is decidable. Nothing correspond to that x is not in the ideal and Just is the witness. Examples include all Bezout domains and polynomial rings.


member :: a -> Ideal a -> Maybe [a]Source


(BezoutDomain a, Eq a) => StronglyDiscrete a

Strongly discreteness for Bezout domains

Given x, compute as such that x = sum (a_i * x_i)

propStronglyDiscrete :: (CommutativeRing a, StronglyDiscrete a, Eq a) => a -> Ideal a -> BoolSource

Test that the witness is actually a witness that the element is in the ideal.