-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathConmutatividad_de_la_conjuncion.lean
97 lines (74 loc) · 1.83 KB
/
Conmutatividad_de_la_conjuncion.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
-- Conmutatividad_de_la_conjuncion.lean
-- Conmutatividad de la conjunción
-- José A. Alonso Jiménez
-- Sevilla, 23 de agosto de 2020
-- ---------------------------------------------------------------------
-- ---------------------------------------------------------------------
-- Ejercicio. Demostrar que
-- P ∧ Q → Q ∧ P
-- ----------------------------------------------------------------------
import tactic
variables (P Q R : Prop)
-- 1ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
begin
intro h,
cases h with hP hQ,
split,
{ exact hQ },
{ exact hP },
end
-- 2ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
begin
rintro ⟨hP, hQ⟩,
exact ⟨hQ, hP⟩,
end
-- 3ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
λ ⟨hP, hQ⟩, ⟨hQ, hP⟩
-- 4ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
and.comm.mp
-- Comentarios:
-- 1. Se usa el lema
-- + and.comm : P ∧ Q ↔ Q ∧ P
-- 2. Si h es una equivalencia (P ↔ Q, entonces h.mp es (P → Q).
-- 3. Si h es una equivalencia (P ↔ Q, entonces h.mpr es (Q → P).
-- 5ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
begin
assume h : P ∧ Q,
have hP : P := h.left,
have hQ : Q := h.right,
show Q ∧ P, from ⟨hQ, hP⟩,
end
-- 6ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
begin
assume h : P ∧ Q,
show Q ∧ P, from ⟨h.right, h.left⟩,
end
example : P ∧ Q → Q ∧ P :=
begin
assume h : P ∧ Q,
show Q ∧ P, from ⟨h.2, h.1⟩,
end
-- 7ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
λ h, ⟨h.2, h.1⟩
-- 8ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
by tauto
-- 9ª demostración
-- ===============
example : P ∧ Q → Q ∧ P :=
by finish