ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  nndi GIF version

Theorem nndi 6093
Description: Distributive law for natural numbers (left-distributivity). Theorem 4K(3) of [Enderton] p. 81. (Contributed by NM, 20-Sep-1995.) (Revised by Mario Carneiro, 15-Nov-2014.)
Assertion
Ref Expression
nndi ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝐶 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶)))

Proof of Theorem nndi
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 oveq2 5545 . . . . . . 7 (𝑥 = 𝐶 → (𝐵 +𝑜 𝑥) = (𝐵 +𝑜 𝐶))
21oveq2d 5553 . . . . . 6 (𝑥 = 𝐶 → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)))
3 oveq2 5545 . . . . . . 7 (𝑥 = 𝐶 → (𝐴 ·𝑜 𝑥) = (𝐴 ·𝑜 𝐶))
43oveq2d 5553 . . . . . 6 (𝑥 = 𝐶 → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶)))
52, 4eqeq12d 2068 . . . . 5 (𝑥 = 𝐶 → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) ↔ (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶))))
65imbi2d 223 . . . 4 (𝑥 = 𝐶 → (((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥))) ↔ ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶)))))
7 oveq2 5545 . . . . . . 7 (𝑥 = ∅ → (𝐵 +𝑜 𝑥) = (𝐵 +𝑜 ∅))
87oveq2d 5553 . . . . . 6 (𝑥 = ∅ → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = (𝐴 ·𝑜 (𝐵 +𝑜 ∅)))
9 oveq2 5545 . . . . . . 7 (𝑥 = ∅ → (𝐴 ·𝑜 𝑥) = (𝐴 ·𝑜 ∅))
109oveq2d 5553 . . . . . 6 (𝑥 = ∅ → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 ∅)))
118, 10eqeq12d 2068 . . . . 5 (𝑥 = ∅ → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) ↔ (𝐴 ·𝑜 (𝐵 +𝑜 ∅)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 ∅))))
12 oveq2 5545 . . . . . . 7 (𝑥 = 𝑦 → (𝐵 +𝑜 𝑥) = (𝐵 +𝑜 𝑦))
1312oveq2d 5553 . . . . . 6 (𝑥 = 𝑦 → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = (𝐴 ·𝑜 (𝐵 +𝑜 𝑦)))
14 oveq2 5545 . . . . . . 7 (𝑥 = 𝑦 → (𝐴 ·𝑜 𝑥) = (𝐴 ·𝑜 𝑦))
1514oveq2d 5553 . . . . . 6 (𝑥 = 𝑦 → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)))
1613, 15eqeq12d 2068 . . . . 5 (𝑥 = 𝑦 → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) ↔ (𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦))))
17 oveq2 5545 . . . . . . 7 (𝑥 = suc 𝑦 → (𝐵 +𝑜 𝑥) = (𝐵 +𝑜 suc 𝑦))
1817oveq2d 5553 . . . . . 6 (𝑥 = suc 𝑦 → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)))
19 oveq2 5545 . . . . . . 7 (𝑥 = suc 𝑦 → (𝐴 ·𝑜 𝑥) = (𝐴 ·𝑜 suc 𝑦))
2019oveq2d 5553 . . . . . 6 (𝑥 = suc 𝑦 → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦)))
2118, 20eqeq12d 2068 . . . . 5 (𝑥 = suc 𝑦 → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥)) ↔ (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦))))
22 nna0 6081 . . . . . . . . 9 (𝐵 ∈ ω → (𝐵 +𝑜 ∅) = 𝐵)
2322adantl 266 . . . . . . . 8 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐵 +𝑜 ∅) = 𝐵)
2423oveq2d 5553 . . . . . . 7 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 ∅)) = (𝐴 ·𝑜 𝐵))
25 nnmcl 6088 . . . . . . . 8 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 𝐵) ∈ ω)
26 nna0 6081 . . . . . . . 8 ((𝐴 ·𝑜 𝐵) ∈ ω → ((𝐴 ·𝑜 𝐵) +𝑜 ∅) = (𝐴 ·𝑜 𝐵))
2725, 26syl 14 . . . . . . 7 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → ((𝐴 ·𝑜 𝐵) +𝑜 ∅) = (𝐴 ·𝑜 𝐵))
2824, 27eqtr4d 2089 . . . . . 6 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 ∅)) = ((𝐴 ·𝑜 𝐵) +𝑜 ∅))
29 nnm0 6082 . . . . . . . 8 (𝐴 ∈ ω → (𝐴 ·𝑜 ∅) = ∅)
3029adantr 265 . . . . . . 7 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 ∅) = ∅)
3130oveq2d 5553 . . . . . 6 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 ∅)) = ((𝐴 ·𝑜 𝐵) +𝑜 ∅))
3228, 31eqtr4d 2089 . . . . 5 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 ∅)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 ∅)))
33 oveq1 5544 . . . . . . . . 9 ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴) = (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴))
34 nnasuc 6083 . . . . . . . . . . . . 13 ((𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐵 +𝑜 suc 𝑦) = suc (𝐵 +𝑜 𝑦))
35343adant1 931 . . . . . . . . . . . 12 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐵 +𝑜 suc 𝑦) = suc (𝐵 +𝑜 𝑦))
3635oveq2d 5553 . . . . . . . . . . 11 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = (𝐴 ·𝑜 suc (𝐵 +𝑜 𝑦)))
37 nnacl 6087 . . . . . . . . . . . . 13 ((𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐵 +𝑜 𝑦) ∈ ω)
38 nnmsuc 6084 . . . . . . . . . . . . 13 ((𝐴 ∈ ω ∧ (𝐵 +𝑜 𝑦) ∈ ω) → (𝐴 ·𝑜 suc (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴))
3937, 38sylan2 274 . . . . . . . . . . . 12 ((𝐴 ∈ ω ∧ (𝐵 ∈ ω ∧ 𝑦 ∈ ω)) → (𝐴 ·𝑜 suc (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴))
40393impb 1109 . . . . . . . . . . 11 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 suc (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴))
4136, 40eqtrd 2086 . . . . . . . . . 10 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴))
42 nnmsuc 6084 . . . . . . . . . . . . 13 ((𝐴 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 suc 𝑦) = ((𝐴 ·𝑜 𝑦) +𝑜 𝐴))
43423adant2 932 . . . . . . . . . . . 12 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 suc 𝑦) = ((𝐴 ·𝑜 𝑦) +𝑜 𝐴))
4443oveq2d 5553 . . . . . . . . . . 11 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))
45 nnmcl 6088 . . . . . . . . . . . . . . . . . 18 ((𝐴 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ·𝑜 𝑦) ∈ ω)
46 nnaass 6092 . . . . . . . . . . . . . . . . . . 19 (((𝐴 ·𝑜 𝐵) ∈ ω ∧ (𝐴 ·𝑜 𝑦) ∈ ω ∧ 𝐴 ∈ ω) → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))
4725, 46syl3an1 1177 . . . . . . . . . . . . . . . . . 18 (((𝐴 ∈ ω ∧ 𝐵 ∈ ω) ∧ (𝐴 ·𝑜 𝑦) ∈ ω ∧ 𝐴 ∈ ω) → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))
4845, 47syl3an2 1178 . . . . . . . . . . . . . . . . 17 (((𝐴 ∈ ω ∧ 𝐵 ∈ ω) ∧ (𝐴 ∈ ω ∧ 𝑦 ∈ ω) ∧ 𝐴 ∈ ω) → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))
49483exp 1112 . . . . . . . . . . . . . . . 16 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → ((𝐴 ∈ ω ∧ 𝑦 ∈ ω) → (𝐴 ∈ ω → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))))
5049exp4b 353 . . . . . . . . . . . . . . 15 (𝐴 ∈ ω → (𝐵 ∈ ω → (𝐴 ∈ ω → (𝑦 ∈ ω → (𝐴 ∈ ω → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))))))
5150pm2.43a 49 . . . . . . . . . . . . . 14 (𝐴 ∈ ω → (𝐵 ∈ ω → (𝑦 ∈ ω → (𝐴 ∈ ω → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴))))))
5251com4r 84 . . . . . . . . . . . . 13 (𝐴 ∈ ω → (𝐴 ∈ ω → (𝐵 ∈ ω → (𝑦 ∈ ω → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴))))))
5352pm2.43i 47 . . . . . . . . . . . 12 (𝐴 ∈ ω → (𝐵 ∈ ω → (𝑦 ∈ ω → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))))
54533imp 1107 . . . . . . . . . . 11 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴) = ((𝐴 ·𝑜 𝐵) +𝑜 ((𝐴 ·𝑜 𝑦) +𝑜 𝐴)))
5544, 54eqtr4d 2089 . . . . . . . . . 10 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦)) = (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴))
5641, 55eqeq12d 2068 . . . . . . . . 9 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → ((𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦)) ↔ ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) +𝑜 𝐴) = (((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) +𝑜 𝐴)))
5733, 56syl5ibr 149 . . . . . . . 8 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝑦 ∈ ω) → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦))))
58573exp 1112 . . . . . . 7 (𝐴 ∈ ω → (𝐵 ∈ ω → (𝑦 ∈ ω → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦))))))
5958com3r 77 . . . . . 6 (𝑦 ∈ ω → (𝐴 ∈ ω → (𝐵 ∈ ω → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦))))))
6059impd 246 . . . . 5 (𝑦 ∈ ω → ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → ((𝐴 ·𝑜 (𝐵 +𝑜 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑦)) → (𝐴 ·𝑜 (𝐵 +𝑜 suc 𝑦)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 suc 𝑦)))))
6111, 16, 21, 32, 60finds2 4349 . . . 4 (𝑥 ∈ ω → ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝑥)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝑥))))
626, 61vtoclga 2634 . . 3 (𝐶 ∈ ω → ((𝐴 ∈ ω ∧ 𝐵 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶))))
6362expdcom 1345 . 2 (𝐴 ∈ ω → (𝐵 ∈ ω → (𝐶 ∈ ω → (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶)))))
64633imp 1107 1 ((𝐴 ∈ ω ∧ 𝐵 ∈ ω ∧ 𝐶 ∈ ω) → (𝐴 ·𝑜 (𝐵 +𝑜 𝐶)) = ((𝐴 ·𝑜 𝐵) +𝑜 (𝐴 ·𝑜 𝐶)))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 101  w3a 894   = wceq 1257  wcel 1407  c0 3249  suc csuc 4127  ωcom 4338  (class class class)co 5537   +𝑜 coa 6026   ·𝑜 comu 6027
This theorem was proved from axioms:  ax-1 5  ax-2 6  ax-mp 7  ax-ia1 103  ax-ia2 104  ax-ia3 105  ax-in1 552  ax-in2 553  ax-io 638  ax-5 1350  ax-7 1351  ax-gen 1352  ax-ie1 1396  ax-ie2 1397  ax-8 1409  ax-10 1410  ax-11 1411  ax-i12 1412  ax-bndl 1413  ax-4 1414  ax-13 1418  ax-14 1419  ax-17 1433  ax-i9 1437  ax-ial 1441  ax-i5r 1442  ax-ext 2036  ax-coll 3897  ax-sep 3900  ax-nul 3908  ax-pow 3952  ax-pr 3969  ax-un 4195  ax-setind 4287  ax-iinf 4336
This theorem depends on definitions:  df-bi 114  df-3an 896  df-tru 1260  df-fal 1263  df-nf 1364  df-sb 1660  df-eu 1917  df-mo 1918  df-clab 2041  df-cleq 2047  df-clel 2050  df-nfc 2181  df-ne 2219  df-ral 2326  df-rex 2327  df-reu 2328  df-rab 2330  df-v 2574  df-sbc 2785  df-csb 2878  df-dif 2945  df-un 2947  df-in 2949  df-ss 2956  df-nul 3250  df-pw 3386  df-sn 3406  df-pr 3407  df-op 3409  df-uni 3606  df-int 3641  df-iun 3684  df-br 3790  df-opab 3844  df-mpt 3845  df-tr 3880  df-id 4055  df-iord 4128  df-on 4130  df-suc 4133  df-iom 4339  df-xp 4376  df-rel 4377  df-cnv 4378  df-co 4379  df-dm 4380  df-rn 4381  df-res 4382  df-ima 4383  df-iota 4892  df-fun 4929  df-fn 4930  df-f 4931  df-f1 4932  df-fo 4933  df-f1o 4934  df-fv 4935  df-ov 5540  df-oprab 5541  df-mpt2 5542  df-1st 5792  df-2nd 5793  df-recs 5948  df-irdg 5985  df-oadd 6033  df-omul 6034
This theorem is referenced by:  nnmass  6094  nndir  6097  distrpig  6459  addcmpblnq0  6569  nnanq0  6584  distrnq0  6585  addassnq0  6588
  Copyright terms: Public domain W3C validator