Documentation

Mathlib.RingTheory.Polynomial.Chebyshev

Chebyshev polynomials #

The Chebyshev polynomials are families of polynomials indexed by , with integral coefficients.

Main definitions #

Main statements #

Implementation details #

Since Chebyshev polynomials have interesting behaviour over the complex numbers and modulo p, we define them to have coefficients in an arbitrary commutative ring, even though technically would suffice. The benefit of allowing arbitrary coefficient rings, is that the statements afterwards are clean, and do not have map (Int.castRingHom R) interfering all the time.

References #

[Lionel Ponton, Roots of the Chebyshev polynomials: A purely algebraic approach] [Pon20]

TODO #

noncomputable def Polynomial.Chebyshev.T (R : Type u_1) [CommRing R] :

T n is the n-th Chebyshev polynomial of the first kind.

Equations
Instances For
    theorem Polynomial.Chebyshev.induct (motive : Prop) (zero : motive 0) (one : motive 1) (add_two : ∀ (n : ), motive (n + 1)motive nmotive (n + 2)) (neg_add_one : ∀ (n : ), motive (-n)motive (-n + 1)motive (-n - 1)) (a : ) :
    motive a

    Induction principle used for proving facts about Chebyshev polynomials.

    @[simp]
    theorem Polynomial.Chebyshev.T_add_two (R : Type u_1) [CommRing R] (n : ) :
    T R (n + 2) = 2 * X * T R (n + 1) - T R n
    theorem Polynomial.Chebyshev.T_add_one (R : Type u_1) [CommRing R] (n : ) :
    T R (n + 1) = 2 * X * T R n - T R (n - 1)
    theorem Polynomial.Chebyshev.T_sub_two (R : Type u_1) [CommRing R] (n : ) :
    T R (n - 2) = 2 * X * T R (n - 1) - T R n
    theorem Polynomial.Chebyshev.T_sub_one (R : Type u_1) [CommRing R] (n : ) :
    T R (n - 1) = 2 * X * T R n - T R (n + 1)
    theorem Polynomial.Chebyshev.T_eq (R : Type u_1) [CommRing R] (n : ) :
    T R n = 2 * X * T R (n - 1) - T R (n - 2)
    @[simp]
    theorem Polynomial.Chebyshev.T_zero (R : Type u_1) [CommRing R] :
    T R 0 = 1
    @[simp]
    theorem Polynomial.Chebyshev.T_one (R : Type u_1) [CommRing R] :
    T R 1 = X
    theorem Polynomial.Chebyshev.T_neg_one (R : Type u_1) [CommRing R] :
    T R (-1) = X
    theorem Polynomial.Chebyshev.T_two (R : Type u_1) [CommRing R] :
    T R 2 = 2 * X ^ 2 - 1
    @[simp]
    theorem Polynomial.Chebyshev.T_neg (R : Type u_1) [CommRing R] (n : ) :
    T R (-n) = T R n
    theorem Polynomial.Chebyshev.T_natAbs (R : Type u_1) [CommRing R] (n : ) :
    T R n.natAbs = T R n
    theorem Polynomial.Chebyshev.T_neg_two (R : Type u_1) [CommRing R] :
    T R (-2) = 2 * X ^ 2 - 1
    @[simp]
    theorem Polynomial.Chebyshev.T_eval_one (R : Type u_1) [CommRing R] (n : ) :
    eval 1 (T R n) = 1
    @[simp]
    theorem Polynomial.Chebyshev.T_eval_neg_one (R : Type u_1) [CommRing R] (n : ) :
    eval (-1) (T R n) = n.negOnePow
    noncomputable def Polynomial.Chebyshev.U (R : Type u_1) [CommRing R] :

    U n is the n-th Chebyshev polynomial of the second kind.

    Equations
    Instances For
      @[simp]
      theorem Polynomial.Chebyshev.U_add_two (R : Type u_1) [CommRing R] (n : ) :
      U R (n + 2) = 2 * X * U R (n + 1) - U R n
      theorem Polynomial.Chebyshev.U_add_one (R : Type u_1) [CommRing R] (n : ) :
      U R (n + 1) = 2 * X * U R n - U R (n - 1)
      theorem Polynomial.Chebyshev.U_sub_two (R : Type u_1) [CommRing R] (n : ) :
      U R (n - 2) = 2 * X * U R (n - 1) - U R n
      theorem Polynomial.Chebyshev.U_sub_one (R : Type u_1) [CommRing R] (n : ) :
      U R (n - 1) = 2 * X * U R n - U R (n + 1)
      theorem Polynomial.Chebyshev.U_eq (R : Type u_1) [CommRing R] (n : ) :
      U R n = 2 * X * U R (n - 1) - U R (n - 2)
      @[simp]
      theorem Polynomial.Chebyshev.U_zero (R : Type u_1) [CommRing R] :
      U R 0 = 1
      @[simp]
      theorem Polynomial.Chebyshev.U_one (R : Type u_1) [CommRing R] :
      U R 1 = 2 * X
      @[simp]
      theorem Polynomial.Chebyshev.U_neg_one (R : Type u_1) [CommRing R] :
      U R (-1) = 0
      theorem Polynomial.Chebyshev.U_two (R : Type u_1) [CommRing R] :
      U R 2 = 4 * X ^ 2 - 1
      @[simp]
      theorem Polynomial.Chebyshev.U_neg_two (R : Type u_1) [CommRing R] :
      U R (-2) = -1
      theorem Polynomial.Chebyshev.U_neg_sub_one (R : Type u_1) [CommRing R] (n : ) :
      U R (-n - 1) = -U R (n - 1)
      theorem Polynomial.Chebyshev.U_neg (R : Type u_1) [CommRing R] (n : ) :
      U R (-n) = -U R (n - 2)
      @[simp]
      theorem Polynomial.Chebyshev.U_neg_sub_two (R : Type u_1) [CommRing R] (n : ) :
      U R (-n - 2) = -U R n
      @[simp]
      theorem Polynomial.Chebyshev.U_eval_one (R : Type u_1) [CommRing R] (n : ) :
      eval 1 (U R n) = n + 1
      @[simp]
      theorem Polynomial.Chebyshev.U_eval_neg_one (R : Type u_1) [CommRing R] (n : ) :
      eval (-1) (U R n) = n.negOnePow * (n + 1)
      theorem Polynomial.Chebyshev.U_eq_X_mul_U_add_T (R : Type u_1) [CommRing R] (n : ) :
      U R (n + 1) = X * U R n + T R (n + 1)
      theorem Polynomial.Chebyshev.T_eq_U_sub_X_mul_U (R : Type u_1) [CommRing R] (n : ) :
      T R n = U R n - X * U R (n - 1)
      theorem Polynomial.Chebyshev.T_eq_X_mul_T_sub_pol_U (R : Type u_1) [CommRing R] (n : ) :
      T R (n + 2) = X * T R (n + 1) - (1 - X ^ 2) * U R n
      theorem Polynomial.Chebyshev.one_sub_X_sq_mul_U_eq_pol_in_T (R : Type u_1) [CommRing R] (n : ) :
      (1 - X ^ 2) * U R n = X * T R (n + 1) - T R (n + 2)
      noncomputable def Polynomial.Chebyshev.C (R : Type u_1) [CommRing R] :

      C n is the nth rescaled Chebyshev polynomial of the first kind (also known as a Vieta–Lucas polynomial), given by $C_n(2x) = 2T_n(x)$. See Polynomial.Chebyshev.C_comp_two_mul_X.

      Equations
      Instances For
        @[simp]
        theorem Polynomial.Chebyshev.C_add_two (R : Type u_1) [CommRing R] (n : ) :
        C R (n + 2) = X * C R (n + 1) - C R n
        theorem Polynomial.Chebyshev.C_add_one (R : Type u_1) [CommRing R] (n : ) :
        C R (n + 1) = X * C R n - C R (n - 1)
        theorem Polynomial.Chebyshev.C_sub_two (R : Type u_1) [CommRing R] (n : ) :
        C R (n - 2) = X * C R (n - 1) - C R n
        theorem Polynomial.Chebyshev.C_sub_one (R : Type u_1) [CommRing R] (n : ) :
        C R (n - 1) = X * C R n - C R (n + 1)
        theorem Polynomial.Chebyshev.C_eq (R : Type u_1) [CommRing R] (n : ) :
        C R n = X * C R (n - 1) - C R (n - 2)
        @[simp]
        theorem Polynomial.Chebyshev.C_zero (R : Type u_1) [CommRing R] :
        C R 0 = 2
        @[simp]
        theorem Polynomial.Chebyshev.C_one (R : Type u_1) [CommRing R] :
        C R 1 = X
        theorem Polynomial.Chebyshev.C_neg_one (R : Type u_1) [CommRing R] :
        C R (-1) = X
        theorem Polynomial.Chebyshev.C_two (R : Type u_1) [CommRing R] :
        C R 2 = X ^ 2 - 2
        @[simp]
        theorem Polynomial.Chebyshev.C_neg (R : Type u_1) [CommRing R] (n : ) :
        C R (-n) = C R n
        theorem Polynomial.Chebyshev.C_natAbs (R : Type u_1) [CommRing R] (n : ) :
        C R n.natAbs = C R n
        theorem Polynomial.Chebyshev.C_neg_two (R : Type u_1) [CommRing R] :
        C R (-2) = X ^ 2 - 2
        theorem Polynomial.Chebyshev.C_comp_two_mul_X (R : Type u_1) [CommRing R] (n : ) :
        (C R n).comp (2 * X) = 2 * T R n
        @[simp]
        theorem Polynomial.Chebyshev.C_eval_two (R : Type u_1) [CommRing R] (n : ) :
        eval 2 (C R n) = 2
        @[simp]
        theorem Polynomial.Chebyshev.C_eval_neg_two (R : Type u_1) [CommRing R] (n : ) :
        eval (-2) (C R n) = 2 * n.negOnePow
        theorem Polynomial.Chebyshev.C_eq_two_mul_T_comp_half_mul_X (R : Type u_1) [CommRing R] [Invertible 2] (n : ) :
        C R n = 2 * (T R n).comp (Polynomial.C 2 * X)
        theorem Polynomial.Chebyshev.T_eq_half_mul_C_comp_two_mul_X (R : Type u_1) [CommRing R] [Invertible 2] (n : ) :
        T R n = Polynomial.C 2 * (C R n).comp (2 * X)
        noncomputable def Polynomial.Chebyshev.S (R : Type u_1) [CommRing R] :

        S n is the nth rescaled Chebyshev polynomial of the second kind (also known as a Vieta–Fibonacci polynomial), given by $S_n(2x) = U_n(x)$. See Polynomial.Chebyshev.S_comp_two_mul_X.

        Equations
        Instances For
          @[simp]
          theorem Polynomial.Chebyshev.S_add_two (R : Type u_1) [CommRing R] (n : ) :
          S R (n + 2) = X * S R (n + 1) - S R n
          theorem Polynomial.Chebyshev.S_add_one (R : Type u_1) [CommRing R] (n : ) :
          S R (n + 1) = X * S R n - S R (n - 1)
          theorem Polynomial.Chebyshev.S_sub_two (R : Type u_1) [CommRing R] (n : ) :
          S R (n - 2) = X * S R (n - 1) - S R n
          theorem Polynomial.Chebyshev.S_sub_one (R : Type u_1) [CommRing R] (n : ) :
          S R (n - 1) = X * S R n - S R (n + 1)
          theorem Polynomial.Chebyshev.S_eq (R : Type u_1) [CommRing R] (n : ) :
          S R n = X * S R (n - 1) - S R (n - 2)
          @[simp]
          theorem Polynomial.Chebyshev.S_zero (R : Type u_1) [CommRing R] :
          S R 0 = 1
          @[simp]
          theorem Polynomial.Chebyshev.S_one (R : Type u_1) [CommRing R] :
          S R 1 = X
          @[simp]
          theorem Polynomial.Chebyshev.S_neg_one (R : Type u_1) [CommRing R] :
          S R (-1) = 0
          theorem Polynomial.Chebyshev.S_two (R : Type u_1) [CommRing R] :
          S R 2 = X ^ 2 - 1
          @[simp]
          theorem Polynomial.Chebyshev.S_neg_two (R : Type u_1) [CommRing R] :
          S R (-2) = -1
          theorem Polynomial.Chebyshev.S_neg_sub_one (R : Type u_1) [CommRing R] (n : ) :
          S R (-n - 1) = -S R (n - 1)
          theorem Polynomial.Chebyshev.S_neg (R : Type u_1) [CommRing R] (n : ) :
          S R (-n) = -S R (n - 2)
          @[simp]
          theorem Polynomial.Chebyshev.S_neg_sub_two (R : Type u_1) [CommRing R] (n : ) :
          S R (-n - 2) = -S R n
          @[simp]
          theorem Polynomial.Chebyshev.S_eval_two (R : Type u_1) [CommRing R] (n : ) :
          eval 2 (S R n) = n + 1
          @[simp]
          theorem Polynomial.Chebyshev.S_eval_neg_two (R : Type u_1) [CommRing R] (n : ) :
          eval (-2) (S R n) = n.negOnePow * (n + 1)
          theorem Polynomial.Chebyshev.S_comp_two_mul_X (R : Type u_1) [CommRing R] (n : ) :
          (S R n).comp (2 * X) = U R n
          theorem Polynomial.Chebyshev.S_sq_add_S_sq (R : Type u_1) [CommRing R] (n : ) :
          S R n ^ 2 + S R (n + 1) ^ 2 - X * S R n * S R (n + 1) = 1
          theorem Polynomial.Chebyshev.S_eq_U_comp_half_mul_X (R : Type u_1) [CommRing R] [Invertible 2] (n : ) :
          S R n = (U R n).comp (Polynomial.C 2 * X)
          theorem Polynomial.Chebyshev.S_eq_X_mul_S_add_C (R : Type u_1) [CommRing R] (n : ) :
          2 * S R (n + 1) = X * S R n + C R (n + 1)
          theorem Polynomial.Chebyshev.C_eq_S_sub_X_mul_S (R : Type u_1) [CommRing R] (n : ) :
          C R n = 2 * S R n - X * S R (n - 1)
          @[simp]
          theorem Polynomial.Chebyshev.map_T {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] (f : R →+* R') (n : ) :
          map f (T R n) = T R' n
          @[simp]
          theorem Polynomial.Chebyshev.map_U {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] (f : R →+* R') (n : ) :
          map f (U R n) = U R' n
          @[simp]
          theorem Polynomial.Chebyshev.map_C {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] (f : R →+* R') (n : ) :
          map f (C R n) = C R' n
          @[simp]
          theorem Polynomial.Chebyshev.map_S {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] (f : R →+* R') (n : ) :
          map f (S R n) = S R' n
          @[simp]
          theorem Polynomial.Chebyshev.aeval_T {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R') (n : ) :
          (aeval x) (T R n) = eval x (T R' n)
          @[simp]
          theorem Polynomial.Chebyshev.aeval_U {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R') (n : ) :
          (aeval x) (U R n) = eval x (U R' n)
          @[simp]
          theorem Polynomial.Chebyshev.aeval_C {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R') (n : ) :
          (aeval x) (C R n) = eval x (C R' n)
          @[simp]
          theorem Polynomial.Chebyshev.aeval_S {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R') (n : ) :
          (aeval x) (S R n) = eval x (S R' n)
          @[simp]
          theorem Polynomial.Chebyshev.algebraMap_eval_T {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R) (n : ) :
          (algebraMap R R') (eval x (T R n)) = eval ((algebraMap R R') x) (T R' n)
          @[simp]
          theorem Polynomial.Chebyshev.algebraMap_eval_U {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R) (n : ) :
          (algebraMap R R') (eval x (U R n)) = eval ((algebraMap R R') x) (U R' n)
          @[simp]
          theorem Polynomial.Chebyshev.algebraMap_eval_C {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R) (n : ) :
          (algebraMap R R') (eval x (C R n)) = eval ((algebraMap R R') x) (C R' n)
          @[simp]
          theorem Polynomial.Chebyshev.algebraMap_eval_S {R : Type u_1} {R' : Type u_2} [CommRing R] [CommRing R'] [Algebra R R'] (x : R) (n : ) :
          (algebraMap R R') (eval x (S R n)) = eval ((algebraMap R R') x) (S R' n)
          theorem Polynomial.Chebyshev.T_derivative_eq_U {R : Type u_1} [CommRing R] (n : ) :
          derivative (T R n) = n * U R (n - 1)
          theorem Polynomial.Chebyshev.one_sub_X_sq_mul_derivative_T_eq_poly_in_T {R : Type u_1} [CommRing R] (n : ) :
          (1 - X ^ 2) * derivative (T R (n + 1)) = (n + 1) * (T R n - X * T R (n + 1))
          theorem Polynomial.Chebyshev.add_one_mul_T_eq_poly_in_U {R : Type u_1} [CommRing R] (n : ) :
          (n + 1) * T R (n + 1) = X * U R n - (1 - X ^ 2) * derivative (U R n)
          theorem Polynomial.Chebyshev.T_mul_T (R : Type u_1) [CommRing R] (m k : ) :
          2 * T R m * T R k = T R (m + k) + T R (m - k)

          Twice the product of two Chebyshev T polynomials is the sum of two other Chebyshev T polynomials.

          @[deprecated Polynomial.Chebyshev.T_mul_T (since := "2024-12-03")]
          theorem Polynomial.Chebyshev.mul_T (R : Type u_1) [CommRing R] (m k : ) :
          2 * T R m * T R k = T R (m + k) + T R (m - k)

          Alias of Polynomial.Chebyshev.T_mul_T.


          Twice the product of two Chebyshev T polynomials is the sum of two other Chebyshev T polynomials.

          theorem Polynomial.Chebyshev.C_mul_C (R : Type u_1) [CommRing R] (m k : ) :
          C R m * C R k = C R (m + k) + C R (m - k)

          The product of two Chebyshev C polynomials is the sum of two other Chebyshev C polynomials.

          theorem Polynomial.Chebyshev.T_mul (R : Type u_1) [CommRing R] (m n : ) :
          T R (m * n) = (T R m).comp (T R n)

          The (m * n)-th Chebyshev T polynomial is the composition of the m-th and n-th.

          theorem Polynomial.Chebyshev.C_mul (R : Type u_1) [CommRing R] (m n : ) :
          C R (m * n) = (C R m).comp (C R n)

          The (m * n)-th Chebyshev C polynomial is the composition of the m-th and n-th.