![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > swrdval2 | Structured version Visualization version GIF version |
Description: Value of the subword extractor in its intended domain. (Contributed by Stefan O'Rear, 15-Aug-2015.) (Proof shortened by AV, 2-May-2020.) |
Ref | Expression |
---|---|
swrdval2 | ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝑆 substr ⟨𝐹, 𝐿⟩) = (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹)))) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | simp1 1136 | . . 3 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → 𝑆 ∈ Word 𝐴) | |
2 | elfzelz 13500 | . . . 4 ⊢ (𝐹 ∈ (0...𝐿) → 𝐹 ∈ ℤ) | |
3 | 2 | 3ad2ant2 1134 | . . 3 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → 𝐹 ∈ ℤ) |
4 | elfzelz 13500 | . . . 4 ⊢ (𝐿 ∈ (0...(♯‘𝑆)) → 𝐿 ∈ ℤ) | |
5 | 4 | 3ad2ant3 1135 | . . 3 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → 𝐿 ∈ ℤ) |
6 | swrdval 14592 | . . 3 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝑆 substr ⟨𝐹, 𝐿⟩) = if((𝐹..^𝐿) ⊆ dom 𝑆, (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹))), ∅)) | |
7 | 1, 3, 5, 6 | syl3anc 1371 | . 2 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝑆 substr ⟨𝐹, 𝐿⟩) = if((𝐹..^𝐿) ⊆ dom 𝑆, (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹))), ∅)) |
8 | elfzuz 13496 | . . . . . . 7 ⊢ (𝐹 ∈ (0...𝐿) → 𝐹 ∈ (ℤ≥‘0)) | |
9 | 8 | 3ad2ant2 1134 | . . . . . 6 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → 𝐹 ∈ (ℤ≥‘0)) |
10 | fzoss1 13658 | . . . . . 6 ⊢ (𝐹 ∈ (ℤ≥‘0) → (𝐹..^𝐿) ⊆ (0..^𝐿)) | |
11 | 9, 10 | syl 17 | . . . . 5 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝐹..^𝐿) ⊆ (0..^𝐿)) |
12 | elfzuz3 13497 | . . . . . . 7 ⊢ (𝐿 ∈ (0...(♯‘𝑆)) → (♯‘𝑆) ∈ (ℤ≥‘𝐿)) | |
13 | 12 | 3ad2ant3 1135 | . . . . . 6 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (♯‘𝑆) ∈ (ℤ≥‘𝐿)) |
14 | fzoss2 13659 | . . . . . 6 ⊢ ((♯‘𝑆) ∈ (ℤ≥‘𝐿) → (0..^𝐿) ⊆ (0..^(♯‘𝑆))) | |
15 | 13, 14 | syl 17 | . . . . 5 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (0..^𝐿) ⊆ (0..^(♯‘𝑆))) |
16 | 11, 15 | sstrd 3992 | . . . 4 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝐹..^𝐿) ⊆ (0..^(♯‘𝑆))) |
17 | wrddm 14470 | . . . . 5 ⊢ (𝑆 ∈ Word 𝐴 → dom 𝑆 = (0..^(♯‘𝑆))) | |
18 | 17 | 3ad2ant1 1133 | . . . 4 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → dom 𝑆 = (0..^(♯‘𝑆))) |
19 | 16, 18 | sseqtrrd 4023 | . . 3 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝐹..^𝐿) ⊆ dom 𝑆) |
20 | 19 | iftrued 4536 | . 2 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → if((𝐹..^𝐿) ⊆ dom 𝑆, (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹))), ∅) = (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹)))) |
21 | 7, 20 | eqtrd 2772 | 1 ⊢ ((𝑆 ∈ Word 𝐴 ∧ 𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑆))) → (𝑆 substr ⟨𝐹, 𝐿⟩) = (𝑥 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑆‘(𝑥 + 𝐹)))) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ∧ w3a 1087 = wceq 1541 ∈ wcel 2106 ⊆ wss 3948 ∅c0 4322 ifcif 4528 ⟨cop 4634 ↦ cmpt 5231 dom cdm 5676 ‘cfv 6543 (class class class)co 7408 0cc0 11109 + caddc 11112 − cmin 11443 ℤcz 12557 ℤ≥cuz 12821 ...cfz 13483 ..^cfzo 13626 ♯chash 14289 Word cword 14463 substr csubstr 14589 |
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 2703 ax-rep 5285 ax-sep 5299 ax-nul 5306 ax-pow 5363 ax-pr 5427 ax-un 7724 ax-cnex 11165 ax-resscn 11166 ax-1cn 11167 ax-icn 11168 ax-addcl 11169 ax-addrcl 11170 ax-mulcl 11171 ax-mulrcl 11172 ax-mulcom 11173 ax-addass 11174 ax-mulass 11175 ax-distr 11176 ax-i2m1 11177 ax-1ne0 11178 ax-1rid 11179 ax-rnegex 11180 ax-rrecex 11181 ax-cnre 11182 ax-pre-lttri 11183 ax-pre-lttrn 11184 ax-pre-ltadd 11185 ax-pre-mulgt0 11186 |
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 2534 df-eu 2563 df-clab 2710 df-cleq 2724 df-clel 2810 df-nfc 2885 df-ne 2941 df-nel 3047 df-ral 3062 df-rex 3071 df-reu 3377 df-rab 3433 df-v 3476 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 7364 df-ov 7411 df-oprab 7412 df-mpo 7413 df-om 7855 df-1st 7974 df-2nd 7975 df-frecs 8265 df-wrecs 8296 df-recs 8370 df-rdg 8409 df-1o 8465 df-er 8702 df-en 8939 df-dom 8940 df-sdom 8941 df-fin 8942 df-card 9933 df-pnf 11249 df-mnf 11250 df-xr 11251 df-ltxr 11252 df-le 11253 df-sub 11445 df-neg 11446 df-nn 12212 df-n0 12472 df-z 12558 df-uz 12822 df-fz 13484 df-fzo 13627 df-hash 14290 df-word 14464 df-substr 14590 |
This theorem is referenced by: swrdlen 14596 swrdfv 14597 swrdwrdsymb 14611 pfxmpt 14627 swrdswrd 14654 swrdrn2 32113 swrdrn3 32114 cshw1s2 32119 |
Copyright terms: Public domain | W3C validator |