-- Ig_opuesto_si_suma_ig_cero.lean -- Si R es un anillo y a, b ∈ R tales que a+b=0, entonces a=-b -- José A. Alonso Jiménez <https://jaalonso.github.io> -- Sevilla, 8-agosto-2023 -- --------------------------------------------------------------------- -- --------------------------------------------------------------------- -- Demostrar que si R es un anillo y a, b ∈ R tales que -- a + b = 0 -- entonces -- a = -b -- ---------------------------------------------------------------------- -- Demostraciones en lenguaje natural (LN) -- ======================================= -- 1ª demostración en LN -- --------------------- -- Por la siguiente cadena de igualdades -- a = (a + b) + -b [por la concelativa] -- = 0 + -b [por la hipótesis] -- = -b [por la suma con cero] -- 2ª demostración en LN -- --------------------- -- Sumando -a a ambos lados de la hipótesis, se tiene -- (a + b) + -b = 0 + -b -- El término de la izquierda se reduce a a (por la cancelativa) y el de -- la derecha a -b (por la suma con cero). Por tanto, se tiene -- a = -b -- Demostraciones con Lean4 -- ======================== import Mathlib.Algebra.Ring.Defs import Mathlib.Tactic variable {R : Type _} [Ring R] variable {a b : R} -- 1ª demostración (basada en la 1ª en LN) example (h : a + b = 0) : a = -b := calc a = (a + b) + -b := by rw [add_neg_cancel_right] _ = 0 + -b := by rw [h] _ = -b := by rw [zero_add] -- 2ª demostración (basada en la 1ª en LN) example (h : a + b = 0) : a = -b := calc a = (a + b) + -b := by simp _ = 0 + -b := by rw [h] _ = -b := by simp -- 3ª demostración (basada en la 1ª en LN) example (h : a + b = 0) : a = -b := by have h1 : (a + b) + -b = 0 + -b := by rw [h] have h2 : (a + b) + -b = a := add_neg_cancel_right a b have h3 : 0 + -b = -b := zero_add (-b) rwa [h2, h3] at h1 -- 4ª demostración example (h : a + b = 0) : a = -b := add_eq_zero_iff_eq_neg.mp h -- Lemas usados -- ============ -- #check (add_eq_zero_iff_eq_neg : a + b = 0 ↔ a = -b) -- #check (add_neg_cancel_right a b : (a + b) + -b = a) -- #check (zero_add a : 0 + a = a)