![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > cshwsiun | Structured version Visualization version GIF version |
Description: The set of (different!) words resulting by cyclically shifting a given word is an indexed union. (Contributed by AV, 19-May-2018.) (Revised by AV, 8-Jun-2018.) (Proof shortened by AV, 8-Nov-2018.) |
Ref | Expression |
---|---|
cshwrepswhash1.m | ⊢ 𝑀 = {𝑤 ∈ Word 𝑉 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤} |
Ref | Expression |
---|---|
cshwsiun | ⊢ (𝑊 ∈ Word 𝑉 → 𝑀 = ∪ 𝑛 ∈ (0..^(♯‘𝑊)){(𝑊 cyclShift 𝑛)}) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | df-rab 3420 | . . 3 ⊢ {𝑤 ∈ Word 𝑉 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤} = {𝑤 ∣ (𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤)} | |
2 | eqcom 2732 | . . . . . . . . 9 ⊢ ((𝑊 cyclShift 𝑛) = 𝑤 ↔ 𝑤 = (𝑊 cyclShift 𝑛)) | |
3 | 2 | biimpi 215 | . . . . . . . 8 ⊢ ((𝑊 cyclShift 𝑛) = 𝑤 → 𝑤 = (𝑊 cyclShift 𝑛)) |
4 | 3 | reximi 3074 | . . . . . . 7 ⊢ (∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤 → ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛)) |
5 | 4 | adantl 480 | . . . . . 6 ⊢ ((𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤) → ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛)) |
6 | cshwcl 14780 | . . . . . . . . . 10 ⊢ (𝑊 ∈ Word 𝑉 → (𝑊 cyclShift 𝑛) ∈ Word 𝑉) | |
7 | 6 | adantr 479 | . . . . . . . . 9 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑛 ∈ (0..^(♯‘𝑊))) → (𝑊 cyclShift 𝑛) ∈ Word 𝑉) |
8 | eleq1 2813 | . . . . . . . . 9 ⊢ (𝑤 = (𝑊 cyclShift 𝑛) → (𝑤 ∈ Word 𝑉 ↔ (𝑊 cyclShift 𝑛) ∈ Word 𝑉)) | |
9 | 7, 8 | syl5ibrcom 246 | . . . . . . . 8 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑛 ∈ (0..^(♯‘𝑊))) → (𝑤 = (𝑊 cyclShift 𝑛) → 𝑤 ∈ Word 𝑉)) |
10 | 9 | rexlimdva 3145 | . . . . . . 7 ⊢ (𝑊 ∈ Word 𝑉 → (∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛) → 𝑤 ∈ Word 𝑉)) |
11 | eqcom 2732 | . . . . . . . . 9 ⊢ (𝑤 = (𝑊 cyclShift 𝑛) ↔ (𝑊 cyclShift 𝑛) = 𝑤) | |
12 | 11 | biimpi 215 | . . . . . . . 8 ⊢ (𝑤 = (𝑊 cyclShift 𝑛) → (𝑊 cyclShift 𝑛) = 𝑤) |
13 | 12 | reximi 3074 | . . . . . . 7 ⊢ (∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛) → ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤) |
14 | 10, 13 | jca2 512 | . . . . . 6 ⊢ (𝑊 ∈ Word 𝑉 → (∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛) → (𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤))) |
15 | 5, 14 | impbid2 225 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → ((𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤) ↔ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛))) |
16 | velsn 4645 | . . . . . . . 8 ⊢ (𝑤 ∈ {(𝑊 cyclShift 𝑛)} ↔ 𝑤 = (𝑊 cyclShift 𝑛)) | |
17 | 16 | bicomi 223 | . . . . . . 7 ⊢ (𝑤 = (𝑊 cyclShift 𝑛) ↔ 𝑤 ∈ {(𝑊 cyclShift 𝑛)}) |
18 | 17 | a1i 11 | . . . . . 6 ⊢ (𝑊 ∈ Word 𝑉 → (𝑤 = (𝑊 cyclShift 𝑛) ↔ 𝑤 ∈ {(𝑊 cyclShift 𝑛)})) |
19 | 18 | rexbidv 3169 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → (∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 = (𝑊 cyclShift 𝑛) ↔ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 ∈ {(𝑊 cyclShift 𝑛)})) |
20 | 15, 19 | bitrd 278 | . . . 4 ⊢ (𝑊 ∈ Word 𝑉 → ((𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤) ↔ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 ∈ {(𝑊 cyclShift 𝑛)})) |
21 | 20 | abbidv 2794 | . . 3 ⊢ (𝑊 ∈ Word 𝑉 → {𝑤 ∣ (𝑤 ∈ Word 𝑉 ∧ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤)} = {𝑤 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 ∈ {(𝑊 cyclShift 𝑛)}}) |
22 | 1, 21 | eqtrid 2777 | . 2 ⊢ (𝑊 ∈ Word 𝑉 → {𝑤 ∈ Word 𝑉 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤} = {𝑤 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 ∈ {(𝑊 cyclShift 𝑛)}}) |
23 | cshwrepswhash1.m | . 2 ⊢ 𝑀 = {𝑤 ∈ Word 𝑉 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))(𝑊 cyclShift 𝑛) = 𝑤} | |
24 | df-iun 4998 | . 2 ⊢ ∪ 𝑛 ∈ (0..^(♯‘𝑊)){(𝑊 cyclShift 𝑛)} = {𝑤 ∣ ∃𝑛 ∈ (0..^(♯‘𝑊))𝑤 ∈ {(𝑊 cyclShift 𝑛)}} | |
25 | 22, 23, 24 | 3eqtr4g 2790 | 1 ⊢ (𝑊 ∈ Word 𝑉 → 𝑀 = ∪ 𝑛 ∈ (0..^(♯‘𝑊)){(𝑊 cyclShift 𝑛)}) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ↔ wb 205 ∧ wa 394 = wceq 1533 ∈ wcel 2098 {cab 2702 ∃wrex 3060 {crab 3419 {csn 4629 ∪ ciun 4996 ‘cfv 6547 (class class class)co 7417 0cc0 11138 ..^cfzo 13659 ♯chash 14321 Word cword 14496 cyclShift ccsh 14770 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1789 ax-4 1803 ax-5 1905 ax-6 1963 ax-7 2003 ax-8 2100 ax-9 2108 ax-10 2129 ax-11 2146 ax-12 2166 ax-ext 2696 ax-rep 5285 ax-sep 5299 ax-nul 5306 ax-pow 5364 ax-pr 5428 ax-un 7739 ax-cnex 11194 ax-resscn 11195 ax-1cn 11196 ax-icn 11197 ax-addcl 11198 ax-addrcl 11199 ax-mulcl 11200 ax-mulrcl 11201 ax-mulcom 11202 ax-addass 11203 ax-mulass 11204 ax-distr 11205 ax-i2m1 11206 ax-1ne0 11207 ax-1rid 11208 ax-rnegex 11209 ax-rrecex 11210 ax-cnre 11211 ax-pre-lttri 11212 ax-pre-lttrn 11213 ax-pre-ltadd 11214 ax-pre-mulgt0 11215 |
This theorem depends on definitions: df-bi 206 df-an 395 df-or 846 df-3or 1085 df-3an 1086 df-tru 1536 df-fal 1546 df-ex 1774 df-nf 1778 df-sb 2060 df-mo 2528 df-eu 2557 df-clab 2703 df-cleq 2717 df-clel 2802 df-nfc 2877 df-ne 2931 df-nel 3037 df-ral 3052 df-rex 3061 df-reu 3365 df-rab 3420 df-v 3465 df-sbc 3775 df-csb 3891 df-dif 3948 df-un 3950 df-in 3952 df-ss 3962 df-pss 3965 df-nul 4324 df-if 4530 df-pw 4605 df-sn 4630 df-pr 4632 df-op 4636 df-uni 4909 df-int 4950 df-iun 4998 df-br 5149 df-opab 5211 df-mpt 5232 df-tr 5266 df-id 5575 df-eprel 5581 df-po 5589 df-so 5590 df-fr 5632 df-we 5634 df-xp 5683 df-rel 5684 df-cnv 5685 df-co 5686 df-dm 5687 df-rn 5688 df-res 5689 df-ima 5690 df-pred 6305 df-ord 6372 df-on 6373 df-lim 6374 df-suc 6375 df-iota 6499 df-fun 6549 df-fn 6550 df-f 6551 df-f1 6552 df-fo 6553 df-f1o 6554 df-fv 6555 df-riota 7373 df-ov 7420 df-oprab 7421 df-mpo 7422 df-om 7870 df-1st 7992 df-2nd 7993 df-frecs 8285 df-wrecs 8316 df-recs 8390 df-rdg 8429 df-1o 8485 df-er 8723 df-en 8963 df-dom 8964 df-sdom 8965 df-fin 8966 df-card 9962 df-pnf 11280 df-mnf 11281 df-xr 11282 df-ltxr 11283 df-le 11284 df-sub 11476 df-neg 11477 df-nn 12243 df-n0 12503 df-z 12589 df-uz 12853 df-fz 13517 df-fzo 13660 df-hash 14322 df-word 14497 df-concat 14553 df-substr 14623 df-pfx 14653 df-csh 14771 |
This theorem is referenced by: cshwsex 17069 cshwshashnsame 17072 |
Copyright terms: Public domain | W3C validator |