Documentation

Mathlib.NumberTheory.Zsqrtd.GaussianInt

Gaussian integers #

The Gaussian integers are complex integer, complex numbers whose real and imaginary parts are both integers.

Main definitions #

The Euclidean domain structure on ℤ[i] is defined in this file.

The homomorphism GaussianInt.toComplex into the complex numbers is also defined in this file.

See also #

See NumberTheory.Zsqrtd.QuadraticReciprocity for:

Notations #

This file uses the local notation ℤ[i] for GaussianInt

Implementation notes #

Gaussian integers are implemented using the more general definition Zsqrtd, the type of integers adjoined a square root of d, in this case -1. The definition is reducible, so that properties and definitions about Zsqrtd can easily be used.

@[reducible]

The Gaussian integers, defined as ℤ√(-1).

Equations
Instances For
    Equations
    • One or more equations did not get rendered due to their size.

    The embedding of the Gaussian integers into the complex numbers, as a ring homomorphism.

    Equations
    Instances For
      theorem GaussianInt.toComplex_def' (x : ) (y : ) :
      GaussianInt.toComplex { re := x, im := y } = x + y * Complex.I
      theorem GaussianInt.toComplex_def₂ (x : GaussianInt) :
      GaussianInt.toComplex x = { re := x.re, im := x.im }
      @[simp]
      @[simp]
      @[simp]
      theorem GaussianInt.toComplex_re (x : ) (y : ) :
      (GaussianInt.toComplex { re := x, im := y }).re = x
      @[simp]
      theorem GaussianInt.toComplex_im (x : ) (y : ) :
      (GaussianInt.toComplex { re := x, im := y }).im = y
      @[simp]
      Equations
      • One or more equations did not get rendered due to their size.
      theorem GaussianInt.div_def (x : GaussianInt) (y : GaussianInt) :
      x / y = { re := round ((x * star y).re / (Zsqrtd.norm y)), im := round ((x * star y).im / (Zsqrtd.norm y)) }
      theorem GaussianInt.normSq_le_normSq_of_re_le_of_im_le {x : } {y : } (hre : |x.re| |y.re|) (him : |x.im| |y.im|) :
      theorem GaussianInt.mod_def (x : GaussianInt) (y : GaussianInt) :
      x % y = x - y * (x / y)
      Equations
      • One or more equations did not get rendered due to their size.
      theorem GaussianInt.sq_add_sq_of_nat_prime_of_not_irreducible (p : ) [hp : Fact (Nat.Prime p)] (hpi : ¬Irreducible p) :
      ∃ (a : ) (b : ), a ^ 2 + b ^ 2 = p