| Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
||
| Mirrors > Home > MPE Home > Th. List > cshwidx0 | Structured version Visualization version GIF version | ||
| Description: The symbol at index 0 of a cyclically shifted nonempty word is the symbol at index N of the original word. (Contributed by AV, 15-May-2018.) (Revised by AV, 21-May-2018.) (Revised by AV, 30-Oct-2018.) |
| Ref | Expression |
|---|---|
| cshwidx0 | ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)) |
| Step | Hyp | Ref | Expression |
|---|---|---|---|
| 1 | hasheq0 14287 | . . . . . 6 ⊢ (𝑊 ∈ Word 𝑉 → ((♯‘𝑊) = 0 ↔ 𝑊 = ∅)) | |
| 2 | elfzo0 13617 | . . . . . . . 8 ⊢ (𝑁 ∈ (0..^(♯‘𝑊)) ↔ (𝑁 ∈ ℕ0 ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 < (♯‘𝑊))) | |
| 3 | elnnne0 12416 | . . . . . . . . . 10 ⊢ ((♯‘𝑊) ∈ ℕ ↔ ((♯‘𝑊) ∈ ℕ0 ∧ (♯‘𝑊) ≠ 0)) | |
| 4 | eqneqall 2944 | . . . . . . . . . . . 12 ⊢ ((♯‘𝑊) = 0 → ((♯‘𝑊) ≠ 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) | |
| 5 | 4 | com12 32 | . . . . . . . . . . 11 ⊢ ((♯‘𝑊) ≠ 0 → ((♯‘𝑊) = 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 6 | 5 | adantl 481 | . . . . . . . . . 10 ⊢ (((♯‘𝑊) ∈ ℕ0 ∧ (♯‘𝑊) ≠ 0) → ((♯‘𝑊) = 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 7 | 3, 6 | sylbi 217 | . . . . . . . . 9 ⊢ ((♯‘𝑊) ∈ ℕ → ((♯‘𝑊) = 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 8 | 7 | 3ad2ant2 1135 | . . . . . . . 8 ⊢ ((𝑁 ∈ ℕ0 ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 < (♯‘𝑊)) → ((♯‘𝑊) = 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 9 | 2, 8 | sylbi 217 | . . . . . . 7 ⊢ (𝑁 ∈ (0..^(♯‘𝑊)) → ((♯‘𝑊) = 0 → (𝑊 ∈ Word 𝑉 → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 10 | 9 | com13 88 | . . . . . 6 ⊢ (𝑊 ∈ Word 𝑉 → ((♯‘𝑊) = 0 → (𝑁 ∈ (0..^(♯‘𝑊)) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 11 | 1, 10 | sylbird 260 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → (𝑊 = ∅ → (𝑁 ∈ (0..^(♯‘𝑊)) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 12 | 11 | com23 86 | . . . 4 ⊢ (𝑊 ∈ Word 𝑉 → (𝑁 ∈ (0..^(♯‘𝑊)) → (𝑊 = ∅ → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)))) |
| 13 | 12 | imp 406 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → (𝑊 = ∅ → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁))) |
| 14 | 13 | com12 32 | . 2 ⊢ (𝑊 = ∅ → ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁))) |
| 15 | simpl 482 | . . . . . 6 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → 𝑊 ∈ Word 𝑉) | |
| 16 | 15 | adantl 481 | . . . . 5 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → 𝑊 ∈ Word 𝑉) |
| 17 | simpl 482 | . . . . 5 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → 𝑊 ≠ ∅) | |
| 18 | elfzoelz 13576 | . . . . . 6 ⊢ (𝑁 ∈ (0..^(♯‘𝑊)) → 𝑁 ∈ ℤ) | |
| 19 | 18 | ad2antll 730 | . . . . 5 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → 𝑁 ∈ ℤ) |
| 20 | cshwidx0mod 14729 | . . . . 5 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅ ∧ 𝑁 ∈ ℤ) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘(𝑁 mod (♯‘𝑊)))) | |
| 21 | 16, 17, 19, 20 | syl3anc 1374 | . . . 4 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘(𝑁 mod (♯‘𝑊)))) |
| 22 | zmodidfzoimp 13822 | . . . . . 6 ⊢ (𝑁 ∈ (0..^(♯‘𝑊)) → (𝑁 mod (♯‘𝑊)) = 𝑁) | |
| 23 | 22 | ad2antll 730 | . . . . 5 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → (𝑁 mod (♯‘𝑊)) = 𝑁) |
| 24 | 23 | fveq2d 6836 | . . . 4 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → (𝑊‘(𝑁 mod (♯‘𝑊))) = (𝑊‘𝑁)) |
| 25 | 21, 24 | eqtrd 2772 | . . 3 ⊢ ((𝑊 ≠ ∅ ∧ (𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊)))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)) |
| 26 | 25 | ex 412 | . 2 ⊢ (𝑊 ≠ ∅ → ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁))) |
| 27 | 14, 26 | pm2.61ine 3016 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘0) = (𝑊‘𝑁)) |
| Colors of variables: wff setvar class |
| Syntax hints: → wi 4 ∧ wa 395 ∧ w3a 1087 = wceq 1542 ∈ wcel 2114 ≠ wne 2933 ∅c0 4274 class class class wbr 5086 ‘cfv 6490 (class class class)co 7358 0cc0 11027 < clt 11167 ℕcn 12146 ℕ0cn0 12402 ℤcz 12489 ..^cfzo 13571 mod cmo 13790 ♯chash 14254 Word cword 14437 cyclShift ccsh 14712 |
| This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1797 ax-4 1811 ax-5 1912 ax-6 1969 ax-7 2010 ax-8 2116 ax-9 2124 ax-10 2147 ax-11 2163 ax-12 2185 ax-ext 2709 ax-rep 5212 ax-sep 5231 ax-nul 5241 ax-pow 5300 ax-pr 5368 ax-un 7680 ax-cnex 11083 ax-resscn 11084 ax-1cn 11085 ax-icn 11086 ax-addcl 11087 ax-addrcl 11088 ax-mulcl 11089 ax-mulrcl 11090 ax-mulcom 11091 ax-addass 11092 ax-mulass 11093 ax-distr 11094 ax-i2m1 11095 ax-1ne0 11096 ax-1rid 11097 ax-rnegex 11098 ax-rrecex 11099 ax-cnre 11100 ax-pre-lttri 11101 ax-pre-lttrn 11102 ax-pre-ltadd 11103 ax-pre-mulgt0 11104 ax-pre-sup 11105 |
| This theorem depends on definitions: df-bi 207 df-an 396 df-or 849 df-3or 1088 df-3an 1089 df-tru 1545 df-fal 1555 df-ex 1782 df-nf 1786 df-sb 2069 df-mo 2540 df-eu 2570 df-clab 2716 df-cleq 2729 df-clel 2812 df-nfc 2886 df-ne 2934 df-nel 3038 df-ral 3053 df-rex 3063 df-rmo 3343 df-reu 3344 df-rab 3391 df-v 3432 df-sbc 3730 df-csb 3839 df-dif 3893 df-un 3895 df-in 3897 df-ss 3907 df-pss 3910 df-nul 4275 df-if 4468 df-pw 4544 df-sn 4569 df-pr 4571 df-op 4575 df-uni 4852 df-int 4891 df-iun 4936 df-br 5087 df-opab 5149 df-mpt 5168 df-tr 5194 df-id 5517 df-eprel 5522 df-po 5530 df-so 5531 df-fr 5575 df-we 5577 df-xp 5628 df-rel 5629 df-cnv 5630 df-co 5631 df-dm 5632 df-rn 5633 df-res 5634 df-ima 5635 df-pred 6257 df-ord 6318 df-on 6319 df-lim 6320 df-suc 6321 df-iota 6446 df-fun 6492 df-fn 6493 df-f 6494 df-f1 6495 df-fo 6496 df-f1o 6497 df-fv 6498 df-riota 7315 df-ov 7361 df-oprab 7362 df-mpo 7363 df-om 7809 df-1st 7933 df-2nd 7934 df-frecs 8222 df-wrecs 8253 df-recs 8302 df-rdg 8340 df-1o 8396 df-er 8634 df-en 8885 df-dom 8886 df-sdom 8887 df-fin 8888 df-sup 9346 df-inf 9347 df-card 9852 df-pnf 11169 df-mnf 11170 df-xr 11171 df-ltxr 11172 df-le 11173 df-sub 11367 df-neg 11368 df-div 11796 df-nn 12147 df-2 12209 df-n0 12403 df-z 12490 df-uz 12753 df-rp 12907 df-fz 13425 df-fzo 13572 df-fl 13713 df-mod 13791 df-hash 14255 df-word 14438 df-concat 14495 df-substr 14566 df-pfx 14596 df-csh 14713 |
| This theorem is referenced by: clwwisshclwws 30074 |
| Copyright terms: Public domain | W3C validator |