Documentation

Mathlib.Algebra.CharP.MixedCharZero

Equal and mixed characteristic #

In commutative algebra, some statements are simpler when working over a -algebra R, in which case one also says that the ring has "equal characteristic zero". A ring that is not a -algebra has either positive characteristic or there exists a prime ideal I ⊂ R such that the quotient R ⧸ I has positive characteristic p > 0. In this case one speaks of "mixed characteristic (0, p)", where p is only unique if R is local.

Examples of mixed characteristic rings are or the p-adic integers/numbers.

This file provides the main theorem split_by_characteristic that splits any proposition P into the following three cases:

  1. Positive characteristic: CharP R p (where p ≠ 0)
  2. Equal characteristic zero: Algebra ℚ R
  3. Mixed characteristic: MixedCharZero R p (where p is prime)

Main definitions #

Main results #

This main theorem has the following three corollaries which include the positive characteristic case for convenience:

Implementation Notes #

We use the terms EqualCharZero and AlgebraRat despite not being such definitions in mathlib. The former refers to the statement ∀ I : Ideal R, I ≠ ⊤ → CharZero (R ⧸ I), the latter refers to the existence of an instance [Algebra ℚ R]. The two are shown to be equivalent conditions.

TODO #

Mixed characteristic #

class MixedCharZero (R : Type u_1) [CommRing R] (p : ) :

A ring of characteristic zero is of "mixed characteristic (0, p)" if there exists an ideal such that the quotient R ⧸ I has characteristic p.

Remark: For p = 0, MixedChar R 0 is a meaningless definition (i.e. satisfied by any ring) as R ⧸ ⊥ ≅ R has by definition always characteristic zero. One could require (I ≠ ⊥) in the definition, but then MixedChar R 0 would mean something like -algebra of extension degree ≥ 1 and would be completely independent from whether something is a -algebra or not (e.g. ℚ[X] would satisfy it but wouldn't).

Instances
    theorem MixedCharZero.reduce_to_p_prime (R : Type u_1) [CommRing R] {P : Prop} :
    (∀ p > 0, MixedCharZero R pP) ∀ (p : ), Nat.Prime pMixedCharZero R pP

    Reduction to p prime: When proving any statement P about mixed characteristic rings we can always assume that p is prime.

    theorem MixedCharZero.reduce_to_maximal_ideal (R : Type u_1) [CommRing R] {p : } (hp : Nat.Prime p) :
    (∃ (I : Ideal R), I CharP (R I) p) ∃ (I : Ideal R), I.IsMaximal CharP (R I) p

    Reduction to I prime ideal: When proving statements about mixed characteristic rings, after we reduced to p prime, we can assume that the ideal I in the definition is maximal.

    Equal characteristic zero #

    A commutative ring R has "equal characteristic zero" if it satisfies one of the following equivalent properties:

    1. R is a -algebra.
    2. The quotient R ⧸ I has characteristic zero for any proper ideal I ⊂ R.
    3. R has characteristic zero and does not have mixed characteristic for any prime p.

    We show (1) ↔ (2) ↔ (3), and most of the following is concerned with constructing an explicit algebra map ℚ →+* R (given by x ↦ (x.num : R) /ₚ ↑x.pnatDen) for the direction (1) ← (2).

    Note: Property (2) is denoted as EqualCharZero in the statement names below.

    theorem EqualCharZero.of_algebraRat (R : Type u_1) [CommRing R] [Algebra R] (I : Ideal R) :
    I CharZero (R I)

    -algebra implies equal characteristic.

    theorem EqualCharZero.PNat.isUnit_natCast {R : Type u_1} [CommRing R] [h : Fact (∀ (I : Ideal R), I CharZero (R I))] (n : ℕ+) :
    IsUnit n

    Internal: Not intended to be used outside this local construction.

    noncomputable def EqualCharZero.pnatCast {R : Type u_1} [CommRing R] [Fact (∀ (I : Ideal R), I CharZero (R I))] :
    ℕ+Rˣ
    Equations
      Instances For
        noncomputable instance EqualCharZero.coePNatUnits {R : Type u_1} [CommRing R] [Fact (∀ (I : Ideal R), I CharZero (R I))] :

        Internal: Not intended to be used outside this local construction.

        Equations
          @[simp]
          theorem EqualCharZero.pnatCast_one {R : Type u_1} [CommRing R] [Fact (∀ (I : Ideal R), I CharZero (R I))] :
          1 = 1

          Internal: Not intended to be used outside this local construction.

          @[simp]
          theorem EqualCharZero.pnatCast_eq_natCast {R : Type u_1} [CommRing R] [Fact (∀ (I : Ideal R), I CharZero (R I))] (n : ℕ+) :
          n = n

          Internal: Not intended to be used outside this local construction.

          noncomputable def EqualCharZero.algebraRat {R : Type u_1} [CommRing R] (h : ∀ (I : Ideal R), I CharZero (R I)) :

          Equal characteristic implies -algebra.

          Equations
            Instances For
              theorem EqualCharZero.of_not_mixedCharZero (R : Type u_1) [CommRing R] [CharZero R] (h : p > 0, ¬MixedCharZero R p) (I : Ideal R) :
              I CharZero (R I)

              Not mixed characteristic implies equal characteristic.

              theorem EqualCharZero.to_not_mixedCharZero (R : Type u_1) [CommRing R] (h : ∀ (I : Ideal R), I CharZero (R I)) (p : ) :
              p > 0¬MixedCharZero R p

              Equal characteristic implies not mixed characteristic.

              theorem EqualCharZero.iff_not_mixedCharZero (R : Type u_1) [CommRing R] [CharZero R] :
              (∀ (I : Ideal R), I CharZero (R I)) p > 0, ¬MixedCharZero R p

              A ring of characteristic zero has equal characteristic iff it does not have mixed characteristic for any p.

              theorem EqualCharZero.nonempty_algebraRat_iff (R : Type u_1) [CommRing R] :
              Nonempty (Algebra R) ∀ (I : Ideal R), I CharZero (R I)

              A ring is a -algebra iff it has equal characteristic zero.

              A ring of characteristic zero is not a -algebra iff it has mixed characteristic for some p.

              Splitting statements into different characteristic #

              Statements to split a proof by characteristic. There are 3 theorems here that are very similar. They only differ in the assumptions we can make on the positive characteristic case: Generally we need to consider all p ≠ 0, but if R is a local ring, we can assume that p is a prime power. And if R is a domain, we can even assume that p is prime.

              theorem split_equalCharZero_mixedCharZero (R : Type u_1) [CommRing R] {P : Prop} [CharZero R] (h_equal : ∀ (a : Algebra R), P) (h_mixed : ∀ (p : ), Nat.Prime pMixedCharZero R pP) :
              P

              Split a Prop in characteristic zero into equal and mixed characteristic.

              theorem split_by_characteristic (R : Type u_1) [CommRing R] {P : Prop} (h_pos : ∀ (p : ), p 0CharP R pP) (h_equal : ∀ (a : Algebra R), P) (h_mixed : ∀ (p : ), Nat.Prime pMixedCharZero R pP) :
              P

              Split any Prop over R into the three cases:

              • positive characteristic.
              • equal characteristic zero.
              • mixed characteristic (0, p).
              theorem split_by_characteristic_domain (R : Type u_1) [CommRing R] {P : Prop} [IsDomain R] (h_pos : ∀ (p : ), Nat.Prime pCharP R pP) (h_equal : ∀ (a : Algebra R), P) (h_mixed : ∀ (p : ), Nat.Prime pMixedCharZero R pP) :
              P

              In an IsDomain R, split any Prop over R into the three cases:

              • prime characteristic.
              • equal characteristic zero.
              • mixed characteristic (0, p).
              theorem split_by_characteristic_localRing (R : Type u_1) [CommRing R] {P : Prop} [IsLocalRing R] (h_pos : ∀ (p : ), IsPrimePow pCharP R pP) (h_equal : ∀ (a : Algebra R), P) (h_mixed : ∀ (p : ), Nat.Prime pMixedCharZero R pP) :
              P

              In a local ring R, split any predicate over R into the three cases:

              • prime power characteristic.
              • equal characteristic zero.
              • mixed characteristic (0, p).