--- Título: La composición de funciones inyectivas es inyectiva Autor: José A. Alonso --- Demostrar con Lean4 que la composición de funciones inyectivas es inyectiva. Para ello, completar la siguiente teoría de Lean4:
import Mathlib.Tactic

open Function

variable {α : Type _} {β : Type _} {γ : Type _}
variable {f : α → β} {g : β → γ}

example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by sorry
Demostraciones en lenguaje natural (LN) [mathjax] 1ª demostración en LN Tenemos que demostrar que \\[ (∀ x, y) [(g ∘ f)(x) = (g ∘ f)(y) → x = y] \\] Sean \\(x, y\\) tales que \\[ (g ∘ f)(x) = (g ∘ f)(y) \\] Entonces, por la definición de la composición, \\[ g(f(x)) = g(f(y)) \\] y, ser \\(g\\) inyectiva, \\[ f(x) = f(y) \\] y, ser \\(f\\) inyectiva, \\[ x = y \\] 2ª demostración en LN Tenemos que demostrar que \\[ (∀ x, y) [(g ∘ f)(x) = (g ∘ f)(y) → x = y] \\] Sean \\(x, y\\) tales que \\[ (g ∘ f)(x) = (g ∘ f)(y) \\tag{1} \\] y tenemos que demostrar que \\[ x = y \\tag{2} \\] El objetivo (2), usando que \\(f\\) es inyectiva, se reduce a \\[ f(x) = f(y) \\] que, usando que \\(g\\) es inyectiva, se reduce a \\[ g(f(x)) = g(f(y)) \\] que, por la definición de la composición, coincide con (1). Demostraciones con Lean4
import Mathlib.Tactic

open Function

variable {α : Type _} {β : Type _} {γ : Type _}
variable {f : α → β} {g : β → γ}

-- 1ª demostración (basada en la 1ª en LN)
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by
  intro (x : α) (y : α) (h1: (g ∘ f) x = (g ∘ f) y)
  have h2: g (f x) = g (f y) := h1
  have h3: f x = f y := hg h2
  show x = y
  exact hf h3

-- 2ª demostración
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by
  intro (x : α) (y : α) (h1: (g ∘ f) x = (g ∘ f) y)
  have h2: f x = f y := hg h1
  show x = y
  exact hf h2

-- 3ª demostración
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by
  intro x y h
  exact hf (hg h)

-- 4ª demostración
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
fun _ _ h ↦ hf (hg h)

-- 5ª demostración (basada en la 2ª en LN)
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by
  intros x y h
  -- x y : α
  -- h : (g ∘ f) x = (g ∘ f) y
  apply hf
  -- ⊢ f x = f y
  apply hg
  -- ⊢ g (f x) = g (f y)
  apply h

-- 6ª demostración
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
-- by exact?
Injective.comp hg hf

-- 7ª demostración
example
  (hg : Injective g)
  (hf : Injective f) :
  Injective (g ∘ f) :=
by tauto

-- Lemas usados
-- ============

-- #check (Injective.comp : Injective g → Injective f → Injective (g ∘ f))
Demostraciones interactivas Se puede interactuar con las demostraciones anteriores en Lean 4 Web. Referencias