constructive-algebra-0.1: 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 euclidean domains and the polynomial ring.


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

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.