All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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