Users' Mathboxes Mathbox for Mario Carneiro < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  mrsubcv Structured version   Visualization version   GIF version

Theorem mrsubcv 34967
Description: The value of a substituted singleton. (Contributed by Mario Carneiro, 18-Jul-2016.)
Hypotheses
Ref Expression
mrsubffval.c 𝐢 = (mCNβ€˜π‘‡)
mrsubffval.v 𝑉 = (mVRβ€˜π‘‡)
mrsubffval.r 𝑅 = (mRExβ€˜π‘‡)
mrsubffval.s 𝑆 = (mRSubstβ€˜π‘‡)
Assertion
Ref Expression
mrsubcv ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((π‘†β€˜πΉ)β€˜βŸ¨β€œπ‘‹β€βŸ©) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))

Proof of Theorem mrsubcv
Dummy variable 𝑣 is distinct from all other variables.
StepHypRef Expression
1 simp3 1137 . . . . 5 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ 𝑋 ∈ (𝐢 βˆͺ 𝑉))
21s1cld 14560 . . . 4 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ βŸ¨β€œπ‘‹β€βŸ© ∈ Word (𝐢 βˆͺ 𝑉))
3 elun 4148 . . . . . . 7 (𝑋 ∈ (𝐢 βˆͺ 𝑉) ↔ (𝑋 ∈ 𝐢 ∨ 𝑋 ∈ 𝑉))
4 elfvex 6929 . . . . . . . . 9 (𝑋 ∈ (mCNβ€˜π‘‡) β†’ 𝑇 ∈ V)
5 mrsubffval.c . . . . . . . . 9 𝐢 = (mCNβ€˜π‘‡)
64, 5eleq2s 2850 . . . . . . . 8 (𝑋 ∈ 𝐢 β†’ 𝑇 ∈ V)
7 elfvex 6929 . . . . . . . . 9 (𝑋 ∈ (mVRβ€˜π‘‡) β†’ 𝑇 ∈ V)
8 mrsubffval.v . . . . . . . . 9 𝑉 = (mVRβ€˜π‘‡)
97, 8eleq2s 2850 . . . . . . . 8 (𝑋 ∈ 𝑉 β†’ 𝑇 ∈ V)
106, 9jaoi 854 . . . . . . 7 ((𝑋 ∈ 𝐢 ∨ 𝑋 ∈ 𝑉) β†’ 𝑇 ∈ V)
113, 10sylbi 216 . . . . . 6 (𝑋 ∈ (𝐢 βˆͺ 𝑉) β†’ 𝑇 ∈ V)
12113ad2ant3 1134 . . . . 5 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ 𝑇 ∈ V)
13 mrsubffval.r . . . . . 6 𝑅 = (mRExβ€˜π‘‡)
145, 8, 13mrexval 34958 . . . . 5 (𝑇 ∈ V β†’ 𝑅 = Word (𝐢 βˆͺ 𝑉))
1512, 14syl 17 . . . 4 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ 𝑅 = Word (𝐢 βˆͺ 𝑉))
162, 15eleqtrrd 2835 . . 3 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ βŸ¨β€œπ‘‹β€βŸ© ∈ 𝑅)
17 mrsubffval.s . . . 4 𝑆 = (mRSubstβ€˜π‘‡)
18 eqid 2731 . . . 4 (freeMndβ€˜(𝐢 βˆͺ 𝑉)) = (freeMndβ€˜(𝐢 βˆͺ 𝑉))
195, 8, 13, 17, 18mrsubval 34966 . . 3 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ βŸ¨β€œπ‘‹β€βŸ© ∈ 𝑅) β†’ ((π‘†β€˜πΉ)β€˜βŸ¨β€œπ‘‹β€βŸ©) = ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©)))
2016, 19syld3an3 1408 . 2 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((π‘†β€˜πΉ)β€˜βŸ¨β€œπ‘‹β€βŸ©) = ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©)))
21 simpl1 1190 . . . . . . . . 9 (((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) β†’ 𝐹:π΄βŸΆπ‘…)
2221ffvelcdmda 7086 . . . . . . . 8 ((((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ 𝐴) β†’ (πΉβ€˜π‘£) ∈ 𝑅)
2315ad2antrr 723 . . . . . . . 8 ((((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ 𝐴) β†’ 𝑅 = Word (𝐢 βˆͺ 𝑉))
2422, 23eleqtrd 2834 . . . . . . 7 ((((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ 𝐴) β†’ (πΉβ€˜π‘£) ∈ Word (𝐢 βˆͺ 𝑉))
25 simplr 766 . . . . . . . 8 ((((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) ∧ Β¬ 𝑣 ∈ 𝐴) β†’ 𝑣 ∈ (𝐢 βˆͺ 𝑉))
2625s1cld 14560 . . . . . . 7 ((((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) ∧ Β¬ 𝑣 ∈ 𝐴) β†’ βŸ¨β€œπ‘£β€βŸ© ∈ Word (𝐢 βˆͺ 𝑉))
2724, 26ifclda 4563 . . . . . 6 (((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) ∧ 𝑣 ∈ (𝐢 βˆͺ 𝑉)) β†’ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©) ∈ Word (𝐢 βˆͺ 𝑉))
2827fmpttd 7116 . . . . 5 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ (𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)):(𝐢 βˆͺ 𝑉)⟢Word (𝐢 βˆͺ 𝑉))
29 s1co 14791 . . . . 5 ((𝑋 ∈ (𝐢 βˆͺ 𝑉) ∧ (𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)):(𝐢 βˆͺ 𝑉)⟢Word (𝐢 βˆͺ 𝑉)) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©) = βŸ¨β€œ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹)β€βŸ©)
301, 28, 29syl2anc 583 . . . 4 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©) = βŸ¨β€œ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹)β€βŸ©)
31 eleq1 2820 . . . . . . . 8 (𝑣 = 𝑋 β†’ (𝑣 ∈ 𝐴 ↔ 𝑋 ∈ 𝐴))
32 fveq2 6891 . . . . . . . 8 (𝑣 = 𝑋 β†’ (πΉβ€˜π‘£) = (πΉβ€˜π‘‹))
33 s1eq 14557 . . . . . . . 8 (𝑣 = 𝑋 β†’ βŸ¨β€œπ‘£β€βŸ© = βŸ¨β€œπ‘‹β€βŸ©)
3431, 32, 33ifbieq12d 4556 . . . . . . 7 (𝑣 = 𝑋 β†’ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
35 eqid 2731 . . . . . . 7 (𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) = (𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))
36 fvex 6904 . . . . . . . 8 (πΉβ€˜π‘‹) ∈ V
37 s1cli 14562 . . . . . . . . 9 βŸ¨β€œπ‘‹β€βŸ© ∈ Word V
3837elexi 3493 . . . . . . . 8 βŸ¨β€œπ‘‹β€βŸ© ∈ V
3936, 38ifex 4578 . . . . . . 7 if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©) ∈ V
4034, 35, 39fvmpt 6998 . . . . . 6 (𝑋 ∈ (𝐢 βˆͺ 𝑉) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
41403ad2ant3 1134 . . . . 5 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
4241s1eqd 14558 . . . 4 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ βŸ¨β€œ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹)β€βŸ© = βŸ¨β€œif(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©)β€βŸ©)
4330, 42eqtrd 2771 . . 3 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©) = βŸ¨β€œif(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©)β€βŸ©)
4443oveq2d 7428 . 2 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©)) ∘ βŸ¨β€œπ‘‹β€βŸ©)) = ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g βŸ¨β€œif(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©)β€βŸ©))
4528, 1ffvelcdmd 7087 . . . 4 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((𝑣 ∈ (𝐢 βˆͺ 𝑉) ↦ if(𝑣 ∈ 𝐴, (πΉβ€˜π‘£), βŸ¨β€œπ‘£β€βŸ©))β€˜π‘‹) ∈ Word (𝐢 βˆͺ 𝑉))
4641, 45eqeltrrd 2833 . . 3 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©) ∈ Word (𝐢 βˆͺ 𝑉))
475fvexi 6905 . . . . . . 7 𝐢 ∈ V
488fvexi 6905 . . . . . . 7 𝑉 ∈ V
4947, 48unex 7737 . . . . . 6 (𝐢 βˆͺ 𝑉) ∈ V
50 eqid 2731 . . . . . . 7 (Baseβ€˜(freeMndβ€˜(𝐢 βˆͺ 𝑉))) = (Baseβ€˜(freeMndβ€˜(𝐢 βˆͺ 𝑉)))
5118, 50frmdbas 18775 . . . . . 6 ((𝐢 βˆͺ 𝑉) ∈ V β†’ (Baseβ€˜(freeMndβ€˜(𝐢 βˆͺ 𝑉))) = Word (𝐢 βˆͺ 𝑉))
5249, 51ax-mp 5 . . . . 5 (Baseβ€˜(freeMndβ€˜(𝐢 βˆͺ 𝑉))) = Word (𝐢 βˆͺ 𝑉)
5352eqcomi 2740 . . . 4 Word (𝐢 βˆͺ 𝑉) = (Baseβ€˜(freeMndβ€˜(𝐢 βˆͺ 𝑉)))
5453gsumws1 18761 . . 3 (if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©) ∈ Word (𝐢 βˆͺ 𝑉) β†’ ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g βŸ¨β€œif(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©)β€βŸ©) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
5546, 54syl 17 . 2 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((freeMndβ€˜(𝐢 βˆͺ 𝑉)) Ξ£g βŸ¨β€œif(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©)β€βŸ©) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
5620, 44, 553eqtrd 2775 1 ((𝐹:π΄βŸΆπ‘… ∧ 𝐴 βŠ† 𝑉 ∧ 𝑋 ∈ (𝐢 βˆͺ 𝑉)) β†’ ((π‘†β€˜πΉ)β€˜βŸ¨β€œπ‘‹β€βŸ©) = if(𝑋 ∈ 𝐴, (πΉβ€˜π‘‹), βŸ¨β€œπ‘‹β€βŸ©))
Colors of variables: wff setvar class
Syntax hints:  Β¬ wn 3   β†’ wi 4   ∧ wa 395   ∨ wo 844   ∧ w3a 1086   = wceq 1540   ∈ wcel 2105  Vcvv 3473   βˆͺ cun 3946   βŠ† wss 3948  ifcif 4528   ↦ cmpt 5231   ∘ ccom 5680  βŸΆwf 6539  β€˜cfv 6543  (class class class)co 7412  Word cword 14471  βŸ¨β€œcs1 14552  Basecbs 17151   Ξ£g cgsu 17393  freeMndcfrmd 18770  mCNcmcn 34917  mVRcmvar 34918  mRExcmrex 34923  mRSubstcmrsub 34927
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1912  ax-6 1970  ax-7 2010  ax-8 2107  ax-9 2115  ax-10 2136  ax-11 2153  ax-12 2170  ax-ext 2702  ax-rep 5285  ax-sep 5299  ax-nul 5306  ax-pow 5363  ax-pr 5427  ax-un 7729  ax-cnex 11172  ax-resscn 11173  ax-1cn 11174  ax-icn 11175  ax-addcl 11176  ax-addrcl 11177  ax-mulcl 11178  ax-mulrcl 11179  ax-mulcom 11180  ax-addass 11181  ax-mulass 11182  ax-distr 11183  ax-i2m1 11184  ax-1ne0 11185  ax-1rid 11186  ax-rnegex 11187  ax-rrecex 11188  ax-cnre 11189  ax-pre-lttri 11190  ax-pre-lttrn 11191  ax-pre-ltadd 11192  ax-pre-mulgt0 11193
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 845  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1781  df-nf 1785  df-sb 2067  df-mo 2533  df-eu 2562  df-clab 2709  df-cleq 2723  df-clel 2809  df-nfc 2884  df-ne 2940  df-nel 3046  df-ral 3061  df-rex 3070  df-rmo 3375  df-reu 3376  df-rab 3432  df-v 3475  df-sbc 3778  df-csb 3894  df-dif 3951  df-un 3953  df-in 3955  df-ss 3965  df-pss 3967  df-nul 4323  df-if 4529  df-pw 4604  df-sn 4629  df-pr 4631  df-op 4635  df-uni 4909  df-int 4951  df-iun 4999  df-br 5149  df-opab 5211  df-mpt 5232  df-tr 5266  df-id 5574  df-eprel 5580  df-po 5588  df-so 5589  df-fr 5631  df-we 5633  df-xp 5682  df-rel 5683  df-cnv 5684  df-co 5685  df-dm 5686  df-rn 5687  df-res 5688  df-ima 5689  df-pred 6300  df-ord 6367  df-on 6368  df-lim 6369  df-suc 6370  df-iota 6495  df-fun 6545  df-fn 6546  df-f 6547  df-f1 6548  df-fo 6549  df-f1o 6550  df-fv 6551  df-riota 7368  df-ov 7415  df-oprab 7416  df-mpo 7417  df-om 7860  df-1st 7979  df-2nd 7980  df-frecs 8272  df-wrecs 8303  df-recs 8377  df-rdg 8416  df-1o 8472  df-er 8709  df-map 8828  df-pm 8829  df-en 8946  df-dom 8947  df-sdom 8948  df-fin 8949  df-card 9940  df-pnf 11257  df-mnf 11258  df-xr 11259  df-ltxr 11260  df-le 11261  df-sub 11453  df-neg 11454  df-nn 12220  df-2 12282  df-n0 12480  df-z 12566  df-uz 12830  df-fz 13492  df-fzo 13635  df-seq 13974  df-hash 14298  df-word 14472  df-s1 14553  df-struct 17087  df-slot 17122  df-ndx 17134  df-base 17152  df-plusg 17217  df-0g 17394  df-gsum 17395  df-frmd 18772  df-mrex 34943  df-mrsub 34947
This theorem is referenced by:  mrsubvr  34968  mrsubcn  34976
  Copyright terms: Public domain W3C validator