Step | Hyp | Ref | Expression |
1 |
|
eqidd |
_1 = n -> z = z |
2 |
|
eqsidd |
_1 = n -> S == S |
3 |
|
id |
_1 = n -> _1 = n |
4 |
1, 2, 3 |
recnauxeqd |
_1 = n -> recnaux z S _1 = recnaux z S n |
5 |
4 |
fsteqd |
_1 = n -> fst (recnaux z S _1) = fst (recnaux z S n) |
6 |
5, 3 |
eqeqd |
_1 = n -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S n) = n) |
7 |
|
eqidd |
_1 = 0 -> z = z |
8 |
|
eqsidd |
_1 = 0 -> S == S |
9 |
|
id |
_1 = 0 -> _1 = 0 |
10 |
7, 8, 9 |
recnauxeqd |
_1 = 0 -> recnaux z S _1 = recnaux z S 0 |
11 |
10 |
fsteqd |
_1 = 0 -> fst (recnaux z S _1) = fst (recnaux z S 0) |
12 |
11, 9 |
eqeqd |
_1 = 0 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S 0) = 0) |
13 |
|
eqidd |
_1 = a1 -> z = z |
14 |
|
eqsidd |
_1 = a1 -> S == S |
15 |
|
id |
_1 = a1 -> _1 = a1 |
16 |
13, 14, 15 |
recnauxeqd |
_1 = a1 -> recnaux z S _1 = recnaux z S a1 |
17 |
16 |
fsteqd |
_1 = a1 -> fst (recnaux z S _1) = fst (recnaux z S a1) |
18 |
17, 15 |
eqeqd |
_1 = a1 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S a1) = a1) |
19 |
|
eqidd |
_1 = suc a1 -> z = z |
20 |
|
eqsidd |
_1 = suc a1 -> S == S |
21 |
|
id |
_1 = suc a1 -> _1 = suc a1 |
22 |
19, 20, 21 |
recnauxeqd |
_1 = suc a1 -> recnaux z S _1 = recnaux z S (suc a1) |
23 |
22 |
fsteqd |
_1 = suc a1 -> fst (recnaux z S _1) = fst (recnaux z S (suc a1)) |
24 |
23, 21 |
eqeqd |
_1 = suc a1 -> (fst (recnaux z S _1) = _1 <-> fst (recnaux z S (suc a1)) = suc a1) |
25 |
|
eqtr |
fst (recnaux z S 0) = fst (0, z) -> fst (0, z) = 0 -> fst (recnaux z S 0) = 0 |
26 |
|
fsteq |
recnaux z S 0 = 0, z -> fst (recnaux z S 0) = fst (0, z) |
27 |
|
recnaux0 |
recnaux z S 0 = 0, z |
28 |
26, 27 |
ax_mp |
fst (recnaux z S 0) = fst (0, z) |
29 |
25, 28 |
ax_mp |
fst (0, z) = 0 -> fst (recnaux z S 0) = 0 |
30 |
|
fstpr |
fst (0, z) = 0 |
31 |
29, 30 |
ax_mp |
fst (recnaux z S 0) = 0 |
32 |
|
eqtr |
fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) ->
fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) ->
fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) |
33 |
|
fsteq |
recnaux z S (suc a1) = suc (fst (recnaux z S a1)), S @ recnaux z S a1 -> fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) |
34 |
|
recnauxS2 |
recnaux z S (suc a1) = suc (fst (recnaux z S a1)), S @ recnaux z S a1 |
35 |
33, 34 |
ax_mp |
fst (recnaux z S (suc a1)) = fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) |
36 |
32, 35 |
ax_mp |
fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) -> fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) |
37 |
|
fstpr |
fst (suc (fst (recnaux z S a1)), S @ recnaux z S a1) = suc (fst (recnaux z S a1)) |
38 |
36, 37 |
ax_mp |
fst (recnaux z S (suc a1)) = suc (fst (recnaux z S a1)) |
39 |
|
suceq |
fst (recnaux z S a1) = a1 -> suc (fst (recnaux z S a1)) = suc a1 |
40 |
38, 39 |
syl5eq |
fst (recnaux z S a1) = a1 -> fst (recnaux z S (suc a1)) = suc a1 |
41 |
6, 12, 18, 24, 31, 40 |
ind |
fst (recnaux z S n) = n |