Step | Hyp | Ref | Expression |
1 |
|
lteq1 |
a3 = i -> (a3 < len l1 <-> i < len l1) |
2 |
|
ntheq1 |
a3 = i -> nth a3 (l1 ++ l2) = nth i (l1 ++ l2) |
3 |
|
ntheq1 |
a3 = i -> nth a3 l1 = nth i l1 |
4 |
2, 3 |
eqeqd |
a3 = i -> (nth a3 (l1 ++ l2) = nth a3 l1 <-> nth i (l1 ++ l2) = nth i l1) |
5 |
1, 4 |
imeqd |
a3 = i -> (a3 < len l1 -> nth a3 (l1 ++ l2) = nth a3 l1 <-> i < len l1 -> nth i (l1 ++ l2) = nth i l1) |
6 |
5 |
eale |
A. a3 (a3 < len l1 -> nth a3 (l1 ++ l2) = nth a3 l1) -> i < len l1 -> nth i (l1 ++ l2) = nth i l1 |
7 |
|
eqidd |
_1 = l1 -> a3 = a3 |
8 |
|
id |
_1 = l1 -> _1 = l1 |
9 |
8 |
leneqd |
_1 = l1 -> len _1 = len l1 |
10 |
7, 9 |
lteqd |
_1 = l1 -> (a3 < len _1 <-> a3 < len l1) |
11 |
|
eqidd |
_1 = l1 -> l2 = l2 |
12 |
8, 11 |
appendeqd |
_1 = l1 -> _1 ++ l2 = l1 ++ l2 |
13 |
7, 12 |
ntheqd |
_1 = l1 -> nth a3 (_1 ++ l2) = nth a3 (l1 ++ l2) |
14 |
7, 8 |
ntheqd |
_1 = l1 -> nth a3 _1 = nth a3 l1 |
15 |
13, 14 |
eqeqd |
_1 = l1 -> (nth a3 (_1 ++ l2) = nth a3 _1 <-> nth a3 (l1 ++ l2) = nth a3 l1) |
16 |
10, 15 |
imeqd |
_1 = l1 -> (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1 <-> a3 < len l1 -> nth a3 (l1 ++ l2) = nth a3 l1) |
17 |
16 |
aleqd |
_1 = l1 -> (A. a3 (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1) <-> A. a3 (a3 < len l1 -> nth a3 (l1 ++ l2) = nth a3 l1)) |
18 |
|
eqidd |
_1 = 0 -> a3 = a3 |
19 |
|
id |
_1 = 0 -> _1 = 0 |
20 |
19 |
leneqd |
_1 = 0 -> len _1 = len 0 |
21 |
18, 20 |
lteqd |
_1 = 0 -> (a3 < len _1 <-> a3 < len 0) |
22 |
|
eqidd |
_1 = 0 -> l2 = l2 |
23 |
19, 22 |
appendeqd |
_1 = 0 -> _1 ++ l2 = 0 ++ l2 |
24 |
18, 23 |
ntheqd |
_1 = 0 -> nth a3 (_1 ++ l2) = nth a3 (0 ++ l2) |
25 |
18, 19 |
ntheqd |
_1 = 0 -> nth a3 _1 = nth a3 0 |
26 |
24, 25 |
eqeqd |
_1 = 0 -> (nth a3 (_1 ++ l2) = nth a3 _1 <-> nth a3 (0 ++ l2) = nth a3 0) |
27 |
21, 26 |
imeqd |
_1 = 0 -> (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1 <-> a3 < len 0 -> nth a3 (0 ++ l2) = nth a3 0) |
28 |
27 |
aleqd |
_1 = 0 -> (A. a3 (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1) <-> A. a3 (a3 < len 0 -> nth a3 (0 ++ l2) = nth a3 0)) |
29 |
|
eqidd |
_1 = a2 -> a3 = a3 |
30 |
|
id |
_1 = a2 -> _1 = a2 |
31 |
30 |
leneqd |
_1 = a2 -> len _1 = len a2 |
32 |
29, 31 |
lteqd |
_1 = a2 -> (a3 < len _1 <-> a3 < len a2) |
33 |
|
eqidd |
_1 = a2 -> l2 = l2 |
34 |
30, 33 |
appendeqd |
_1 = a2 -> _1 ++ l2 = a2 ++ l2 |
35 |
29, 34 |
ntheqd |
_1 = a2 -> nth a3 (_1 ++ l2) = nth a3 (a2 ++ l2) |
36 |
29, 30 |
ntheqd |
_1 = a2 -> nth a3 _1 = nth a3 a2 |
37 |
35, 36 |
eqeqd |
_1 = a2 -> (nth a3 (_1 ++ l2) = nth a3 _1 <-> nth a3 (a2 ++ l2) = nth a3 a2) |
38 |
32, 37 |
imeqd |
_1 = a2 -> (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1 <-> a3 < len a2 -> nth a3 (a2 ++ l2) = nth a3 a2) |
39 |
38 |
aleqd |
_1 = a2 -> (A. a3 (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1) <-> A. a3 (a3 < len a2 -> nth a3 (a2 ++ l2) = nth a3 a2)) |
40 |
|
eqidd |
_1 = a1 : a2 -> a3 = a3 |
41 |
|
id |
_1 = a1 : a2 -> _1 = a1 : a2 |
42 |
41 |
leneqd |
_1 = a1 : a2 -> len _1 = len (a1 : a2) |
43 |
40, 42 |
lteqd |
_1 = a1 : a2 -> (a3 < len _1 <-> a3 < len (a1 : a2)) |
44 |
|
eqidd |
_1 = a1 : a2 -> l2 = l2 |
45 |
41, 44 |
appendeqd |
_1 = a1 : a2 -> _1 ++ l2 = a1 : a2 ++ l2 |
46 |
40, 45 |
ntheqd |
_1 = a1 : a2 -> nth a3 (_1 ++ l2) = nth a3 (a1 : a2 ++ l2) |
47 |
40, 41 |
ntheqd |
_1 = a1 : a2 -> nth a3 _1 = nth a3 (a1 : a2) |
48 |
46, 47 |
eqeqd |
_1 = a1 : a2 -> (nth a3 (_1 ++ l2) = nth a3 _1 <-> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
49 |
43, 48 |
imeqd |
_1 = a1 : a2 -> (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1 <-> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
50 |
49 |
aleqd |
_1 = a1 : a2 -> (A. a3 (a3 < len _1 -> nth a3 (_1 ++ l2) = nth a3 _1) <-> A. a3 (a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2))) |
51 |
|
lteq2 |
len 0 = 0 -> (a3 < len 0 <-> a3 < 0) |
52 |
|
len0 |
len 0 = 0 |
53 |
51, 52 |
ax_mp |
a3 < len 0 <-> a3 < 0 |
54 |
|
absurd |
~a3 < 0 -> a3 < 0 -> nth a3 (0 ++ l2) = nth a3 0 |
55 |
|
lt02 |
~a3 < 0 |
56 |
54, 55 |
ax_mp |
a3 < 0 -> nth a3 (0 ++ l2) = nth a3 0 |
57 |
53, 56 |
sylbi |
a3 < len 0 -> nth a3 (0 ++ l2) = nth a3 0 |
58 |
57 |
ax_gen |
A. a3 (a3 < len 0 -> nth a3 (0 ++ l2) = nth a3 0) |
59 |
|
lteq1 |
a3 = a4 -> (a3 < len a2 <-> a4 < len a2) |
60 |
|
ntheq1 |
a3 = a4 -> nth a3 (a2 ++ l2) = nth a4 (a2 ++ l2) |
61 |
|
ntheq1 |
a3 = a4 -> nth a3 a2 = nth a4 a2 |
62 |
60, 61 |
eqeqd |
a3 = a4 -> (nth a3 (a2 ++ l2) = nth a3 a2 <-> nth a4 (a2 ++ l2) = nth a4 a2) |
63 |
59, 62 |
imeqd |
a3 = a4 -> (a3 < len a2 -> nth a3 (a2 ++ l2) = nth a3 a2 <-> a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) |
64 |
63 |
cbval |
A. a3 (a3 < len a2 -> nth a3 (a2 ++ l2) = nth a3 a2) <-> A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) |
65 |
|
ntheq2 |
a1 : a2 ++ l2 = a1 : (a2 ++ l2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : (a2 ++ l2)) |
66 |
|
appendS |
a1 : a2 ++ l2 = a1 : (a2 ++ l2) |
67 |
65, 66 |
ax_mp |
nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : (a2 ++ l2)) |
68 |
|
ntheq1 |
a3 = 0 -> nth a3 (a1 : (a2 ++ l2)) = nth 0 (a1 : (a2 ++ l2)) |
69 |
|
eqtr4 |
nth 0 (a1 : a2) = suc a1 -> nth 0 (a1 : (a2 ++ l2)) = suc a1 -> nth 0 (a1 : a2) = nth 0 (a1 : (a2 ++ l2)) |
70 |
|
nthZ |
nth 0 (a1 : a2) = suc a1 |
71 |
69, 70 |
ax_mp |
nth 0 (a1 : (a2 ++ l2)) = suc a1 -> nth 0 (a1 : a2) = nth 0 (a1 : (a2 ++ l2)) |
72 |
|
nthZ |
nth 0 (a1 : (a2 ++ l2)) = suc a1 |
73 |
71, 72 |
ax_mp |
nth 0 (a1 : a2) = nth 0 (a1 : (a2 ++ l2)) |
74 |
|
ntheq1 |
a3 = 0 -> nth a3 (a1 : a2) = nth 0 (a1 : a2) |
75 |
73, 74 |
syl6eq |
a3 = 0 -> nth a3 (a1 : a2) = nth 0 (a1 : (a2 ++ l2)) |
76 |
68, 75 |
eqtr4d |
a3 = 0 -> nth a3 (a1 : (a2 ++ l2)) = nth a3 (a1 : a2) |
77 |
67, 76 |
syl5eq |
a3 = 0 -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
78 |
77 |
a1d |
a3 = 0 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
79 |
78 |
a1i |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> a3 = 0 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
80 |
|
exsuc |
a3 != 0 <-> E. a4 a3 = suc a4 |
81 |
80 |
conv ne |
~a3 = 0 <-> E. a4 a3 = suc a4 |
82 |
|
eexb |
E. a4 a3 = suc a4 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) <->
A. a4 (a3 = suc a4 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
83 |
|
lteq2 |
len (a1 : a2) = suc (len a2) -> (a3 < len (a1 : a2) <-> a3 < suc (len a2)) |
84 |
|
lenS |
len (a1 : a2) = suc (len a2) |
85 |
83, 84 |
ax_mp |
a3 < len (a1 : a2) <-> a3 < suc (len a2) |
86 |
|
ltsuc |
a4 < len a2 <-> suc a4 < suc (len a2) |
87 |
|
lteq1 |
a3 = suc a4 -> (a3 < suc (len a2) <-> suc a4 < suc (len a2)) |
88 |
86, 87 |
syl6bbr |
a3 = suc a4 -> (a3 < suc (len a2) <-> a4 < len a2) |
89 |
85, 88 |
syl5bb |
a3 = suc a4 -> (a3 < len (a1 : a2) <-> a4 < len a2) |
90 |
|
nthS |
nth (suc a4) (a1 : (a2 ++ l2)) = nth a4 (a2 ++ l2) |
91 |
|
ntheq1 |
a3 = suc a4 -> nth a3 (a1 : (a2 ++ l2)) = nth (suc a4) (a1 : (a2 ++ l2)) |
92 |
90, 91 |
syl6eq |
a3 = suc a4 -> nth a3 (a1 : (a2 ++ l2)) = nth a4 (a2 ++ l2) |
93 |
67, 92 |
syl5eq |
a3 = suc a4 -> nth a3 (a1 : a2 ++ l2) = nth a4 (a2 ++ l2) |
94 |
|
nthS |
nth (suc a4) (a1 : a2) = nth a4 a2 |
95 |
|
ntheq1 |
a3 = suc a4 -> nth a3 (a1 : a2) = nth (suc a4) (a1 : a2) |
96 |
94, 95 |
syl6eq |
a3 = suc a4 -> nth a3 (a1 : a2) = nth a4 a2 |
97 |
93, 96 |
eqeqd |
a3 = suc a4 -> (nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) <-> nth a4 (a2 ++ l2) = nth a4 a2) |
98 |
89, 97 |
imeqd |
a3 = suc a4 -> (a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) <-> a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) |
99 |
98 |
bi2d |
a3 = suc a4 -> (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
100 |
99 |
com12 |
(a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> a3 = suc a4 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
101 |
100 |
alimi |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> A. a4 (a3 = suc a4 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
102 |
82, 101 |
sylibr |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> E. a4 a3 = suc a4 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
103 |
81, 102 |
syl5bi |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> ~a3 = 0 -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
104 |
79, 103 |
casesd |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2) |
105 |
104 |
iald |
A. a4 (a4 < len a2 -> nth a4 (a2 ++ l2) = nth a4 a2) -> A. a3 (a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
106 |
64, 105 |
sylbi |
A. a3 (a3 < len a2 -> nth a3 (a2 ++ l2) = nth a3 a2) -> A. a3 (a3 < len (a1 : a2) -> nth a3 (a1 : a2 ++ l2) = nth a3 (a1 : a2)) |
107 |
17, 28, 39, 50, 58, 106 |
listind |
A. a3 (a3 < len l1 -> nth a3 (l1 ++ l2) = nth a3 l1) |
108 |
6, 107 |
ax_mp |
i < len l1 -> nth i (l1 ++ l2) = nth i l1 |