Step | Hyp | Ref | Expression |
1 |
|
id |
_1 = l1 -> _1 = l1 |
2 |
|
eqidd |
_1 = l1 -> l2 = l2 |
3 |
1, 2 |
appendeqd |
_1 = l1 -> _1 ++ l2 = l1 ++ l2 |
4 |
3 |
reveqd |
_1 = l1 -> rev (_1 ++ l2) = rev (l1 ++ l2) |
5 |
|
eqidd |
_1 = l1 -> rev l2 = rev l2 |
6 |
1 |
reveqd |
_1 = l1 -> rev _1 = rev l1 |
7 |
5, 6 |
appendeqd |
_1 = l1 -> rev l2 ++ rev _1 = rev l2 ++ rev l1 |
8 |
4, 7 |
eqeqd |
_1 = l1 -> (rev (_1 ++ l2) = rev l2 ++ rev _1 <-> rev (l1 ++ l2) = rev l2 ++ rev l1) |
9 |
|
id |
_1 = 0 -> _1 = 0 |
10 |
|
eqidd |
_1 = 0 -> l2 = l2 |
11 |
9, 10 |
appendeqd |
_1 = 0 -> _1 ++ l2 = 0 ++ l2 |
12 |
11 |
reveqd |
_1 = 0 -> rev (_1 ++ l2) = rev (0 ++ l2) |
13 |
|
eqidd |
_1 = 0 -> rev l2 = rev l2 |
14 |
9 |
reveqd |
_1 = 0 -> rev _1 = rev 0 |
15 |
13, 14 |
appendeqd |
_1 = 0 -> rev l2 ++ rev _1 = rev l2 ++ rev 0 |
16 |
12, 15 |
eqeqd |
_1 = 0 -> (rev (_1 ++ l2) = rev l2 ++ rev _1 <-> rev (0 ++ l2) = rev l2 ++ rev 0) |
17 |
|
id |
_1 = a2 -> _1 = a2 |
18 |
|
eqidd |
_1 = a2 -> l2 = l2 |
19 |
17, 18 |
appendeqd |
_1 = a2 -> _1 ++ l2 = a2 ++ l2 |
20 |
19 |
reveqd |
_1 = a2 -> rev (_1 ++ l2) = rev (a2 ++ l2) |
21 |
|
eqidd |
_1 = a2 -> rev l2 = rev l2 |
22 |
17 |
reveqd |
_1 = a2 -> rev _1 = rev a2 |
23 |
21, 22 |
appendeqd |
_1 = a2 -> rev l2 ++ rev _1 = rev l2 ++ rev a2 |
24 |
20, 23 |
eqeqd |
_1 = a2 -> (rev (_1 ++ l2) = rev l2 ++ rev _1 <-> rev (a2 ++ l2) = rev l2 ++ rev a2) |
25 |
|
id |
_1 = a1 : a2 -> _1 = a1 : a2 |
26 |
|
eqidd |
_1 = a1 : a2 -> l2 = l2 |
27 |
25, 26 |
appendeqd |
_1 = a1 : a2 -> _1 ++ l2 = a1 : a2 ++ l2 |
28 |
27 |
reveqd |
_1 = a1 : a2 -> rev (_1 ++ l2) = rev (a1 : a2 ++ l2) |
29 |
|
eqidd |
_1 = a1 : a2 -> rev l2 = rev l2 |
30 |
25 |
reveqd |
_1 = a1 : a2 -> rev _1 = rev (a1 : a2) |
31 |
29, 30 |
appendeqd |
_1 = a1 : a2 -> rev l2 ++ rev _1 = rev l2 ++ rev (a1 : a2) |
32 |
28, 31 |
eqeqd |
_1 = a1 : a2 -> (rev (_1 ++ l2) = rev l2 ++ rev _1 <-> rev (a1 : a2 ++ l2) = rev l2 ++ rev (a1 : a2)) |
33 |
|
eqtr4 |
rev (0 ++ l2) = rev l2 -> rev l2 ++ rev 0 = rev l2 -> rev (0 ++ l2) = rev l2 ++ rev 0 |
34 |
|
reveq |
0 ++ l2 = l2 -> rev (0 ++ l2) = rev l2 |
35 |
|
append0 |
0 ++ l2 = l2 |
36 |
34, 35 |
ax_mp |
rev (0 ++ l2) = rev l2 |
37 |
33, 36 |
ax_mp |
rev l2 ++ rev 0 = rev l2 -> rev (0 ++ l2) = rev l2 ++ rev 0 |
38 |
|
eqtr |
rev l2 ++ rev 0 = rev l2 ++ 0 -> rev l2 ++ 0 = rev l2 -> rev l2 ++ rev 0 = rev l2 |
39 |
|
appendeq2 |
rev 0 = 0 -> rev l2 ++ rev 0 = rev l2 ++ 0 |
40 |
|
rev0 |
rev 0 = 0 |
41 |
39, 40 |
ax_mp |
rev l2 ++ rev 0 = rev l2 ++ 0 |
42 |
38, 41 |
ax_mp |
rev l2 ++ 0 = rev l2 -> rev l2 ++ rev 0 = rev l2 |
43 |
|
append02 |
rev l2 ++ 0 = rev l2 |
44 |
42, 43 |
ax_mp |
rev l2 ++ rev 0 = rev l2 |
45 |
37, 44 |
ax_mp |
rev (0 ++ l2) = rev l2 ++ rev 0 |
46 |
|
eqtr |
rev (a1 : a2 ++ l2) = rev (a1 : (a2 ++ l2)) -> rev (a1 : (a2 ++ l2)) = rev (a2 ++ l2) |> a1 -> rev (a1 : a2 ++ l2) = rev (a2 ++ l2) |> a1 |
47 |
|
reveq |
a1 : a2 ++ l2 = a1 : (a2 ++ l2) -> rev (a1 : a2 ++ l2) = rev (a1 : (a2 ++ l2)) |
48 |
|
appendS |
a1 : a2 ++ l2 = a1 : (a2 ++ l2) |
49 |
47, 48 |
ax_mp |
rev (a1 : a2 ++ l2) = rev (a1 : (a2 ++ l2)) |
50 |
46, 49 |
ax_mp |
rev (a1 : (a2 ++ l2)) = rev (a2 ++ l2) |> a1 -> rev (a1 : a2 ++ l2) = rev (a2 ++ l2) |> a1 |
51 |
|
revS |
rev (a1 : (a2 ++ l2)) = rev (a2 ++ l2) |> a1 |
52 |
50, 51 |
ax_mp |
rev (a1 : a2 ++ l2) = rev (a2 ++ l2) |> a1 |
53 |
|
appendeq2 |
rev (a1 : a2) = rev a2 |> a1 -> rev l2 ++ rev (a1 : a2) = rev l2 ++ (rev a2 |> a1) |
54 |
|
revS |
rev (a1 : a2) = rev a2 |> a1 |
55 |
53, 54 |
ax_mp |
rev l2 ++ rev (a1 : a2) = rev l2 ++ (rev a2 |> a1) |
56 |
|
appendsnoc |
rev l2 ++ (rev a2 |> a1) = rev l2 ++ rev a2 |> a1 |
57 |
|
snoceq1 |
rev (a2 ++ l2) = rev l2 ++ rev a2 -> rev (a2 ++ l2) |> a1 = rev l2 ++ rev a2 |> a1 |
58 |
56, 57 |
syl6eqr |
rev (a2 ++ l2) = rev l2 ++ rev a2 -> rev (a2 ++ l2) |> a1 = rev l2 ++ (rev a2 |> a1) |
59 |
55, 58 |
syl6eqr |
rev (a2 ++ l2) = rev l2 ++ rev a2 -> rev (a2 ++ l2) |> a1 = rev l2 ++ rev (a1 : a2) |
60 |
52, 59 |
syl5eq |
rev (a2 ++ l2) = rev l2 ++ rev a2 -> rev (a1 : a2 ++ l2) = rev l2 ++ rev (a1 : a2) |
61 |
8, 16, 24, 32, 45, 60 |
listind |
rev (l1 ++ l2) = rev l2 ++ rev l1 |