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 485 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → 𝑊 ∈ Word 𝑉) | |
2 | elfzelz 12902 | . . . 4 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → 𝑁 ∈ ℤ) | |
3 | 2 | adantl 484 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → 𝑁 ∈ ℤ) |
4 | ubmelfzo 13096 | . . . 4 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) | |
5 | 4 | adantl 484 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) |
6 | cshwidxmod 14159 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ ℤ ∧ ((♯‘𝑊) − 𝑁) ∈ (0..^(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)))) | |
7 | 1, 3, 5, 6 | syl3anc 1367 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)))) |
8 | elfz1b 12970 | . . . . . . . 8 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) ↔ (𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊))) | |
9 | nncn 11640 | . . . . . . . . . 10 ⊢ (𝑁 ∈ ℕ → 𝑁 ∈ ℂ) | |
10 | nncn 11640 | . . . . . . . . . 10 ⊢ ((♯‘𝑊) ∈ ℕ → (♯‘𝑊) ∈ ℂ) | |
11 | 9, 10 | anim12ci 615 | . . . . . . . . 9 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
12 | 11 | 3adant3 1128 | . . . . . . . 8 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊)) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
13 | 8, 12 | sylbi 219 | . . . . . . 7 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ)) |
14 | npcan 10889 | . . . . . . 7 ⊢ (((♯‘𝑊) ∈ ℂ ∧ 𝑁 ∈ ℂ) → (((♯‘𝑊) − 𝑁) + 𝑁) = (♯‘𝑊)) | |
15 | 13, 14 | syl 17 | . . . . . 6 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → (((♯‘𝑊) − 𝑁) + 𝑁) = (♯‘𝑊)) |
16 | 15 | oveq1d 7165 | . . . . 5 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = ((♯‘𝑊) mod (♯‘𝑊))) |
17 | 16 | adantl 484 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = ((♯‘𝑊) mod (♯‘𝑊))) |
18 | nnrp 12394 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℕ → (♯‘𝑊) ∈ ℝ+) | |
19 | modid0 13259 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℝ+ → ((♯‘𝑊) mod (♯‘𝑊)) = 0) | |
20 | 18, 19 | syl 17 | . . . . . . 7 ⊢ ((♯‘𝑊) ∈ ℕ → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
21 | 20 | 3ad2ant2 1130 | . . . . . 6 ⊢ ((𝑁 ∈ ℕ ∧ (♯‘𝑊) ∈ ℕ ∧ 𝑁 ≤ (♯‘𝑊)) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
22 | 8, 21 | sylbi 219 | . . . . 5 ⊢ (𝑁 ∈ (1...(♯‘𝑊)) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
23 | 22 | adantl 484 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((♯‘𝑊) mod (♯‘𝑊)) = 0) |
24 | 17, 23 | eqtrd 2856 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊)) = 0) |
25 | 24 | fveq2d 6669 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → (𝑊‘((((♯‘𝑊) − 𝑁) + 𝑁) mod (♯‘𝑊))) = (𝑊‘0)) |
26 | 7, 25 | eqtrd 2856 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑁 ∈ (1...(♯‘𝑊))) → ((𝑊 cyclShift 𝑁)‘((♯‘𝑊) − 𝑁)) = (𝑊‘0)) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ∧ wa 398 ∧ w3a 1083 = wceq 1533 ∈ wcel 2110 class class class wbr 5059 ‘cfv 6350 (class class class)co 7150 ℂcc 10529 0cc0 10531 1c1 10532 + caddc 10534 ≤ cle 10670 − cmin 10864 ℕcn 11632 ℤcz 11975 ℝ+crp 12383 ...cfz 12886 ..^cfzo 13027 mod cmo 13231 ♯chash 13684 Word cword 13855 cyclShift ccsh 14144 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1792 ax-4 1806 ax-5 1907 ax-6 1966 ax-7 2011 ax-8 2112 ax-9 2120 ax-10 2141 ax-11 2156 ax-12 2172 ax-ext 2793 ax-rep 5183 ax-sep 5196 ax-nul 5203 ax-pow 5259 ax-pr 5322 ax-un 7455 ax-cnex 10587 ax-resscn 10588 ax-1cn 10589 ax-icn 10590 ax-addcl 10591 ax-addrcl 10592 ax-mulcl 10593 ax-mulrcl 10594 ax-mulcom 10595 ax-addass 10596 ax-mulass 10597 ax-distr 10598 ax-i2m1 10599 ax-1ne0 10600 ax-1rid 10601 ax-rnegex 10602 ax-rrecex 10603 ax-cnre 10604 ax-pre-lttri 10605 ax-pre-lttrn 10606 ax-pre-ltadd 10607 ax-pre-mulgt0 10608 ax-pre-sup 10609 |
This theorem depends on definitions: df-bi 209 df-an 399 df-or 844 df-3or 1084 df-3an 1085 df-tru 1536 df-ex 1777 df-nf 1781 df-sb 2066 df-mo 2618 df-eu 2650 df-clab 2800 df-cleq 2814 df-clel 2893 df-nfc 2963 df-ne 3017 df-nel 3124 df-ral 3143 df-rex 3144 df-reu 3145 df-rmo 3146 df-rab 3147 df-v 3497 df-sbc 3773 df-csb 3884 df-dif 3939 df-un 3941 df-in 3943 df-ss 3952 df-pss 3954 df-nul 4292 df-if 4468 df-pw 4541 df-sn 4562 df-pr 4564 df-tp 4566 df-op 4568 df-uni 4833 df-int 4870 df-iun 4914 df-br 5060 df-opab 5122 df-mpt 5140 df-tr 5166 df-id 5455 df-eprel 5460 df-po 5469 df-so 5470 df-fr 5509 df-we 5511 df-xp 5556 df-rel 5557 df-cnv 5558 df-co 5559 df-dm 5560 df-rn 5561 df-res 5562 df-ima 5563 df-pred 6143 df-ord 6189 df-on 6190 df-lim 6191 df-suc 6192 df-iota 6309 df-fun 6352 df-fn 6353 df-f 6354 df-f1 6355 df-fo 6356 df-f1o 6357 df-fv 6358 df-riota 7108 df-ov 7153 df-oprab 7154 df-mpo 7155 df-om 7575 df-1st 7683 df-2nd 7684 df-wrecs 7941 df-recs 8002 df-rdg 8040 df-1o 8096 df-oadd 8100 df-er 8283 df-en 8504 df-dom 8505 df-sdom 8506 df-fin 8507 df-sup 8900 df-inf 8901 df-card 9362 df-pnf 10671 df-mnf 10672 df-xr 10673 df-ltxr 10674 df-le 10675 df-sub 10866 df-neg 10867 df-div 11292 df-nn 11633 df-2 11694 df-n0 11892 df-z 11976 df-uz 12238 df-rp 12384 df-fz 12887 df-fzo 13028 df-fl 13156 df-mod 13232 df-hash 13685 df-word 13856 df-concat 13917 df-substr 13997 df-pfx 14027 df-csh 14145 |
This theorem is referenced by: (None) |
Copyright terms: Public domain | W3C validator |