Step | Hyp | Ref
| Expression |
1 | | wim 137 |
. . . 4
⊢ ⇒ :(∗
→ (∗ → ∗)) |
2 | | olc.1 |
. . . . 5
⊢ A:∗ |
3 | | wv 64 |
. . . . 5
⊢ x:∗:∗ |
4 | 1, 2, 3 | wov 72 |
. . . 4
⊢ [A ⇒ x:∗]:∗ |
5 | | olc.2 |
. . . . . 6
⊢ B:∗ |
6 | 1, 5, 3 | wov 72 |
. . . . 5
⊢ [B ⇒ x:∗]:∗ |
7 | 1, 6, 3 | wov 72 |
. . . 4
⊢ [[B ⇒ x:∗] ⇒ x:∗]:∗ |
8 | 1, 4, 7 | wov 72 |
. . 3
⊢ [[A ⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]]:∗ |
9 | | wtru 43 |
. . . 4
⊢
⊤:∗ |
10 | 2, 4 | simpl 22 |
. . . . . . . . 9
⊢ (A, [A ⇒
x:∗])⊧A |
11 | 2, 4 | simpr 23 |
. . . . . . . . 9
⊢ (A, [A ⇒
x:∗])⊧[A ⇒ x:∗] |
12 | 3, 10, 11 | mpd 156 |
. . . . . . . 8
⊢ (A, [A ⇒
x:∗])⊧x:∗ |
13 | 12, 6 | adantr 55 |
. . . . . . 7
⊢ ((A, [A ⇒
x:∗]), [B ⇒ x:∗])⊧x:∗ |
14 | 13 | ex 158 |
. . . . . 6
⊢ (A, [A ⇒
x:∗])⊧[[B ⇒ x:∗] ⇒ x:∗] |
15 | 14 | ex 158 |
. . . . 5
⊢ A⊧[[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] |
16 | 15 | eqtru 86 |
. . . 4
⊢ A⊧[⊤ = [[A ⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]]] |
17 | 9, 16 | eqcomi 79 |
. . 3
⊢ A⊧[[[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] = ⊤] |
18 | 8, 17 | leq 91 |
. 2
⊢ A⊧[λx:∗ [[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] = λx:∗ ⊤] |
19 | | wor 140 |
. . . . 5
⊢ ∨ :(∗ → (∗ →
∗)) |
20 | 19, 2, 5 | wov 72 |
. . . 4
⊢ [A ∨ B]:∗ |
21 | 2, 5 | orval 147 |
. . . 4
⊢
⊤⊧[[A ∨ B] = (∀λx:∗ [[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]])] |
22 | 8 | wl 66 |
. . . . 5
⊢
λx:∗ [[A ⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]]:(∗ →
∗) |
23 | 22 | alval 142 |
. . . 4
⊢
⊤⊧[(∀λx:∗ [[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]]) = [λx:∗ [[A
⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] = λx:∗ ⊤]] |
24 | 20, 21, 23 | eqtri 95 |
. . 3
⊢
⊤⊧[[A ∨ B] =
[λx:∗ [[A ⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] = λx:∗ ⊤]] |
25 | 2, 24 | a1i 28 |
. 2
⊢ A⊧[[A
∨ B] =
[λx:∗ [[A ⇒ x:∗] ⇒ [[B ⇒ x:∗] ⇒ x:∗]] = λx:∗ ⊤]] |
26 | 18, 25 | mpbir 87 |
1
⊢ A⊧[A ∨ B] |