Documentation

Mathlib.RingTheory.PolynomialAlgebra

Algebra isomorphism between matrices of polynomials and polynomials of matrices #

Given [CommRing R] [Ring A] [Algebra R A] we show A[X] ≃ₐ[R] (A ⊗[R] R[X]). Combining this with the isomorphism Matrix n n A ≃ₐ[R] (A ⊗[R] Matrix n n R) proved earlier in RingTheory.MatrixAlgebra, we obtain the algebra isomorphism

def matPolyEquiv :
    Matrix n n R[X] ≃ₐ[R] (Matrix n n R)[X]

which is characterized by

coeff (matPolyEquiv m) k i j = coeff (m i j) k

We will use this algebra isomorphism to prove the Cayley-Hamilton theorem.

(Implementation detail). The function underlying A ⊗[R] R[X] →ₐ[R] A[X], as a bilinear function of two arguments.

Equations
Instances For
    theorem PolyEquivTensor.toFunBilinear_apply_eq_sum (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (a : A) (p : Polynomial R) :
    ((PolyEquivTensor.toFunBilinear R A) a) p = p.sum fun (n : ) (r : R) => (Polynomial.monomial n) (a * (algebraMap R A) r)

    (Implementation detail). The function underlying A ⊗[R] R[X] →ₐ[R] A[X], as a linear map.

    Equations
    Instances For
      theorem PolyEquivTensor.toFunLinear_mul_tmul_mul_aux_1 (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (p : Polynomial R) (k : ) (h : Decidable ¬p.coeff k = 0) (a : A) :
      (if ¬p.coeff k = 0 then a * (algebraMap R A) (p.coeff k) else 0) = a * (algebraMap R A) (p.coeff k)
      theorem PolyEquivTensor.toFunLinear_mul_tmul_mul_aux_2 (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (k : ) (a₁ a₂ : A) (p₁ p₂ : Polynomial R) :
      a₁ * a₂ * (algebraMap R A) ((p₁ * p₂).coeff k) = xFinset.antidiagonal k, a₁ * (algebraMap R A) (p₁.coeff x.1) * (a₂ * (algebraMap R A) (p₂.coeff x.2))
      theorem PolyEquivTensor.toFunLinear_mul_tmul_mul (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (a₁ a₂ : A) (p₁ p₂ : Polynomial R) :
      (PolyEquivTensor.toFunLinear R A) ((a₁ * a₂) ⊗ₜ[R] (p₁ * p₂)) = (PolyEquivTensor.toFunLinear R A) (a₁ ⊗ₜ[R] p₁) * (PolyEquivTensor.toFunLinear R A) (a₂ ⊗ₜ[R] p₂)

      (Implementation detail). The algebra homomorphism A ⊗[R] R[X] →ₐ[R] A[X].

      Equations
      Instances For
        @[simp]
        theorem PolyEquivTensor.toFunAlgHom_apply_tmul (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (a : A) (p : Polynomial R) :
        (PolyEquivTensor.toFunAlgHom R A) (a ⊗ₜ[R] p) = p.sum fun (n : ) (r : R) => (Polynomial.monomial n) (a * (algebraMap R A) r)
        def PolyEquivTensor.invFun (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (p : Polynomial A) :

        (Implementation detail.)

        The bare function A[X] → A ⊗[R] R[X]. (We don't need to show that it's an algebra map, thankfully --- just that it's an inverse.)

        Equations
        Instances For

          (Implementation detail)

          The equivalence, ignoring the algebra structure, (A ⊗[R] R[X]) ≃ A[X].

          Equations
          Instances For

            The R-algebra isomorphism A[X] ≃ₐ[R] (A ⊗[R] R[X]).

            Equations
            • One or more equations did not get rendered due to their size.
            Instances For
              @[simp]
              theorem polyEquivTensor_symm_apply_tmul (R : Type u_1) (A : Type u_2) [CommSemiring R] [Semiring A] [Algebra R A] (a : A) (p : Polynomial R) :
              (polyEquivTensor R A).symm (a ⊗ₜ[R] p) = p.sum fun (n : ) (r : R) => (Polynomial.monomial n) (a * (algebraMap R A) r)

              The A-algebra isomorphism A[X] ≃ₐ[A] A ⊗[R] R[X] (when A is commutative).

              Equations
              Instances For
                @[simp]
                theorem coe_polyEquivTensor' (R : Type u_1) [CommSemiring R] (A : Type u_3) [CommSemiring A] [Algebra R A] :

                polyEquivTensor' R A is the same as polyEquivTensor R A as a function.

                @[simp]
                theorem coe_polyEquivTensor'_symm (R : Type u_1) [CommSemiring R] (A : Type u_3) [CommSemiring A] [Algebra R A] :
                (polyEquivTensor' R A).symm = (polyEquivTensor R A).symm
                noncomputable def matPolyEquiv {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] :

                The algebra isomorphism stating "matrices of polynomials are the same as polynomials of matrices".

                (You probably shouldn't attempt to use this underlying definition --- it's an algebra equivalence, and characterised extensionally by the lemma matPolyEquiv_coeff_apply below.)

                Equations
                Instances For
                  @[simp]
                  theorem matPolyEquiv_symm_C {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (M : Matrix n n R) :
                  matPolyEquiv.symm (Polynomial.C M) = M.map Polynomial.C
                  @[simp]
                  theorem matPolyEquiv_map_C {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (M : Matrix n n R) :
                  matPolyEquiv (M.map Polynomial.C) = Polynomial.C M
                  @[simp]
                  @[simp]
                  theorem matPolyEquiv_diagonal_X {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] :
                  matPolyEquiv (Matrix.diagonal fun (x : n) => Polynomial.X) = Polynomial.X
                  theorem matPolyEquiv_coeff_apply_aux_1 {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (i j : n) (k : ) (x : R) :
                  theorem matPolyEquiv_coeff_apply_aux_2 {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (i j : n) (p : Polynomial R) (k : ) :
                  (matPolyEquiv (Matrix.stdBasisMatrix i j p)).coeff k = Matrix.stdBasisMatrix i j (p.coeff k)
                  @[simp]
                  theorem matPolyEquiv_coeff_apply {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (m : Matrix n n (Polynomial R)) (k : ) (i j : n) :
                  (matPolyEquiv m).coeff k i j = (m i j).coeff k
                  @[simp]
                  theorem matPolyEquiv_symm_apply_coeff {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (p : Polynomial (Matrix n n R)) (i j : n) (k : ) :
                  (matPolyEquiv.symm p i j).coeff k = p.coeff k i j
                  theorem matPolyEquiv_smul_one {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (p : Polynomial R) :
                  matPolyEquiv (p 1) = Polynomial.map (algebraMap R (Matrix n n R)) p
                  @[simp]
                  theorem matPolyEquiv_map_smul {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (p : Polynomial R) (M : Matrix n n (Polynomial R)) :
                  matPolyEquiv (p M) = Polynomial.map (algebraMap R (Matrix n n R)) p * matPolyEquiv M
                  theorem support_subset_support_matPolyEquiv {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] (m : Matrix n n (Polynomial R)) (i j : n) :
                  (m i j).support (matPolyEquiv m).support
                  def RingHom.polyToMatrix {R : Type u_1} {A : Type u_2} [CommSemiring R] [Semiring A] {n : Type w} [DecidableEq n] [Fintype n] (f : A →+* Matrix n n R) :

                  Extend a ring hom A → Mₙ(R) to a ring hom A[X] → Mₙ(R[X]).

                  Equations
                  Instances For
                    theorem evalRingHom_mapMatrix_comp_polyToMatrix {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] {S : Type u_3} [CommSemiring S] (f : S →+* Matrix n n R) :
                    (Polynomial.evalRingHom 0).mapMatrix.comp f.polyToMatrix = f.comp (Polynomial.evalRingHom 0)
                    theorem evalRingHom_mapMatrix_comp_compRingEquiv {R : Type u_1} [CommSemiring R] {n : Type w} [DecidableEq n] [Fintype n] {m : Type u_4} [Fintype m] [DecidableEq m] :
                    (Polynomial.evalRingHom 0).mapMatrix.comp (Matrix.compRingEquiv m n (Polynomial R)) = (Matrix.compRingEquiv m n R).toRingHom.comp (Polynomial.evalRingHom 0).mapMatrix.mapMatrix