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:

Notation #

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, inline]

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

Instances For
    @[implicit_reducible]

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

    Instances For
      @[implicit_reducible]
      theorem GaussianInt.toComplex_def' (x y : ) :
      toComplex { re := x, im := y } = x + y * Complex.I
      theorem GaussianInt.toComplex_def₂ (x : GaussianInt) :
      toComplex x = { re := x.re, im := x.im }
      @[simp]
      theorem GaussianInt.re_toComplex (x y : ) :
      (toComplex { re := x, im := y }).re = x
      @[simp]
      theorem GaussianInt.im_toComplex (x y : ) :
      (toComplex { re := x, im := y }).im = y
      theorem GaussianInt.natAbs_norm_eq (x : GaussianInt) :
      (Zsqrtd.norm x).natAbs = x.re.natAbs * x.re.natAbs + x.im.natAbs * x.im.natAbs
      @[implicit_reducible]
      theorem GaussianInt.div_def (x y : GaussianInt) :
      x / y = { re := round ((x * star y).re / (Zsqrtd.norm y)), im := round ((x * star y).im / (Zsqrtd.norm y)) }
      @[implicit_reducible]
      theorem GaussianInt.mod_def (x y : GaussianInt) :
      x % y = x - y * (x / y)
      theorem GaussianInt.natAbs_norm_mod_lt (x : GaussianInt) {y : GaussianInt} (hy : y 0) :
      (Zsqrtd.norm (x % y)).natAbs < (Zsqrtd.norm y).natAbs
      theorem GaussianInt.norm_le_norm_mul_left (x : GaussianInt) {y : GaussianInt} (hy : y 0) :
      (Zsqrtd.norm x).natAbs (Zsqrtd.norm (x * y)).natAbs
      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