-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEncadenamiento_de_ecuaciones.lean
103 lines (89 loc) · 2.51 KB
/
Encadenamiento_de_ecuaciones.lean
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
-- Encadenamiento_de_ecuaciones.lean
-- Encadenamiento de ecuaciones.
-- José A. Alonso Jiménez
-- Sevilla, 12 de agosto de 2020
-- ---------------------------------------------------------------------
-- En esta relación comentan distintas pruebas con Lean de una igualdad
-- con productos de números reales. La primera es por reescritura usando
-- las propiedades asociativa y conmutativa, La segunda es con
-- encadenamiento de ecuaciones. Las restantes son automáticas.
-- ---------------------------------------------------------------------
-- Ejercicio. Sean a, b, c y d números reales. Demostrar que si
-- c = d * a + b
-- b = a + d
-- entonces c = 2 * a * d.
-- ----------------------------------------------------------------------
import data.real.basic
variables (a b c d : ℝ)
-- 1ª demostración (reescribiendo las hipótesis)
-- =============================================
example
(h1 : c = d * a + b)
(h2 : b = a * d)
: c = 2 * a * d :=
begin
rw h2 at h1,
rw mul_comm at h1,
rw ← two_mul (a * d) at h1,
rw ← mul_assoc at h1,
exact h1,
end
-- Prueba:
/-
a b c d : ℝ,
h1 : c = d * a + b,
h2 : b = a * d
⊢ c = 2 * a * d
rw h2 at h1,
h1 : c = d * a + a * d
⊢ c = 2 * a * d
rw mul_comm at h1,
h1 : c = a * d + a * d
⊢ c = 2 * a * d
rw ← two_mul (a * d) at h1,
h1 : c = 2 * (a * d)
⊢ c = 2 * a * d
rw ← mul_assoc at h1,
h1 : c = 2 * a * d
⊢ c = 2 * a * d
exact h1,
no goals
-/
-- Comentarios:
-- + Se han usado los siguientes lemas
-- + mul_comm : ∀ (a b : ℝ), a * b = b * a
-- + mul_assoc : ∀ (a b c : ℝ), a * b * c = a * (b * c)
-- + two_mul : 2 * a = a + a
-- 2ª demostración (encadenamiento de ecuaciones)
-- ==============================================
example
(h1 : c = d * a + b)
(h2 : b = a * d)
: c = 2 * a * d :=
begin
calc
c = d * a + b : by exact h1
... = d * a + a * d : by rw h2
... = a * d + a * d : by rw mul_comm
... = 2 * (a * d) : by rw two_mul (a * d)
... = 2 * a * d : by rw mul_assoc,
end
-- 3ª demostración (encadenamiento de ecuaciones)
-- ==============================================
example
(h1 : c = d * a + b)
(h2 : b = a * d)
: c = 2 * a * d :=
begin
calc
c = d * a + b : by exact h1
... = d * a + a * d : by rw h2
... = 2 * a * d : by ring,
end
-- 4ª demostración (automática con linarith)
-- =========================================
example
(h1 : c = d * a + b)
(h2 : b = a * d)
: c = 2 * a * d :=
by linarith