Коммутативное кольцо с единицей

Формальное определение

Коммутативное кольцо с единицей объединяет в себе коммутативное кольцо и кольцо с единицей.

Для коммутативного кольца с единицей должны соблюдаться следующие законы:

Определение в виде кода на Scala

trait CRingWithUnity[A] extends CRing[A], RingWithUnity[A]

Законы в виде кода на Scala

trait CRingWithUnityLaw extends RingWithUnityLaw, CRingLaw:
  def checkCRingWithUnityLaw[A: CRingWithUnity](
      x: A,
      y: A,
      z: A
  ): ValidatedNel[String, Unit] =
    checkRingWithUnityLaw(x, y, z) combine
      checkCRingLaw(x, y, z)

Примеры

Числа относительно сложения с 0 и умножения с 1

(Z, +, *)

given CRingWithUnity[Int] with
  val empty: Int                               = 0
  val one: Int                                 = 1
  def combine(x: Int, y: Int): Int             = x + y
  def times(x: Int, y: Int): Int               = x * y
  extension (a: Int) override def inverse: Int = -a

Реализация

Реализация в Spire

import spire.algebra.CRing
import spire.math.Rational

CRing.plus(Rational(1, 2), Rational(1, 3))
// val res0: spire.math.Rational = 5/6
CRing.times(Rational(1, 2), Rational(1, 3))
// val res1: spire.math.Rational = 1/6
CRing.pow(Rational(1, 2), 3)
// val res2: spire.math.Rational = 1/8
CRing.negate(Rational(1, 2))
// val res3: spire.math.Rational = -1/2
CRing.minus(Rational(1, 2), Rational(1, 3))
// val res4: spire.math.Rational = 1/6
CRing.zero[Rational]
// val res5: spire.math.Rational = 0
CRing.one[Rational]
// val res6: spire.math.Rational = 1

Ссылки: