Documentation

Mathlib.Data.Prod.Basic

Extra facts about Prod #

This file proves various simple lemmas about Prod. It also defines better delaborators for product projections.

@[deprecated Prod.map_apply (since := "2024-05-08")]
theorem Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} (f : αβ) (g : γδ) (x : α) (y : γ) :
Prod.map f g (x, y) = (f x, g y)

Alias of Prod.map_apply.

theorem Prod.swap_eq_iff_eq_swap {α : Type u_1} {β : Type u_2} {x : α × β} {y : β × α} :
x.swap = y x = y.swap
def Prod.mk.injArrow {α : Type u_1} {β : Type u_2} {x₁ : α} {y₁ : β} {x₂ : α} {y₂ : β} :
(x₁, y₁) = (x₂, y₂)P : Sort u_5⦄ → (x₁ = x₂y₁ = y₂P)P
Equations
Instances For
    @[simp]
    theorem Prod.mk.eta {α : Type u_1} {β : Type u_2} {p : α × β} :
    (p.1, p.2) = p
    theorem Prod.forall' {α : Type u_1} {β : Type u_2} {p : αβProp} :
    (∀ (x : α × β), p x.1 x.2) ∀ (a : α) (b : β), p a b
    theorem Prod.exists' {α : Type u_1} {β : Type u_2} {p : αβProp} :
    (∃ (x : α × β), p x.1 x.2) ∃ (a : α), ∃ (b : β), p a b
    @[simp]
    theorem Prod.snd_comp_mk {α : Type u_1} {β : Type u_2} (x : α) :
    @[simp]
    theorem Prod.fst_comp_mk {α : Type u_1} {β : Type u_2} (x : α) :
    @[deprecated Prod.map_apply (since := "2024-10-17")]
    theorem Prod.map_mk {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} (f : αβ) (g : γδ) (x : α) (y : γ) :
    Prod.map f g (x, y) = (f x, g y)

    Alias of Prod.map_apply.

    theorem Prod.map_apply' {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} (f : αγ) (g : βδ) (p : α × β) :
    Prod.map f g p = (f p.1, g p.2)
    theorem Prod.map_fst' {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} (f : αγ) (g : βδ) :
    theorem Prod.map_snd' {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} (f : αγ) (g : βδ) :
    theorem Prod.mk.inj_iff {α : Type u_1} {β : Type u_2} {a₁ a₂ : α} {b₁ b₂ : β} :
    (a₁, b₁) = (a₂, b₂) a₁ = a₂ b₁ = b₂
    theorem Prod.mk.inj_left {α : Type u_5} {β : Type u_6} (a : α) :
    theorem Prod.mk.inj_right {α : Type u_5} {β : Type u_6} (b : β) :
    Function.Injective fun (a : α) => (a, b)
    theorem Prod.mk_inj_left {α : Type u_1} {β : Type u_2} {a : α} {b₁ b₂ : β} :
    (a, b₁) = (a, b₂) b₁ = b₂
    theorem Prod.mk_inj_right {α : Type u_1} {β : Type u_2} {a₁ a₂ : α} {b : β} :
    (a₁, b) = (a₂, b) a₁ = a₂
    theorem Prod.map_def {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} :
    Prod.map f g = fun (p : α × β) => (f p.1, g p.2)
    theorem Prod.id_prod {α : Type u_1} {β : Type u_2} :
    (fun (p : α × β) => (p.1, p.2)) = id
    @[simp]
    theorem Prod.map_iterate {α : Type u_1} {β : Type u_2} (f : αα) (g : ββ) (n : ) :
    @[deprecated Prod.map_iterate (since := "2024-07-03")]
    theorem Prod.iterate_prod_map {α : Type u_1} {β : Type u_2} (f : αα) (g : ββ) (n : ) :

    Alias of Prod.map_iterate.

    theorem Function.Semiconj.swap_map {α : Type u_1} {β : Type u_2} (f : αα) (g : ββ) :
    theorem Prod.eq_iff_fst_eq_snd_eq {α : Type u_1} {β : Type u_2} {p q : α × β} :
    p = q p.1 = q.1 p.2 = q.2
    theorem Prod.fst_eq_iff {α : Type u_1} {β : Type u_2} {p : α × β} {x : α} :
    p.1 = x p = (x, p.2)
    theorem Prod.snd_eq_iff {α : Type u_1} {β : Type u_2} {p : α × β} {x : β} :
    p.2 = x p = (p.1, x)
    theorem Prod.lex_iff {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} {x y : α × β} :
    Prod.Lex r s x y r x.1 y.1 x.1 = y.1 s x.2 y.2
    instance Prod.Lex.decidable {α : Type u_1} {β : Type u_2} [DecidableEq α] (r : ααProp) (s : ββProp) [DecidableRel r] [DecidableRel s] :
    Equations
    theorem Prod.Lex.refl_left {α : Type u_1} {β : Type u_2} (r : ααProp) (s : ββProp) [IsRefl α r] (x : α × β) :
    Prod.Lex r s x x
    instance Prod.instIsReflLex {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsRefl α r] :
    IsRefl (α × β) (Prod.Lex r s)
    theorem Prod.Lex.refl_right {α : Type u_1} {β : Type u_2} (r : ααProp) (s : ββProp) [IsRefl β s] (x : α × β) :
    Prod.Lex r s x x
    instance Prod.instIsReflLex_1 {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsRefl β s] :
    IsRefl (α × β) (Prod.Lex r s)
    instance Prod.isIrrefl {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsIrrefl α r] [IsIrrefl β s] :
    IsIrrefl (α × β) (Prod.Lex r s)
    theorem Prod.Lex.trans {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsTrans α r] [IsTrans β s] {x y z : α × β} :
    Prod.Lex r s x yProd.Lex r s y zProd.Lex r s x z
    instance Prod.instIsTransLex {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsTrans α r] [IsTrans β s] :
    IsTrans (α × β) (Prod.Lex r s)
    instance Prod.instIsAntisymmLexOfIsStrictOrder {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsStrictOrder α r] [IsAntisymm β s] :
    IsAntisymm (α × β) (Prod.Lex r s)
    instance Prod.isTotal_left {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsTotal α r] :
    IsTotal (α × β) (Prod.Lex r s)
    instance Prod.isTotal_right {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsTrichotomous α r] [IsTotal β s] :
    IsTotal (α × β) (Prod.Lex r s)
    instance Prod.IsTrichotomous {α : Type u_1} {β : Type u_2} {r : ααProp} {s : ββProp} [IsTrichotomous α r] [IsTrichotomous β s] :
    IsTrichotomous (α × β) (Prod.Lex r s)
    theorem Function.Injective.prodMap {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Injective f) (hg : Function.Injective g) :
    theorem Function.Surjective.prodMap {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Surjective f) (hg : Function.Surjective g) :
    theorem Function.Bijective.prodMap {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Bijective f) (hg : Function.Bijective g) :
    theorem Function.LeftInverse.prodMap {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} (hf : Function.LeftInverse f₁ f₂) (hg : Function.LeftInverse g₁ g₂) :
    Function.LeftInverse (Prod.map f₁ g₁) (Prod.map f₂ g₂)
    theorem Function.RightInverse.prodMap {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} :
    Function.RightInverse f₁ f₂Function.RightInverse g₁ g₂Function.RightInverse (Prod.map f₁ g₁) (Prod.map f₂ g₂)
    theorem Function.Involutive.prodMap {α : Type u_1} {β : Type u_2} {f : αα} {g : ββ} :
    @[deprecated Function.Injective.prodMap (since := "2024-05-08")]
    theorem Function.Injective.Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Injective f) (hg : Function.Injective g) :

    Alias of Function.Injective.prodMap.

    @[deprecated Function.Surjective.prodMap (since := "2024-05-08")]
    theorem Function.Surjective.Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Surjective f) (hg : Function.Surjective g) :

    Alias of Function.Surjective.prodMap.

    @[deprecated Function.Bijective.prodMap (since := "2024-05-08")]
    theorem Function.Bijective.Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f : αγ} {g : βδ} (hf : Function.Bijective f) (hg : Function.Bijective g) :

    Alias of Function.Bijective.prodMap.

    @[deprecated Function.LeftInverse.prodMap (since := "2024-05-08")]
    theorem Function.LeftInverse.Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} (hf : Function.LeftInverse f₁ f₂) (hg : Function.LeftInverse g₁ g₂) :
    Function.LeftInverse (Prod.map f₁ g₁) (Prod.map f₂ g₂)

    Alias of Function.LeftInverse.prodMap.

    @[deprecated Function.RightInverse.prodMap (since := "2024-05-08")]
    theorem Function.RightInverse.Prod_map {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} :
    Function.RightInverse f₁ f₂Function.RightInverse g₁ g₂Function.RightInverse (Prod.map f₁ g₁) (Prod.map f₂ g₂)

    Alias of Function.RightInverse.prodMap.

    @[deprecated Function.Involutive.prodMap (since := "2024-05-08")]
    theorem Function.Involutive.Prod_map {α : Type u_1} {β : Type u_2} {f : αα} {g : ββ} :

    Alias of Function.Involutive.prodMap.

    @[simp]
    theorem Prod.map_injective {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} [Nonempty α] [Nonempty β] {f : αγ} {g : βδ} :
    @[simp]
    theorem Prod.map_surjective {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} [Nonempty γ] [Nonempty δ] {f : αγ} {g : βδ} :
    @[simp]
    theorem Prod.map_bijective {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} [Nonempty α] [Nonempty β] {f : αγ} {g : βδ} :
    @[simp]
    theorem Prod.map_leftInverse {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} [Nonempty β] [Nonempty δ] {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} :
    @[simp]
    theorem Prod.map_rightInverse {α : Type u_1} {β : Type u_2} {γ : Type u_3} {δ : Type u_4} [Nonempty α] [Nonempty γ] {f₁ : αβ} {g₁ : γδ} {f₂ : βα} {g₂ : δγ} :
    @[simp]
    theorem Prod.map_involutive {α : Type u_1} {β : Type u_2} [Nonempty α] [Nonempty β] {f : αα} {g : ββ} :

    When true, then Prod.fst x and Prod.snd x pretty print as x.1 and x.2 rather than as x.fst and x.snd.

    Tell whether pretty-printing should use numeric projection notations .1 and .2 for Prod.fst and Prod.snd.

    Equations
    Instances For

      Delaborator for Prod.fst x as x.1.

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For

        Delaborator for Prod.snd x as x.2.

        Equations
        • One or more equations did not get rendered due to their size.
        Instances For