![]() |
Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
|
Mirrors > Home > MPE Home > Th. List > ccats1pfxeqbi | Structured version Visualization version GIF version |
Description: A word is a prefix of a word with length greater by 1 than the first word iff the second word is the first word concatenated with the last symbol of the second word. (Contributed by AV, 24-Oct-2018.) (Revised by AV, 10-May-2020.) |
Ref | Expression |
---|---|
ccats1pfxeqbi | ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (𝑊 = (𝑈 prefix (♯‘𝑊)) ↔ 𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉))) |
Step | Hyp | Ref | Expression |
---|---|---|---|
1 | ccats1pfxeq 14067 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (𝑊 = (𝑈 prefix (♯‘𝑊)) → 𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉))) | |
2 | simp1 1133 | . . . . 5 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → 𝑊 ∈ Word 𝑉) | |
3 | lencl 13876 | . . . . . . . . 9 ⊢ (𝑊 ∈ Word 𝑉 → (♯‘𝑊) ∈ ℕ0) | |
4 | nn0p1nn 11924 | . . . . . . . . 9 ⊢ ((♯‘𝑊) ∈ ℕ0 → ((♯‘𝑊) + 1) ∈ ℕ) | |
5 | 3, 4 | syl 17 | . . . . . . . 8 ⊢ (𝑊 ∈ Word 𝑉 → ((♯‘𝑊) + 1) ∈ ℕ) |
6 | 5 | 3ad2ant1 1130 | . . . . . . 7 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → ((♯‘𝑊) + 1) ∈ ℕ) |
7 | 3simpc 1147 | . . . . . . 7 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1))) | |
8 | lswlgt0cl 13912 | . . . . . . 7 ⊢ ((((♯‘𝑊) + 1) ∈ ℕ ∧ (𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1))) → (lastS‘𝑈) ∈ 𝑉) | |
9 | 6, 7, 8 | syl2anc 587 | . . . . . 6 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (lastS‘𝑈) ∈ 𝑉) |
10 | 9 | s1cld 13948 | . . . . 5 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → 〈“(lastS‘𝑈)”〉 ∈ Word 𝑉) |
11 | eqidd 2799 | . . . . 5 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (♯‘𝑊) = (♯‘𝑊)) | |
12 | pfxccatid 14094 | . . . . . 6 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 〈“(lastS‘𝑈)”〉 ∈ Word 𝑉 ∧ (♯‘𝑊) = (♯‘𝑊)) → ((𝑊 ++ 〈“(lastS‘𝑈)”〉) prefix (♯‘𝑊)) = 𝑊) | |
13 | 12 | eqcomd 2804 | . . . . 5 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 〈“(lastS‘𝑈)”〉 ∈ Word 𝑉 ∧ (♯‘𝑊) = (♯‘𝑊)) → 𝑊 = ((𝑊 ++ 〈“(lastS‘𝑈)”〉) prefix (♯‘𝑊))) |
14 | 2, 10, 11, 13 | syl3anc 1368 | . . . 4 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → 𝑊 = ((𝑊 ++ 〈“(lastS‘𝑈)”〉) prefix (♯‘𝑊))) |
15 | oveq1 7142 | . . . . 5 ⊢ (𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉) → (𝑈 prefix (♯‘𝑊)) = ((𝑊 ++ 〈“(lastS‘𝑈)”〉) prefix (♯‘𝑊))) | |
16 | 15 | eqcomd 2804 | . . . 4 ⊢ (𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉) → ((𝑊 ++ 〈“(lastS‘𝑈)”〉) prefix (♯‘𝑊)) = (𝑈 prefix (♯‘𝑊))) |
17 | 14, 16 | sylan9eq 2853 | . . 3 ⊢ (((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) ∧ 𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉)) → 𝑊 = (𝑈 prefix (♯‘𝑊))) |
18 | 17 | ex 416 | . 2 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉) → 𝑊 = (𝑈 prefix (♯‘𝑊)))) |
19 | 1, 18 | impbid 215 | 1 ⊢ ((𝑊 ∈ Word 𝑉 ∧ 𝑈 ∈ Word 𝑉 ∧ (♯‘𝑈) = ((♯‘𝑊) + 1)) → (𝑊 = (𝑈 prefix (♯‘𝑊)) ↔ 𝑈 = (𝑊 ++ 〈“(lastS‘𝑈)”〉))) |
Colors of variables: wff setvar class |
Syntax hints: → wi 4 ↔ wb 209 ∧ wa 399 ∧ w3a 1084 = wceq 1538 ∈ wcel 2111 ‘cfv 6324 (class class class)co 7135 1c1 10527 + caddc 10529 ℕcn 11625 ℕ0cn0 11885 ♯chash 13686 Word cword 13857 lastSclsw 13905 ++ cconcat 13913 〈“cs1 13940 prefix cpfx 14023 |
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 1911 ax-6 1970 ax-7 2015 ax-8 2113 ax-9 2121 ax-10 2142 ax-11 2158 ax-12 2175 ax-ext 2770 ax-rep 5154 ax-sep 5167 ax-nul 5174 ax-pow 5231 ax-pr 5295 ax-un 7441 ax-cnex 10582 ax-resscn 10583 ax-1cn 10584 ax-icn 10585 ax-addcl 10586 ax-addrcl 10587 ax-mulcl 10588 ax-mulrcl 10589 ax-mulcom 10590 ax-addass 10591 ax-mulass 10592 ax-distr 10593 ax-i2m1 10594 ax-1ne0 10595 ax-1rid 10596 ax-rnegex 10597 ax-rrecex 10598 ax-cnre 10599 ax-pre-lttri 10600 ax-pre-lttrn 10601 ax-pre-ltadd 10602 ax-pre-mulgt0 10603 |
This theorem depends on definitions: df-bi 210 df-an 400 df-or 845 df-3or 1085 df-3an 1086 df-tru 1541 df-ex 1782 df-nf 1786 df-sb 2070 df-mo 2598 df-eu 2629 df-clab 2777 df-cleq 2791 df-clel 2870 df-nfc 2938 df-ne 2988 df-nel 3092 df-ral 3111 df-rex 3112 df-reu 3113 df-rab 3115 df-v 3443 df-sbc 3721 df-csb 3829 df-dif 3884 df-un 3886 df-in 3888 df-ss 3898 df-pss 3900 df-nul 4244 df-if 4426 df-pw 4499 df-sn 4526 df-pr 4528 df-tp 4530 df-op 4532 df-uni 4801 df-int 4839 df-iun 4883 df-br 5031 df-opab 5093 df-mpt 5111 df-tr 5137 df-id 5425 df-eprel 5430 df-po 5438 df-so 5439 df-fr 5478 df-we 5480 df-xp 5525 df-rel 5526 df-cnv 5527 df-co 5528 df-dm 5529 df-rn 5530 df-res 5531 df-ima 5532 df-pred 6116 df-ord 6162 df-on 6163 df-lim 6164 df-suc 6165 df-iota 6283 df-fun 6326 df-fn 6327 df-f 6328 df-f1 6329 df-fo 6330 df-f1o 6331 df-fv 6332 df-riota 7093 df-ov 7138 df-oprab 7139 df-mpo 7140 df-om 7561 df-1st 7671 df-2nd 7672 df-wrecs 7930 df-recs 7991 df-rdg 8029 df-1o 8085 df-oadd 8089 df-er 8272 df-en 8493 df-dom 8494 df-sdom 8495 df-fin 8496 df-card 9352 df-pnf 10666 df-mnf 10667 df-xr 10668 df-ltxr 10669 df-le 10670 df-sub 10861 df-neg 10862 df-nn 11626 df-n0 11886 df-xnn0 11956 df-z 11970 df-uz 12232 df-fz 12886 df-fzo 13029 df-hash 13687 df-word 13858 df-lsw 13906 df-concat 13914 df-s1 13941 df-substr 13994 df-pfx 14024 |
This theorem is referenced by: (None) |
Copyright terms: Public domain | W3C validator |