| Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
||
| Mirrors > Home > MPE Home > Th. List > swrdlsw | Structured version Visualization version GIF version | ||
| Description: Extract the last single symbol from a word. (Contributed by Alexander van der Vekens, 23-Sep-2018.) |
| Ref | Expression |
|---|---|
| swrdlsw | ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (𝑊 substr 〈((♯‘𝑊) − 1), (♯‘𝑊)〉) = 〈“(lastS‘𝑊)”〉) |
| Step | Hyp | Ref | Expression |
|---|---|---|---|
| 1 | hashneq0 14320 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → (0 < (♯‘𝑊) ↔ 𝑊 ≠ ∅)) | |
| 2 | lencl 14489 | . . . . . 6 ⊢ (𝑊 ∈ Word 𝑉 → (♯‘𝑊) ∈ ℕ0) | |
| 3 | nn0z 12542 | . . . . . 6 ⊢ ((♯‘𝑊) ∈ ℕ0 → (♯‘𝑊) ∈ ℤ) | |
| 4 | elnnz 12528 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℕ ↔ ((♯‘𝑊) ∈ ℤ ∧ 0 < (♯‘𝑊))) | |
| 5 | fzo0end 13707 | . . . . . . . 8 ⊢ ((♯‘𝑊) ∈ ℕ → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊))) | |
| 6 | 4, 5 | sylbir 235 | . . . . . . 7 ⊢ (((♯‘𝑊) ∈ ℤ ∧ 0 < (♯‘𝑊)) → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊))) |
| 7 | 6 | ex 412 | . . . . . 6 ⊢ ((♯‘𝑊) ∈ ℤ → (0 < (♯‘𝑊) → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊)))) |
| 8 | 2, 3, 7 | 3syl 18 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → (0 < (♯‘𝑊) → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊)))) |
| 9 | 1, 8 | sylbird 260 | . . . 4 ⊢ (𝑊 ∈ Word 𝑉 → (𝑊 ≠ ∅ → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊)))) |
| 10 | 9 | imp 406 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊))) |
| 11 | swrds1 14623 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ ((♯‘𝑊) − 1) ∈ (0..^(♯‘𝑊))) → (𝑊 substr 〈((♯‘𝑊) − 1), (((♯‘𝑊) − 1) + 1)〉) = 〈“(𝑊‘((♯‘𝑊) − 1))”〉) | |
| 12 | 10, 11 | syldan 592 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (𝑊 substr 〈((♯‘𝑊) − 1), (((♯‘𝑊) − 1) + 1)〉) = 〈“(𝑊‘((♯‘𝑊) − 1))”〉) |
| 13 | nn0cn 12441 | . . . . . . 7 ⊢ ((♯‘𝑊) ∈ ℕ0 → (♯‘𝑊) ∈ ℂ) | |
| 14 | ax-1cn 11090 | . . . . . . 7 ⊢ 1 ∈ ℂ | |
| 15 | 13, 14 | jctir 520 | . . . . . 6 ⊢ ((♯‘𝑊) ∈ ℕ0 → ((♯‘𝑊) ∈ ℂ ∧ 1 ∈ ℂ)) |
| 16 | npcan 11396 | . . . . . . 7 ⊢ (((♯‘𝑊) ∈ ℂ ∧ 1 ∈ ℂ) → (((♯‘𝑊) − 1) + 1) = (♯‘𝑊)) | |
| 17 | 16 | eqcomd 2743 | . . . . . 6 ⊢ (((♯‘𝑊) ∈ ℂ ∧ 1 ∈ ℂ) → (♯‘𝑊) = (((♯‘𝑊) − 1) + 1)) |
| 18 | 2, 15, 17 | 3syl 18 | . . . . 5 ⊢ (𝑊 ∈ Word 𝑉 → (♯‘𝑊) = (((♯‘𝑊) − 1) + 1)) |
| 19 | 18 | adantr 480 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (♯‘𝑊) = (((♯‘𝑊) − 1) + 1)) |
| 20 | 19 | opeq2d 4824 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → 〈((♯‘𝑊) − 1), (♯‘𝑊)〉 = 〈((♯‘𝑊) − 1), (((♯‘𝑊) − 1) + 1)〉) |
| 21 | 20 | oveq2d 7377 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (𝑊 substr 〈((♯‘𝑊) − 1), (♯‘𝑊)〉) = (𝑊 substr 〈((♯‘𝑊) − 1), (((♯‘𝑊) − 1) + 1)〉)) |
| 22 | lsw 14520 | . . . 4 ⊢ (𝑊 ∈ Word 𝑉 → (lastS‘𝑊) = (𝑊‘((♯‘𝑊) − 1))) | |
| 23 | 22 | adantr 480 | . . 3 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (lastS‘𝑊) = (𝑊‘((♯‘𝑊) − 1))) |
| 24 | 23 | s1eqd 14558 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → 〈“(lastS‘𝑊)”〉 = 〈“(𝑊‘((♯‘𝑊) − 1))”〉) |
| 25 | 12, 21, 24 | 3eqtr4d 2782 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑊 ≠ ∅) → (𝑊 substr 〈((♯‘𝑊) − 1), (♯‘𝑊)〉) = 〈“(lastS‘𝑊)”〉) |
| Colors of variables: wff setvar class |
| Syntax hints: → wi 4 ∧ wa 395 = wceq 1542 ∈ wcel 2114 ≠ wne 2933 ∅c0 4274 〈cop 4574 class class class wbr 5086 ‘cfv 6493 (class class class)co 7361 ℂcc 11030 0cc0 11032 1c1 11033 + caddc 11035 < clt 11173 − cmin 11371 ℕcn 12168 ℕ0cn0 12431 ℤcz 12518 ..^cfzo 13602 ♯chash 14286 Word cword 14469 lastSclsw 14518 〈“cs1 14552 substr csubstr 14597 |
| 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 5213 ax-sep 5232 ax-nul 5242 ax-pow 5303 ax-pr 5371 ax-un 7683 ax-cnex 11088 ax-resscn 11089 ax-1cn 11090 ax-icn 11091 ax-addcl 11092 ax-addrcl 11093 ax-mulcl 11094 ax-mulrcl 11095 ax-mulcom 11096 ax-addass 11097 ax-mulass 11098 ax-distr 11099 ax-i2m1 11100 ax-1ne0 11101 ax-1rid 11102 ax-rnegex 11103 ax-rrecex 11104 ax-cnre 11105 ax-pre-lttri 11106 ax-pre-lttrn 11107 ax-pre-ltadd 11108 ax-pre-mulgt0 11109 |
| 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-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 5520 df-eprel 5525 df-po 5533 df-so 5534 df-fr 5578 df-we 5580 df-xp 5631 df-rel 5632 df-cnv 5633 df-co 5634 df-dm 5635 df-rn 5636 df-res 5637 df-ima 5638 df-pred 6260 df-ord 6321 df-on 6322 df-lim 6323 df-suc 6324 df-iota 6449 df-fun 6495 df-fn 6496 df-f 6497 df-f1 6498 df-fo 6499 df-f1o 6500 df-fv 6501 df-riota 7318 df-ov 7364 df-oprab 7365 df-mpo 7366 df-om 7812 df-1st 7936 df-2nd 7937 df-frecs 8225 df-wrecs 8256 df-recs 8305 df-rdg 8343 df-1o 8399 df-er 8637 df-en 8888 df-dom 8889 df-sdom 8890 df-fin 8891 df-card 9857 df-pnf 11175 df-mnf 11176 df-xr 11177 df-ltxr 11178 df-le 11179 df-sub 11373 df-neg 11374 df-nn 12169 df-n0 12432 df-xnn0 12505 df-z 12519 df-uz 12783 df-fz 13456 df-fzo 13603 df-hash 14287 df-word 14470 df-lsw 14519 df-s1 14553 df-substr 14598 |
| This theorem is referenced by: pfxsuff1eqwrdeq 14655 pfxlswccat 14669 |
| Copyright terms: Public domain | W3C validator |