Documentation

Mathlib.FieldTheory.AbelRuffini

The Abel-Ruffini Theorem #

This file proves one direction of the Abel-Ruffini theorem, namely that if an element is solvable by radicals, then its minimal polynomial has solvable Galois group.

Main definitions #

Main results #

theorem gal_C_isSolvable {F : Type u_1} [Field F] (x : F) :
IsSolvable (Polynomial.C x).Gal
theorem gal_X_isSolvable {F : Type u_1} [Field F] :
IsSolvable Polynomial.X.Gal
theorem gal_X_sub_C_isSolvable {F : Type u_1} [Field F] (x : F) :
IsSolvable (Polynomial.X - Polynomial.C x).Gal
theorem gal_X_pow_isSolvable {F : Type u_1} [Field F] (n : ) :
IsSolvable (Polynomial.X ^ n).Gal
theorem gal_mul_isSolvable {F : Type u_1} [Field F] {p : Polynomial F} {q : Polynomial F} :
IsSolvable p.GalIsSolvable q.GalIsSolvable (p * q).Gal
theorem gal_prod_isSolvable {F : Type u_1} [Field F] {s : Multiset (Polynomial F)} (hs : ps, IsSolvable p.Gal) :
IsSolvable s.prod.Gal
theorem gal_isSolvable_of_splits {F : Type u_1} [Field F] {p : Polynomial F} {q : Polynomial F} :
Fact (Polynomial.Splits (algebraMap F q.SplittingField) p)IsSolvable q.GalIsSolvable p.Gal
theorem gal_isSolvable_tower {F : Type u_1} [Field F] (p : Polynomial F) (q : Polynomial F) (hpq : Polynomial.Splits (algebraMap F q.SplittingField) p) (hp : IsSolvable p.Gal) (hq : IsSolvable (Polynomial.map (algebraMap F p.SplittingField) q).Gal) :
theorem gal_X_pow_sub_one_isSolvable {F : Type u_1} [Field F] (n : ) :
IsSolvable (Polynomial.X ^ n - 1).Gal
theorem gal_X_pow_sub_C_isSolvable_aux {F : Type u_1} [Field F] (n : ) (a : F) (h : Polynomial.Splits (RingHom.id F) (Polynomial.X ^ n - 1)) :
IsSolvable (Polynomial.X ^ n - Polynomial.C a).Gal
theorem splits_X_pow_sub_one_of_X_pow_sub_C {F : Type u_3} [Field F] {E : Type u_4} [Field E] (i : F →+* E) (n : ) {a : F} (ha : a 0) (h : Polynomial.Splits i (Polynomial.X ^ n - Polynomial.C a)) :
Polynomial.Splits i (Polynomial.X ^ n - 1)
theorem gal_X_pow_sub_C_isSolvable {F : Type u_1} [Field F] (n : ) (x : F) :
IsSolvable (Polynomial.X ^ n - Polynomial.C x).Gal
inductive IsSolvableByRad (F : Type u_1) [Field F] {E : Type u_2} [Field E] [Algebra F E] :
EProp

Inductive definition of solvable by radicals

Instances For
    def solvableByRad (F : Type u_1) [Field F] (E : Type u_2) [Field E] [Algebra F E] :

    The intermediate field of solvable-by-radicals elements

    Equations
    • solvableByRad F E = { carrier := IsSolvableByRad F, mul_mem' := , one_mem' := , add_mem' := , zero_mem' := , algebraMap_mem' := , inv_mem' := }
    Instances For
      theorem solvableByRad.induction {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] (P : { x : E // x solvableByRad F E }Prop) (base : ∀ (α : F), P ((algebraMap F { x : E // x solvableByRad F E }) α)) (add : ∀ (α β : { x : E // x solvableByRad F E }), P αP βP (α + β)) (neg : ∀ (α : { x : E // x solvableByRad F E }), P αP (-α)) (mul : ∀ (α β : { x : E // x solvableByRad F E }), P αP βP (α * β)) (inv : ∀ (α : { x : E // x solvableByRad F E }), P αP α⁻¹) (rad : ∀ (α : { x : E // x solvableByRad F E }) (n : ), n 0P (α ^ n)P α) (α : { x : E // x solvableByRad F E }) :
      P α
      theorem solvableByRad.isIntegral {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] (α : { x : E // x solvableByRad F E }) :
      def solvableByRad.P {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] (α : { x : E // x solvableByRad F E }) :

      The statement to be proved inductively

      Equations
      Instances For
        theorem solvableByRad.induction3 {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] {α : { x : E // x solvableByRad F E }} {n : } (hn : n 0) (hα : solvableByRad.P (α ^ n)) :

        An auxiliary induction lemma, which is generalized by solvableByRad.isSolvable.

        theorem solvableByRad.induction2 {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] {α : { x : E // x solvableByRad F E }} {β : { x : E // x solvableByRad F E }} {γ : { x : E // x solvableByRad F E }} (hγ : γ Fα, β) (hα : solvableByRad.P α) (hβ : solvableByRad.P β) :

        An auxiliary induction lemma, which is generalized by solvableByRad.isSolvable.

        theorem solvableByRad.induction1 {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] {α : { x : E // x solvableByRad F E }} {β : { x : E // x solvableByRad F E }} (hβ : β Fα) (hα : solvableByRad.P α) :

        An auxiliary induction lemma, which is generalized by solvableByRad.isSolvable.

        theorem solvableByRad.isSolvable {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] (α : { x : E // x solvableByRad F E }) :
        IsSolvable (minpoly F α).Gal
        theorem solvableByRad.isSolvable' {F : Type u_1} [Field F] {E : Type u_2} [Field E] [Algebra F E] {α : E} {q : Polynomial F} (q_irred : Irreducible q) (q_aeval : (Polynomial.aeval α) q = 0) (hα : IsSolvableByRad F α) :

        Abel-Ruffini Theorem (one direction): An irreducible polynomial with an IsSolvableByRad root has solvable Galois group