Кольцо

Кольцо — это одна из ключевых алгебраических структур в математике, которая обобщает понятие чисел и операций над ними. Кольцо определяется как множество, на котором заданы две бинарные операции (обычно называемые сложением и умножением), удовлетворяющие определённым аксиомам.

Определение кольца

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

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

Дополнительные свойства колец

Примеры колец

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

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

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

Кольцо (Ring) - это полукольцо, являющееся абелевой группой по сложению.

Учитывая множество R и операции + и *, мы говорим, что (R, +, *) - это кольцо, если оно удовлетворяет следующим свойствам:

Законы кольца:

Код

trait Ring[A] extends AbGroup[A], Semiring[A]

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

(Z, +, *)

given Ring[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

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

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

import spire.algebra.Rng
import spire.math.Rational

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

Ссылки: