![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > cshwidxm | Structured version Visualization version GIF version |
Description: The symbol at index (n-N) of a word of length n (not 0) cyclically shifted by N positions (not 0) is the symbol at index 0 of the original word. (Contributed by AV, 18-May-2018.) (Revised by AV, 21-May-2018.) (Revised by AV, 30-Oct-2018.) |
Ref | Expression |
---|---|
cshwidxm | ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘0)) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | simpl 483 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → 𝑊 ∈ Word 𝑉) | |
2 | elfzelz 13466 | . . . 4 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → 𝑁 ∈ ℤ) | |
3 | 2 | adantl 482 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → 𝑁 ∈ ℤ) |
4 | ubmelfzo 13662 | . . . 4 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) | |
5 | 4 | adantl 482 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) |
6 | cshwidxmod 14718 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ ℤ ∧ ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)))) | |
7 | 1, 3, 5, 6 | syl3anc 1371 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)))) |
8 | elfz1b 13535 | . . . . . . . 8 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) ↔ (𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊))) | |
9 | nncn 12185 | . . . . . . . . . 10 ⊢ (𝑁 ∈ ℕ → 𝑁 ∈ ℂ) | |
10 | nncn 12185 | . . . . . . . . . 10 ⊢ ((♯‘𝑊) ∈ ℕ → (♯‘𝑊) ∈ ℂ) | |
11 | 9, 10 | anim12ci 614 | . . . . . . . . 9 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
12 | 11 | 3adant3 1132 | . . . . . . . 8 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊)) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
13 | 8, 12 | sylbi 216 | . . . . . . 7 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
14 | npcan 11434 | . . . . . . 7 ⊢ (((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ) → (((♯‘𝑊) − 𝑁) + 𝑁) = (♯‘𝑊)) | |
15 | 13, 14 | syl 17 | . . . . . 6 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → (((♯‘𝑊) − 𝑁) + 𝑁) = (♯‘𝑊)) |
16 | 15 | oveq1d 7392 | . . . . 5 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = ((♯‘𝑊) mod (♯‘𝑊))) |
17 | 16 | adantl 482 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = ((♯‘𝑊) mod (♯‘𝑊))) |
18 | nnrp 12950 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℕ → (♯‘𝑊) ∈ ℝ+) | |
19 | modid0 13827 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℝ+ → ((♯‘𝑊) mod (♯‘𝑊)) = 0) | |
20 | 18, 19 | syl 17 | . . . . . . 7 ⊢ ((♯‘𝑊) ∈ ℕ → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
21 | 20 | 3ad2ant2 1134 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊)) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
22 | 8, 21 | sylbi 216 | . . . . 5 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
23 | 22 | adantl 482 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
24 | 17, 23 | eqtrd 2771 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = 0) |
25 | 24 | fveq2d 6866 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊))) = (𝑊‘0)) |
26 | 7, 25 | eqtrd 2771 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘0)) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ∧ wa 396 ∧ w3a 1087 = wceq 1541 ∈ wcel 2106 class class class wbr 5125 ‘cfv 6516 (class class class)co 7377 ℂcc 11073 0cc0 11075 1c1 11076 + caddc 11078 ≤ cle 11214 − cmin 11409 ℕcn 12177 ℤcz 12523 ℝ+crp 12939 ...cfz 13449 ..^cfzo 13592 mod cmo 13799 ♯chash 14255 Word cword 14429 cyclShift ccsh 14703 |
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 1913 ax-6 1971 ax-7 2011 ax-8 2108 ax-9 2116 ax-10 2137 ax-11 2154 ax-12 2171 ax-ext 2702 ax-rep 5262 ax-sep 5276 ax-nul 5283 ax-pow 5340 ax-pr 5404 ax-un 7692 ax-cnex 11131 ax-resscn 11132 ax-1cn 11133 ax-icn 11134 ax-addcl 11135 ax-addrcl 11136 ax-mulcl 11137 ax-mulrcl 11138 ax-mulcom 11139 ax-addass 11140 ax-mulass 11141 ax-distr 11142 ax-i2m1 11143 ax-1ne0 11144 ax-1rid 11145 ax-rnegex 11146 ax-rrecex 11147 ax-cnre 11148 ax-pre-lttri 11149 ax-pre-lttrn 11150 ax-pre-ltadd 11151 ax-pre-mulgt0 11152 ax-pre-sup 11153 |
This theorem depends on definitions: df-bi 206 df-an 397 df-or 846 df-3or 1088 df-3an 1089 df-tru 1544 df-fal 1554 df-ex 1782 df-nf 1786 df-sb 2068 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 3364 df-reu 3365 df-rab 3419 df-v 3461 df-sbc 3758 df-csb 3874 df-dif 3931 df-un 3933 df-in 3935 df-ss 3945 df-pss 3947 df-nul 4303 df-if 4507 df-pw 4582 df-sn 4607 df-pr 4609 df-op 4613 df-uni 4886 df-int 4928 df-iun 4976 df-br 5126 df-opab 5188 df-mpt 5209 df-tr 5243 df-id 5551 df-eprel 5557 df-po 5565 df-so 5566 df-fr 5608 df-we 5610 df-xp 5659 df-rel 5660 df-cnv 5661 df-co 5662 df-dm 5663 df-rn 5664 df-res 5665 df-ima 5666 df-pred 6273 df-ord 6340 df-on 6341 df-lim 6342 df-suc 6343 df-iota 6468 df-fun 6518 df-fn 6519 df-f 6520 df-f1 6521 df-fo 6522 df-f1o 6523 df-fv 6524 df-riota 7333 df-ov 7380 df-oprab 7381 df-mpo 7382 df-om 7823 df-1st 7941 df-2nd 7942 df-frecs 8232 df-wrecs 8263 df-recs 8337 df-rdg 8376 df-1o 8432 df-er 8670 df-en 8906 df-dom 8907 df-sdom 8908 df-fin 8909 df-sup 9402 df-inf 9403 df-card 9899 df-pnf 11215 df-mnf 11216 df-xr 11217 df-ltxr 11218 df-le 11219 df-sub 11411 df-neg 11412 df-div 11837 df-nn 12178 df-2 12240 df-n0 12438 df-z 12524 df-uz 12788 df-rp 12940 df-fz 13450 df-fzo 13593 df-fl 13722 df-mod 13800 df-hash 14256 df-word 14430 df-concat 14486 df-substr 14556 df-pfx 14586 df-csh 14704 |
This theorem is referenced by: (None) |
Copyright terms: Public domain | W3C validator |