algebra.std.set.scala Maven / Gradle / Ivy
package algebra
package std
import algebra.lattice.GenBool
import algebra.ring.{BoolRng, Semiring}
package object set extends SetInstances
trait SetInstances {
implicit def setLattice[A]: GenBool[Set[A]] = new SetLattice[A]
implicit def setPartialOrder[A]: PartialOrder[Set[A]] = new SetPartialOrder[A]
implicit def setSemiring[A] = new SetSemiring[A]
def setBoolRng[A] = new SetBoolRng[A]
}
class SetLattice[A] extends GenBool[Set[A]] {
def zero: Set[A] = Set.empty[A]
def or(lhs: Set[A], rhs: Set[A]): Set[A] = lhs.union(rhs)
def and(lhs: Set[A], rhs: Set[A]): Set[A] = lhs.intersect(rhs)
def without(lhs: Set[A], rhs: Set[A]): Set[A] = lhs.diff(rhs)
}
class SetPartialOrder[A] extends PartialOrder[Set[A]] {
def partialCompare(x: Set[A], y: Set[A]): Double =
if (x.size < y.size) if (x.subsetOf(y)) -1.0 else Double.NaN
else if (y.size < x.size) -partialCompare(y, x)
else if (x == y) 0.0
else Double.NaN
override def eqv(x: Set[A], y: Set[A]): Boolean = x == y
}
class SetSemiring[A] extends Semiring[Set[A]] {
def zero: Set[A] = Set.empty
def plus(x: Set[A], y: Set[A]): Set[A] = x | y
def times(x: Set[A], y: Set[A]): Set[A] = x & y
}
class SetBoolRng[A] extends BoolRng[Set[A]] {
def zero: Set[A] = Set.empty
def plus(x: Set[A], y: Set[A]): Set[A] = (x diff y) | (y diff x)
def times(x: Set[A], y: Set[A]): Set[A] = x & y
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy