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

spire.laws.PartialGroupLaws.scala Maven / Gradle / Ivy

package spire.laws

import spire.algebra._
import spire.algebra.partial._
import spire.implicits._

import org.typelevel.discipline.Laws

import org.scalacheck.{Arbitrary, Prop}
import org.scalacheck.Prop._

object PartialGroupLaws {
  def apply[A : Eq : Arbitrary] = new PartialGroupLaws[A] {
    def Equ = Eq[A]
    def Arb = implicitly[Arbitrary[A]]
  }
}

trait PartialGroupLaws[A] extends GroupLaws[A] {

  def semigroupoid(implicit A: Semigroupoid[A]) = new GroupProperties(
    name = "semigroupoid",
    parent = None,
    "associative: a |+|?? b && b |+|?? c imply (a |+| b) |+|?? c" → forAll((a: A, b: A, c: A) =>
      !((a |+|?? b) && (b |+|?? c)) || ((a |+|? b).get |+|?? c)
    ),

    "associative: (a |+|? b) |+|? c === a |+|? (b |+|? c)" → forAll((a: A, b: A, c: A) => {
      (!(a |+|?? b) || !(b |+|?? c)) ||
      ((a |+|? b).get |+|? c).get === (a |+|? (b |+|? c).get).get
    }
    )
  )

  def groupoid(implicit A: Groupoid[A]) = new GroupProperties(
    name = "groupoid",
    parent = Some(semigroupoid),
    "left identity" → forAll((a: A) =>
      (a.leftId |+|?? a) && ((a.leftId() |+|? a).get === a)
    ),

    "right identity" → forAll((a: A) =>
      (a |+|?? a.rightId) && ((a |+|? a.rightId).get === a)
    ),

    "product with inverse is always defined" → forAll((a: A) =>
      (a |+|?? a.inverse) && (a.inverse |+|?? a)
    ),

    "product with inverse is a left and right identity" → forAll((a: A, b: A) =>
      !(a |+|?? b) || (
        ((a |+|? b).get |+|? b.inverse).get === a &&
          ((a.inverse |+|? a).get |+|? b).get === b
      )
    )
  )

}

// vim: expandtab:ts=2:sw=2




© 2015 - 2025 Weber Informatics LLC | Privacy Policy