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

Коммутативное кольцо — это кольцо, в котором операция умножения коммутативна. Это означает, что для любых элементов \(a\) и \(b\) из кольца выполняется равенство \(a \cdot b = b \cdot a\).

Определение коммутативного кольца

Коммутативное кольцо — это множество \(R\), на котором определены две бинарные операции:

Эти операции должны удовлетворять следующим аксиомам:

Примеры коммутативных колец

Зачем нужны коммутативные кольца?

Коммутативные кольца играют важную роль в математике и её приложениях:

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

Коммутативное кольцо - кольцо, коммутативное относительно умножения.

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

, а также закон коммутативности умножения:

Код

trait CRing[A] extends Ring[A], CSemiring[A]

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

(Z, +, *)

given CRing[Int] with
  val empty                                    = 0
  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

Законы

Законы наследуются от законов кольца и коммутативного полукольца.

Схема

classDiagram
    class Semigroup~A~{
        +combine(x: A, y: A) A
    }  
    class Monoid~A~{
        +empty() A
    }
    Semigroup <|-- Monoid
    class CommutativeSemigroup~A~
    Semigroup <|-- CommutativeSemigroup  
    class Group~A~{
      +inverse(x: A) A
    }  
    Monoid <|-- Group 
    class CommutativeMonoid~A~
    Monoid <|-- CommutativeMonoid
    CommutativeSemigroup <|-- CommutativeMonoid
    class AbelianGroup~A~
    Group <|-- AbelianGroup
    CommutativeMonoid <|-- AbelianGroup
    class Semiring~A~
    CommutativeMonoid <|-- Semiring
    class MultiplicativeSemigroup~A~{
        +times(x: A, y: A) A
    }
    MultiplicativeSemigroup <|-- Semiring
    Semigroup .. MultiplicativeSemigroup
    class Ring~A~
    AbelianGroup <|-- Ring
    Semiring <|-- Ring
    class CommutativeSemiring~A~
    Semiring <|-- CommutativeSemiring
    class CommutativeRing~A~
    Ring <|-- CommutativeRing
    CommutativeSemiring <|-- CommutativeRing

Реализация в библиотеках

Реализация в 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

Ссылки: