Documentation

Mathlib.RingTheory.WittVector.Truncated

Truncated Witt vectors #

The ring of truncated Witt vectors (of length n) is a quotient of the ring of Witt vectors. It retains the first n coefficients of each Witt vector. In this file, we set up the basic quotient API for this ring.

The ring of Witt vectors is the projective limit of all the rings of truncated Witt vectors.

Main declarations #

References #

def TruncatedWittVector :
(n : ) → (R : Type u_2) → Type u_2

A truncated Witt vector over R is a vector of elements of R, i.e., the first n coefficients of a Witt vector. We will define operations on this type that are compatible with the (untruncated) Witt vector operations.

TruncatedWittVector p n R takes a parameter p : ℕ that is not used in the definition. In practice, this number p is assumed to be a prime number, and under this assumption we construct a ring structure on TruncatedWittVector p n R. (TruncatedWittVector p₁ n R and TruncatedWittVector p₂ n R are definitionally equal as types but will have different ring operations.)

Equations
Instances For
    Equations
    def TruncatedWittVector.mk (p : ) {n : } {R : Type u_1} (x : Fin nR) :

    Create a TruncatedWittVector from a vector x.

    Equations
    Instances For
      def TruncatedWittVector.coeff {p n : } {R : Type u_1} (i : Fin n) (x : TruncatedWittVector p n R) :
      R

      x.coeff i is the ith entry of x.

      Equations
      Instances For
        theorem TruncatedWittVector.ext {p n : } {R : Type u_1} {x y : TruncatedWittVector p n R} (h : ∀ (i : Fin n), coeff i x = coeff i y) :
        x = y
        @[simp]
        theorem TruncatedWittVector.coeff_mk {p n : } {R : Type u_1} (x : Fin nR) (i : Fin n) :
        coeff i (mk p x) = x i
        @[simp]
        theorem TruncatedWittVector.mk_coeff {p n : } {R : Type u_1} (x : TruncatedWittVector p n R) :
        (mk p fun (i : Fin n) => coeff i x) = x
        def TruncatedWittVector.out {p n : } {R : Type u_1} [CommRing R] (x : TruncatedWittVector p n R) :

        We can turn a truncated Witt vector x into a Witt vector by setting all coefficients after x to be 0.

        Equations
        Instances For
          @[simp]
          theorem TruncatedWittVector.coeff_out {p n : } {R : Type u_1} [CommRing R] (x : TruncatedWittVector p n R) (i : Fin n) :
          x.out.coeff i = coeff i x
          def WittVector.truncateFun {p : } (n : ) {R : Type u_1} (x : WittVector p R) :

          truncateFun n x uses the first n entries of x to construct a TruncatedWittVector, which has the same base p as x. This function is bundled into a ring homomorphism in WittVector.truncate

          Equations
          Instances For
            @[simp]
            theorem WittVector.coeff_truncateFun {p n : } {R : Type u_1} (x : WittVector p R) (i : Fin n) :
            @[simp]
            theorem WittVector.out_truncateFun {p n : } {R : Type u_1} [CommRing R] (x : WittVector p R) :
            (truncateFun n x).out = init n x
            @[simp]
            Equations
            Equations
            instance TruncatedWittVector.instAdd (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
            Equations
            instance TruncatedWittVector.instMul (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
            Equations
            instance TruncatedWittVector.instNeg (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
            Equations
            instance TruncatedWittVector.instSub (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
            Equations
            Equations
            Equations
            Equations
            @[simp]
            theorem TruncatedWittVector.coeff_zero (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] (i : Fin n) :
            coeff i 0 = 0

            A macro tactic used to prove that truncateFun respects ring operations.

            Equations
            Instances For
              @[simp]
              theorem WittVector.truncateFun_zero (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
              @[simp]
              theorem WittVector.truncateFun_one (p n : ) (R : Type u_1) [CommRing R] [Fact (Nat.Prime p)] :
              @[simp]
              theorem WittVector.truncateFun_add {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x y : WittVector p R) :
              @[simp]
              theorem WittVector.truncateFun_mul {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x y : WittVector p R) :
              theorem WittVector.truncateFun_neg {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x : WittVector p R) :
              theorem WittVector.truncateFun_sub {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x y : WittVector p R) :
              theorem WittVector.truncateFun_nsmul {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) (x : WittVector p R) :
              theorem WittVector.truncateFun_zsmul {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) (x : WittVector p R) :
              theorem WittVector.truncateFun_pow {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x : WittVector p R) (m : ) :
              truncateFun n (x ^ m) = truncateFun n x ^ m
              theorem WittVector.truncateFun_natCast {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) :
              truncateFun n m = m
              @[deprecated WittVector.truncateFun_natCast (since := "2024-04-17")]
              theorem WittVector.truncateFun_nat_cast {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) :
              truncateFun n m = m

              Alias of WittVector.truncateFun_natCast.

              theorem WittVector.truncateFun_intCast {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) :
              truncateFun n m = m
              @[deprecated WittVector.truncateFun_intCast (since := "2024-04-17")]
              theorem WittVector.truncateFun_int_cast {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (m : ) :
              truncateFun n m = m

              Alias of WittVector.truncateFun_intCast.

              Equations
              noncomputable def WittVector.truncate {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] :

              truncate n is a ring homomorphism that truncates x to its first n entries to obtain a TruncatedWittVector, which has the same base p as x.

              Equations
              Instances For
                @[simp]
                theorem WittVector.coeff_truncate {p n : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x : WittVector p R) (i : Fin n) :
                TruncatedWittVector.coeff i ((truncate n) x) = x.coeff i
                theorem WittVector.mem_ker_truncate {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (x : WittVector p R) :
                x RingHom.ker (truncate n) i < n, x.coeff i = 0
                @[simp]
                theorem WittVector.truncate_mk' (p n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] (f : R) :
                (truncate n) { coeff := f } = TruncatedWittVector.mk p fun (k : Fin n) => f k
                def TruncatedWittVector.truncate {p n : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {m : } (hm : n m) :

                A ring homomorphism that truncates a truncated Witt vector of length m to a truncated Witt vector of length n, for n ≤ m.

                Equations
                Instances For
                  @[simp]
                  theorem TruncatedWittVector.truncate_wittVector_truncate {p n : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {m : } (hm : n m) (x : WittVector p R) :
                  @[simp]
                  theorem TruncatedWittVector.truncate_truncate {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {n₁ n₂ n₃ : } (h1 : n₁ n₂) (h2 : n₂ n₃) (x : TruncatedWittVector p n₃ R) :
                  (truncate h1) ((truncate h2) x) = (truncate ) x
                  @[simp]
                  theorem TruncatedWittVector.truncate_comp {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {n₁ n₂ n₃ : } (h1 : n₁ n₂) (h2 : n₂ n₃) :
                  (truncate h1).comp (truncate h2) = truncate
                  theorem TruncatedWittVector.truncate_surjective {p n : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {m : } (hm : n m) :
                  @[simp]
                  theorem TruncatedWittVector.coeff_truncate {p n : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {m : } (hm : n m) (i : Fin n) (x : TruncatedWittVector p m R) :
                  coeff i ((truncate hm) x) = coeff (Fin.castLE hm i) x
                  def WittVector.liftFun {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] (f : (k : ) → S →+* TruncatedWittVector p k R) (s : S) :

                  Given a family fₖ : S → TruncatedWittVector p k R and s : S, we produce a Witt vector by defining the kth entry to be the final entry of fₖ s.

                  Equations
                  Instances For
                    @[simp]
                    theorem WittVector.truncate_liftFun {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] {f : (k : ) → S →+* TruncatedWittVector p k R} (f_compat : ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁) (s : S) :
                    (truncate n) (liftFun f s) = (f n) s
                    def WittVector.lift {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] (f : (k : ) → S →+* TruncatedWittVector p k R) (f_compat : ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁) :

                    Given compatible ring homs from S into TruncatedWittVector n for each n, we can lift these to a ring hom S → 𝕎 R.

                    lift defines the universal property of 𝕎 R as the inverse limit of TruncatedWittVector n.

                    Equations
                    Instances For
                      @[simp]
                      theorem WittVector.truncate_lift {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] {f : (k : ) → S →+* TruncatedWittVector p k R} (f_compat : ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁) (s : S) :
                      (truncate n) ((lift f f_compat) s) = (f n) s
                      @[simp]
                      theorem WittVector.truncate_comp_lift {p : } (n : ) {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] {f : (k : ) → S →+* TruncatedWittVector p k R} (f_compat : ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁) :
                      (truncate n).comp (lift f f_compat) = f n
                      theorem WittVector.lift_unique {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] {f : (k : ) → S →+* TruncatedWittVector p k R} (f_compat : ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁) (g : S →+* WittVector p R) (g_compat : ∀ (k : ), (truncate k).comp g = f k) :
                      lift f f_compat = g

                      The uniqueness part of the universal property of 𝕎 R.

                      def WittVector.liftEquiv {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] :
                      { f : (k : ) → S →+* TruncatedWittVector p k R // ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁ } (S →+* WittVector p R)

                      The universal property of 𝕎 R as projective limit of truncated Witt vector rings.

                      Equations
                      • One or more equations did not get rendered due to their size.
                      Instances For
                        @[simp]
                        theorem WittVector.liftEquiv_apply {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] (f : { f : (k : ) → S →+* TruncatedWittVector p k R // ∀ (k₁ k₂ : ) (hk : k₁ k₂), (TruncatedWittVector.truncate hk).comp (f k₂) = f k₁ }) :
                        liftEquiv f = lift f
                        @[simp]
                        theorem WittVector.liftEquiv_symm_apply_coe {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] (g : S →+* WittVector p R) (k : ) :
                        (liftEquiv.symm g) k = (truncate k).comp g
                        theorem WittVector.hom_ext {p : } {R : Type u_1} [CommRing R] [Fact (Nat.Prime p)] {S : Type u_2} [Semiring S] (g₁ g₂ : S →+* WittVector p R) (h : ∀ (k : ), (truncate k).comp g₁ = (truncate k).comp g₂) :
                        g₁ = g₂