MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  uzwo Structured version   Visualization version   GIF version

Theorem uzwo 11954
Description: Well-ordering principle: any nonempty subset of an upper set of integers has a least element. (Contributed by NM, 8-Oct-2005.)
Assertion
Ref Expression
uzwo ((𝑆 ⊆ (ℤ𝑀) ∧ 𝑆 ≠ ∅) → ∃𝑗𝑆𝑘𝑆 𝑗𝑘)
Distinct variable group:   𝑗,𝑘,𝑆
Allowed substitution hints:   𝑀(𝑗,𝑘)

Proof of Theorem uzwo
Dummy variables 𝑡 𝑛 𝑚 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 breq1 4789 . . . . . . . . . . . 12 ( = 𝑀 → (𝑡𝑀𝑡))
21ralbidv 3135 . . . . . . . . . . 11 ( = 𝑀 → (∀𝑡𝑆 𝑡 ↔ ∀𝑡𝑆 𝑀𝑡))
32imbi2d 329 . . . . . . . . . 10 ( = 𝑀 → (((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑡) ↔ ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑀𝑡)))
4 breq1 4789 . . . . . . . . . . . 12 ( = 𝑚 → (𝑡𝑚𝑡))
54ralbidv 3135 . . . . . . . . . . 11 ( = 𝑚 → (∀𝑡𝑆 𝑡 ↔ ∀𝑡𝑆 𝑚𝑡))
65imbi2d 329 . . . . . . . . . 10 ( = 𝑚 → (((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑡) ↔ ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑚𝑡)))
7 breq1 4789 . . . . . . . . . . . 12 ( = (𝑚 + 1) → (𝑡 ↔ (𝑚 + 1) ≤ 𝑡))
87ralbidv 3135 . . . . . . . . . . 11 ( = (𝑚 + 1) → (∀𝑡𝑆 𝑡 ↔ ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡))
98imbi2d 329 . . . . . . . . . 10 ( = (𝑚 + 1) → (((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑡) ↔ ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
10 breq1 4789 . . . . . . . . . . . 12 ( = 𝑛 → (𝑡𝑛𝑡))
1110ralbidv 3135 . . . . . . . . . . 11 ( = 𝑛 → (∀𝑡𝑆 𝑡 ↔ ∀𝑡𝑆 𝑛𝑡))
1211imbi2d 329 . . . . . . . . . 10 ( = 𝑛 → (((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑡) ↔ ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑛𝑡)))
13 ssel 3746 . . . . . . . . . . . . . 14 (𝑆 ⊆ (ℤ𝑀) → (𝑡𝑆𝑡 ∈ (ℤ𝑀)))
14 eluzle 11901 . . . . . . . . . . . . . 14 (𝑡 ∈ (ℤ𝑀) → 𝑀𝑡)
1513, 14syl6 35 . . . . . . . . . . . . 13 (𝑆 ⊆ (ℤ𝑀) → (𝑡𝑆𝑀𝑡))
1615ralrimiv 3114 . . . . . . . . . . . 12 (𝑆 ⊆ (ℤ𝑀) → ∀𝑡𝑆 𝑀𝑡)
1716adantr 466 . . . . . . . . . . 11 ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑀𝑡)
1817a1i 11 . . . . . . . . . 10 (𝑀 ∈ ℤ → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑀𝑡))
19 uzssz 11908 . . . . . . . . . . . . 13 (ℤ𝑀) ⊆ ℤ
20 sstr 3760 . . . . . . . . . . . . 13 ((𝑆 ⊆ (ℤ𝑀) ∧ (ℤ𝑀) ⊆ ℤ) → 𝑆 ⊆ ℤ)
2119, 20mpan2 671 . . . . . . . . . . . 12 (𝑆 ⊆ (ℤ𝑀) → 𝑆 ⊆ ℤ)
22 eluzelz 11898 . . . . . . . . . . . . 13 (𝑚 ∈ (ℤ𝑀) → 𝑚 ∈ ℤ)
23 breq1 4789 . . . . . . . . . . . . . . . . . . . 20 (𝑗 = 𝑚 → (𝑗𝑡𝑚𝑡))
2423ralbidv 3135 . . . . . . . . . . . . . . . . . . 19 (𝑗 = 𝑚 → (∀𝑡𝑆 𝑗𝑡 ↔ ∀𝑡𝑆 𝑚𝑡))
2524rspcev 3460 . . . . . . . . . . . . . . . . . 18 ((𝑚𝑆 ∧ ∀𝑡𝑆 𝑚𝑡) → ∃𝑗𝑆𝑡𝑆 𝑗𝑡)
2625expcom 398 . . . . . . . . . . . . . . . . 17 (∀𝑡𝑆 𝑚𝑡 → (𝑚𝑆 → ∃𝑗𝑆𝑡𝑆 𝑗𝑡))
2726con3rr3 152 . . . . . . . . . . . . . . . 16 (¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡 → (∀𝑡𝑆 𝑚𝑡 → ¬ 𝑚𝑆))
28 ssel2 3747 . . . . . . . . . . . . . . . . . . . . . . . . . 26 ((𝑆 ⊆ ℤ ∧ 𝑡𝑆) → 𝑡 ∈ ℤ)
29 zre 11583 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 (𝑚 ∈ ℤ → 𝑚 ∈ ℝ)
30 zre 11583 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 (𝑡 ∈ ℤ → 𝑡 ∈ ℝ)
31 letri3 10325 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 ((𝑚 ∈ ℝ ∧ 𝑡 ∈ ℝ) → (𝑚 = 𝑡 ↔ (𝑚𝑡𝑡𝑚)))
3229, 30, 31syl2an 583 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 ((𝑚 ∈ ℤ ∧ 𝑡 ∈ ℤ) → (𝑚 = 𝑡 ↔ (𝑚𝑡𝑡𝑚)))
33 zleltp1 11630 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 ((𝑡 ∈ ℤ ∧ 𝑚 ∈ ℤ) → (𝑡𝑚𝑡 < (𝑚 + 1)))
34 peano2re 10411 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 (𝑚 ∈ ℝ → (𝑚 + 1) ∈ ℝ)
3529, 34syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 (𝑚 ∈ ℤ → (𝑚 + 1) ∈ ℝ)
36 ltnle 10319 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 ((𝑡 ∈ ℝ ∧ (𝑚 + 1) ∈ ℝ) → (𝑡 < (𝑚 + 1) ↔ ¬ (𝑚 + 1) ≤ 𝑡))
3730, 35, 36syl2an 583 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 ((𝑡 ∈ ℤ ∧ 𝑚 ∈ ℤ) → (𝑡 < (𝑚 + 1) ↔ ¬ (𝑚 + 1) ≤ 𝑡))
3833, 37bitrd 268 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 ((𝑡 ∈ ℤ ∧ 𝑚 ∈ ℤ) → (𝑡𝑚 ↔ ¬ (𝑚 + 1) ≤ 𝑡))
3938ancoms 455 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 ((𝑚 ∈ ℤ ∧ 𝑡 ∈ ℤ) → (𝑡𝑚 ↔ ¬ (𝑚 + 1) ≤ 𝑡))
4039anbi2d 614 . . . . . . . . . . . . . . . . . . . . . . . . . . 27 ((𝑚 ∈ ℤ ∧ 𝑡 ∈ ℤ) → ((𝑚𝑡𝑡𝑚) ↔ (𝑚𝑡 ∧ ¬ (𝑚 + 1) ≤ 𝑡)))
4132, 40bitrd 268 . . . . . . . . . . . . . . . . . . . . . . . . . 26 ((𝑚 ∈ ℤ ∧ 𝑡 ∈ ℤ) → (𝑚 = 𝑡 ↔ (𝑚𝑡 ∧ ¬ (𝑚 + 1) ≤ 𝑡)))
4228, 41sylan2 580 . . . . . . . . . . . . . . . . . . . . . . . . 25 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → (𝑚 = 𝑡 ↔ (𝑚𝑡 ∧ ¬ (𝑚 + 1) ≤ 𝑡)))
43 eleq1a 2845 . . . . . . . . . . . . . . . . . . . . . . . . . 26 (𝑡𝑆 → (𝑚 = 𝑡𝑚𝑆))
4443ad2antll 708 . . . . . . . . . . . . . . . . . . . . . . . . 25 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → (𝑚 = 𝑡𝑚𝑆))
4542, 44sylbird 250 . . . . . . . . . . . . . . . . . . . . . . . 24 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → ((𝑚𝑡 ∧ ¬ (𝑚 + 1) ≤ 𝑡) → 𝑚𝑆))
4645expd 400 . . . . . . . . . . . . . . . . . . . . . . 23 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → (𝑚𝑡 → (¬ (𝑚 + 1) ≤ 𝑡𝑚𝑆)))
47 con1 145 . . . . . . . . . . . . . . . . . . . . . . 23 ((¬ (𝑚 + 1) ≤ 𝑡𝑚𝑆) → (¬ 𝑚𝑆 → (𝑚 + 1) ≤ 𝑡))
4846, 47syl6 35 . . . . . . . . . . . . . . . . . . . . . 22 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → (𝑚𝑡 → (¬ 𝑚𝑆 → (𝑚 + 1) ≤ 𝑡)))
4948com23 86 . . . . . . . . . . . . . . . . . . . . 21 ((𝑚 ∈ ℤ ∧ (𝑆 ⊆ ℤ ∧ 𝑡𝑆)) → (¬ 𝑚𝑆 → (𝑚𝑡 → (𝑚 + 1) ≤ 𝑡)))
5049exp32 407 . . . . . . . . . . . . . . . . . . . 20 (𝑚 ∈ ℤ → (𝑆 ⊆ ℤ → (𝑡𝑆 → (¬ 𝑚𝑆 → (𝑚𝑡 → (𝑚 + 1) ≤ 𝑡)))))
5150com34 91 . . . . . . . . . . . . . . . . . . 19 (𝑚 ∈ ℤ → (𝑆 ⊆ ℤ → (¬ 𝑚𝑆 → (𝑡𝑆 → (𝑚𝑡 → (𝑚 + 1) ≤ 𝑡)))))
5251imp41 412 . . . . . . . . . . . . . . . . . 18 ((((𝑚 ∈ ℤ ∧ 𝑆 ⊆ ℤ) ∧ ¬ 𝑚𝑆) ∧ 𝑡𝑆) → (𝑚𝑡 → (𝑚 + 1) ≤ 𝑡))
5352ralimdva 3111 . . . . . . . . . . . . . . . . 17 (((𝑚 ∈ ℤ ∧ 𝑆 ⊆ ℤ) ∧ ¬ 𝑚𝑆) → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡))
5453ex 397 . . . . . . . . . . . . . . . 16 ((𝑚 ∈ ℤ ∧ 𝑆 ⊆ ℤ) → (¬ 𝑚𝑆 → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
5527, 54sylan9r 498 . . . . . . . . . . . . . . 15 (((𝑚 ∈ ℤ ∧ 𝑆 ⊆ ℤ) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑚𝑡 → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
5655pm2.43d 53 . . . . . . . . . . . . . 14 (((𝑚 ∈ ℤ ∧ 𝑆 ⊆ ℤ) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡))
5756expl 445 . . . . . . . . . . . . 13 (𝑚 ∈ ℤ → ((𝑆 ⊆ ℤ ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
5822, 57syl 17 . . . . . . . . . . . 12 (𝑚 ∈ (ℤ𝑀) → ((𝑆 ⊆ ℤ ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
5921, 58sylani 591 . . . . . . . . . . 11 (𝑚 ∈ (ℤ𝑀) → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑚𝑡 → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
6059a2d 29 . . . . . . . . . 10 (𝑚 ∈ (ℤ𝑀) → (((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑚𝑡) → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 (𝑚 + 1) ≤ 𝑡)))
613, 6, 9, 12, 18, 60uzind4 11948 . . . . . . . . 9 (𝑛 ∈ (ℤ𝑀) → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ∀𝑡𝑆 𝑛𝑡))
62 breq1 4789 . . . . . . . . . . . . . 14 (𝑗 = 𝑛 → (𝑗𝑡𝑛𝑡))
6362ralbidv 3135 . . . . . . . . . . . . 13 (𝑗 = 𝑛 → (∀𝑡𝑆 𝑗𝑡 ↔ ∀𝑡𝑆 𝑛𝑡))
6463rspcev 3460 . . . . . . . . . . . 12 ((𝑛𝑆 ∧ ∀𝑡𝑆 𝑛𝑡) → ∃𝑗𝑆𝑡𝑆 𝑗𝑡)
6564expcom 398 . . . . . . . . . . 11 (∀𝑡𝑆 𝑛𝑡 → (𝑛𝑆 → ∃𝑗𝑆𝑡𝑆 𝑗𝑡))
6665con3rr3 152 . . . . . . . . . 10 (¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡 → (∀𝑡𝑆 𝑛𝑡 → ¬ 𝑛𝑆))
6766adantl 467 . . . . . . . . 9 ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → (∀𝑡𝑆 𝑛𝑡 → ¬ 𝑛𝑆))
6861, 67sylcom 30 . . . . . . . 8 (𝑛 ∈ (ℤ𝑀) → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ¬ 𝑛𝑆))
69 ssel 3746 . . . . . . . . . 10 (𝑆 ⊆ (ℤ𝑀) → (𝑛𝑆𝑛 ∈ (ℤ𝑀)))
7069con3rr3 152 . . . . . . . . 9 𝑛 ∈ (ℤ𝑀) → (𝑆 ⊆ (ℤ𝑀) → ¬ 𝑛𝑆))
7170adantrd 479 . . . . . . . 8 𝑛 ∈ (ℤ𝑀) → ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ¬ 𝑛𝑆))
7268, 71pm2.61i 176 . . . . . . 7 ((𝑆 ⊆ (ℤ𝑀) ∧ ¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡) → ¬ 𝑛𝑆)
7372ex 397 . . . . . 6 (𝑆 ⊆ (ℤ𝑀) → (¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡 → ¬ 𝑛𝑆))
7473alrimdv 2009 . . . . 5 (𝑆 ⊆ (ℤ𝑀) → (¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡 → ∀𝑛 ¬ 𝑛𝑆))
75 eq0 4076 . . . . 5 (𝑆 = ∅ ↔ ∀𝑛 ¬ 𝑛𝑆)
7674, 75syl6ibr 242 . . . 4 (𝑆 ⊆ (ℤ𝑀) → (¬ ∃𝑗𝑆𝑡𝑆 𝑗𝑡𝑆 = ∅))
7776necon1ad 2960 . . 3 (𝑆 ⊆ (ℤ𝑀) → (𝑆 ≠ ∅ → ∃𝑗𝑆𝑡𝑆 𝑗𝑡))
7877imp 393 . 2 ((𝑆 ⊆ (ℤ𝑀) ∧ 𝑆 ≠ ∅) → ∃𝑗𝑆𝑡𝑆 𝑗𝑡)
79 breq2 4790 . . . 4 (𝑡 = 𝑘 → (𝑗𝑡𝑗𝑘))
8079cbvralv 3320 . . 3 (∀𝑡𝑆 𝑗𝑡 ↔ ∀𝑘𝑆 𝑗𝑘)
8180rexbii 3189 . 2 (∃𝑗𝑆𝑡𝑆 𝑗𝑡 ↔ ∃𝑗𝑆𝑘𝑆 𝑗𝑘)
8278, 81sylib 208 1 ((𝑆 ⊆ (ℤ𝑀) ∧ 𝑆 ≠ ∅) → ∃𝑗𝑆𝑘𝑆 𝑗𝑘)
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 196  wa 382  wal 1629   = wceq 1631  wcel 2145  wne 2943  wral 3061  wrex 3062  wss 3723  c0 4063   class class class wbr 4786  cfv 6031  (class class class)co 6793  cr 10137  1c1 10139   + caddc 10141   < clt 10276  cle 10277  cz 11579  cuz 11888
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1870  ax-4 1885  ax-5 1991  ax-6 2057  ax-7 2093  ax-8 2147  ax-9 2154  ax-10 2174  ax-11 2190  ax-12 2203  ax-13 2408  ax-ext 2751  ax-sep 4915  ax-nul 4923  ax-pow 4974  ax-pr 5034  ax-un 7096  ax-cnex 10194  ax-resscn 10195  ax-1cn 10196  ax-icn 10197  ax-addcl 10198  ax-addrcl 10199  ax-mulcl 10200  ax-mulrcl 10201  ax-mulcom 10202  ax-addass 10203  ax-mulass 10204  ax-distr 10205  ax-i2m1 10206  ax-1ne0 10207  ax-1rid 10208  ax-rnegex 10209  ax-rrecex 10210  ax-cnre 10211  ax-pre-lttri 10212  ax-pre-lttrn 10213  ax-pre-ltadd 10214  ax-pre-mulgt0 10215
This theorem depends on definitions:  df-bi 197  df-an 383  df-or 837  df-3or 1072  df-3an 1073  df-tru 1634  df-ex 1853  df-nf 1858  df-sb 2050  df-eu 2622  df-mo 2623  df-clab 2758  df-cleq 2764  df-clel 2767  df-nfc 2902  df-ne 2944  df-nel 3047  df-ral 3066  df-rex 3067  df-reu 3068  df-rab 3070  df-v 3353  df-sbc 3588  df-csb 3683  df-dif 3726  df-un 3728  df-in 3730  df-ss 3737  df-pss 3739  df-nul 4064  df-if 4226  df-pw 4299  df-sn 4317  df-pr 4319  df-tp 4321  df-op 4323  df-uni 4575  df-iun 4656  df-br 4787  df-opab 4847  df-mpt 4864  df-tr 4887  df-id 5157  df-eprel 5162  df-po 5170  df-so 5171  df-fr 5208  df-we 5210  df-xp 5255  df-rel 5256  df-cnv 5257  df-co 5258  df-dm 5259  df-rn 5260  df-res 5261  df-ima 5262  df-pred 5823  df-ord 5869  df-on 5870  df-lim 5871  df-suc 5872  df-iota 5994  df-fun 6033  df-fn 6034  df-f 6035  df-f1 6036  df-fo 6037  df-f1o 6038  df-fv 6039  df-riota 6754  df-ov 6796  df-oprab 6797  df-mpt2 6798  df-om 7213  df-wrecs 7559  df-recs 7621  df-rdg 7659  df-er 7896  df-en 8110  df-dom 8111  df-sdom 8112  df-pnf 10278  df-mnf 10279  df-xr 10280  df-ltxr 10281  df-le 10282  df-sub 10470  df-neg 10471  df-nn 11223  df-n0 11495  df-z 11580  df-uz 11889
This theorem is referenced by:  uzwo2  11955  nnwo  11956  infssuzle  11974  infssuzcl  11975  uzwo4  39742
  Copyright terms: Public domain W3C validator