Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
||
Mirrors > Home > MPE Home > Th. List > swrdlend | Structured version Visualization version GIF version |
Description: The value of the subword extractor is the empty set (undefined) if the range is not valid. (Contributed by Alexander van der Vekens, 16-Mar-2018.) (Proof shortened by AV, 2-May-2020.) |
Ref | Expression |
---|---|
swrdlend | ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐿 ≤ 𝐹 → (𝑊 substr 〈𝐹, 𝐿〉) = ∅)) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | swrdval 13993 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝑊 substr 〈𝐹, 𝐿〉) = if((𝐹..^𝐿) ⊆ dom 𝑊, (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹))), ∅)) | |
2 | 1 | adantr 481 | . . 3 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝑊 substr 〈𝐹, 𝐿〉) = if((𝐹..^𝐿) ⊆ dom 𝑊, (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹))), ∅)) |
3 | simpr 485 | . . . . . 6 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → 𝐿 ≤ 𝐹) | |
4 | 3simpc 1142 | . . . . . . . 8 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ)) | |
5 | 4 | adantr 481 | . . . . . . 7 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ)) |
6 | fzon 13046 | . . . . . . 7 ⊢ ((𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐿 ≤ 𝐹 ↔ (𝐹..^𝐿) = ∅)) | |
7 | 5, 6 | syl 17 | . . . . . 6 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝐿 ≤ 𝐹 ↔ (𝐹..^𝐿) = ∅)) |
8 | 3, 7 | mpbid 233 | . . . . 5 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝐹..^𝐿) = ∅) |
9 | 0ss 4347 | . . . . 5 ⊢ ∅ ⊆ dom 𝑊 | |
10 | 8, 9 | eqsstrdi 4018 | . . . 4 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝐹..^𝐿) ⊆ dom 𝑊) |
11 | 10 | iftrued 4471 | . . 3 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → if((𝐹..^𝐿) ⊆ dom 𝑊, (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹))), ∅) = (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹)))) |
12 | fzo0n 13047 | . . . . . . 7 ⊢ ((𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐿 ≤ 𝐹 ↔ (0..^(𝐿 − 𝐹)) = ∅)) | |
13 | 12 | biimpa 477 | . . . . . 6 ⊢ (((𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (0..^(𝐿 − 𝐹)) = ∅) |
14 | 13 | 3adantl1 1158 | . . . . 5 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (0..^(𝐿 − 𝐹)) = ∅) |
15 | 14 | mpteq1d 5146 | . . . 4 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹))) = (𝑖 ∈ ∅ ↦ (𝑊‘(𝑖 + 𝐹)))) |
16 | mpt0 6483 | . . . 4 ⊢ (𝑖 ∈ ∅ ↦ (𝑊‘(𝑖 + 𝐹))) = ∅ | |
17 | 15, 16 | syl6eq 2869 | . . 3 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝑖 ∈ (0..^(𝐿 − 𝐹)) ↦ (𝑊‘(𝑖 + 𝐹))) = ∅) |
18 | 2, 11, 17 | 3eqtrd 2857 | . 2 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) ∧ 𝐿 ≤ 𝐹) → (𝑊 substr 〈𝐹, 𝐿〉) = ∅) |
19 | 18 | ex 413 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝐹 ∈ ℤ ∧ 𝐿 ∈ ℤ) → (𝐿 ≤ 𝐹 → (𝑊 substr 〈𝐹, 𝐿〉) = ∅)) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ↔ wb 207 ∧ wa 396 ∧ w3a 1079 = wceq 1528 ∈ wcel 2105 ⊆ wss 3933 ∅c0 4288 ifcif 4463 〈cop 4563 class class class wbr 5057 ↦ cmpt 5137 dom cdm 5548 ‘cfv 6348 (class class class)co 7145 0cc0 10525 + caddc 10528 ≤ cle 10664 − cmin 10858 ℤcz 11969 ..^cfzo 13021 Word cword 13849 substr csubstr 13990 |
This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1787 ax-4 1801 ax-5 1902 ax-6 1961 ax-7 2006 ax-8 2107 ax-9 2115 ax-10 2136 ax-11 2151 ax-12 2167 ax-ext 2790 ax-rep 5181 ax-sep 5194 ax-nul 5201 ax-pow 5257 ax-pr 5320 ax-un 7450 ax-cnex 10581 ax-resscn 10582 ax-1cn 10583 ax-icn 10584 ax-addcl 10585 ax-addrcl 10586 ax-mulcl 10587 ax-mulrcl 10588 ax-mulcom 10589 ax-addass 10590 ax-mulass 10591 ax-distr 10592 ax-i2m1 10593 ax-1ne0 10594 ax-1rid 10595 ax-rnegex 10596 ax-rrecex 10597 ax-cnre 10598 ax-pre-lttri 10599 ax-pre-lttrn 10600 ax-pre-ltadd 10601 ax-pre-mulgt0 10602 |
This theorem depends on definitions: df-bi 208 df-an 397 df-or 842 df-3or 1080 df-3an 1081 df-tru 1531 df-ex 1772 df-nf 1776 df-sb 2061 df-mo 2615 df-eu 2647 df-clab 2797 df-cleq 2811 df-clel 2890 df-nfc 2960 df-ne 3014 df-nel 3121 df-ral 3140 df-rex 3141 df-reu 3142 df-rab 3144 df-v 3494 df-sbc 3770 df-csb 3881 df-dif 3936 df-un 3938 df-in 3940 df-ss 3949 df-pss 3951 df-nul 4289 df-if 4464 df-pw 4537 df-sn 4558 df-pr 4560 df-tp 4562 df-op 4564 df-uni 4831 df-iun 4912 df-br 5058 df-opab 5120 df-mpt 5138 df-tr 5164 df-id 5453 df-eprel 5458 df-po 5467 df-so 5468 df-fr 5507 df-we 5509 df-xp 5554 df-rel 5555 df-cnv 5556 df-co 5557 df-dm 5558 df-rn 5559 df-res 5560 df-ima 5561 df-pred 6141 df-ord 6187 df-on 6188 df-lim 6189 df-suc 6190 df-iota 6307 df-fun 6350 df-fn 6351 df-f 6352 df-f1 6353 df-fo 6354 df-f1o 6355 df-fv 6356 df-riota 7103 df-ov 7148 df-oprab 7149 df-mpo 7150 df-om 7570 df-1st 7678 df-2nd 7679 df-wrecs 7936 df-recs 7997 df-rdg 8035 df-er 8278 df-en 8498 df-dom 8499 df-sdom 8500 df-pnf 10665 df-mnf 10666 df-xr 10667 df-ltxr 10668 df-le 10669 df-sub 10860 df-neg 10861 df-nn 11627 df-n0 11886 df-z 11970 df-uz 12232 df-fz 12881 df-fzo 13022 df-substr 13991 |
This theorem is referenced by: swrdnd 14004 swrdnd2 14005 swrdsb0eq 14013 swrdccat 14085 |
Copyright terms: Public domain | W3C validator |