MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  pfxco Structured version   Visualization version   GIF version

Theorem pfxco 14747
Description: Mapping of words commutes with the prefix operation. (Contributed by AV, 15-May-2020.)
Assertion
Ref Expression
pfxco ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (𝐹 ∘ (𝑊 prefix 𝑁)) = ((𝐹𝑊) prefix 𝑁))

Proof of Theorem pfxco
StepHypRef Expression
1 elfznn0 13522 . . . . . 6 (𝑁 ∈ (0...(♯‘𝑊)) → 𝑁 ∈ ℕ0)
213ad2ant2 1134 . . . . 5 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → 𝑁 ∈ ℕ0)
3 0elfz 13526 . . . . 5 (𝑁 ∈ ℕ0 → 0 ∈ (0...𝑁))
42, 3syl 17 . . . 4 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → 0 ∈ (0...𝑁))
5 simp2 1137 . . . 4 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → 𝑁 ∈ (0...(♯‘𝑊)))
64, 5jca 511 . . 3 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (0 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑊))))
7 swrdco 14746 . . 3 ((𝑊 ∈ Word 𝐴 ∧ (0 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑊))) ∧ 𝐹:𝐴𝐵) → (𝐹 ∘ (𝑊 substr ⟨0, 𝑁⟩)) = ((𝐹𝑊) substr ⟨0, 𝑁⟩))
86, 7syld3an2 1413 . 2 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (𝐹 ∘ (𝑊 substr ⟨0, 𝑁⟩)) = ((𝐹𝑊) substr ⟨0, 𝑁⟩))
9 pfxval 14583 . . . . 5 ((𝑊 ∈ Word 𝐴𝑁 ∈ ℕ0) → (𝑊 prefix 𝑁) = (𝑊 substr ⟨0, 𝑁⟩))
101, 9sylan2 593 . . . 4 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊))) → (𝑊 prefix 𝑁) = (𝑊 substr ⟨0, 𝑁⟩))
1110coeq2d 5806 . . 3 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊))) → (𝐹 ∘ (𝑊 prefix 𝑁)) = (𝐹 ∘ (𝑊 substr ⟨0, 𝑁⟩)))
12113adant3 1132 . 2 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (𝐹 ∘ (𝑊 prefix 𝑁)) = (𝐹 ∘ (𝑊 substr ⟨0, 𝑁⟩)))
13 ffun 6659 . . . . . . . 8 (𝐹:𝐴𝐵 → Fun 𝐹)
1413anim2i 617 . . . . . . 7 ((𝑊 ∈ Word 𝐴𝐹:𝐴𝐵) → (𝑊 ∈ Word 𝐴 ∧ Fun 𝐹))
1514ancomd 461 . . . . . 6 ((𝑊 ∈ Word 𝐴𝐹:𝐴𝐵) → (Fun 𝐹𝑊 ∈ Word 𝐴))
16153adant2 1131 . . . . 5 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (Fun 𝐹𝑊 ∈ Word 𝐴))
17 cofunexg 7887 . . . . 5 ((Fun 𝐹𝑊 ∈ Word 𝐴) → (𝐹𝑊) ∈ V)
1816, 17syl 17 . . . 4 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (𝐹𝑊) ∈ V)
1918, 2jca 511 . . 3 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → ((𝐹𝑊) ∈ V ∧ 𝑁 ∈ ℕ0))
20 pfxval 14583 . . 3 (((𝐹𝑊) ∈ V ∧ 𝑁 ∈ ℕ0) → ((𝐹𝑊) prefix 𝑁) = ((𝐹𝑊) substr ⟨0, 𝑁⟩))
2119, 20syl 17 . 2 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → ((𝐹𝑊) prefix 𝑁) = ((𝐹𝑊) substr ⟨0, 𝑁⟩))
228, 12, 213eqtr4d 2778 1 ((𝑊 ∈ Word 𝐴𝑁 ∈ (0...(♯‘𝑊)) ∧ 𝐹:𝐴𝐵) → (𝐹 ∘ (𝑊 prefix 𝑁)) = ((𝐹𝑊) prefix 𝑁))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395  w3a 1086   = wceq 1541  wcel 2113  Vcvv 3437  cop 4581  ccom 5623  Fun wfun 6480  wf 6482  cfv 6486  (class class class)co 7352  0cc0 11013  0cn0 12388  ...cfz 13409  chash 14239  Word cword 14422   substr csubstr 14550   prefix cpfx 14580
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1968  ax-7 2009  ax-8 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2182  ax-ext 2705  ax-rep 5219  ax-sep 5236  ax-nul 5246  ax-pow 5305  ax-pr 5372  ax-un 7674  ax-cnex 11069  ax-resscn 11070  ax-1cn 11071  ax-icn 11072  ax-addcl 11073  ax-addrcl 11074  ax-mulcl 11075  ax-mulrcl 11076  ax-mulcom 11077  ax-addass 11078  ax-mulass 11079  ax-distr 11080  ax-i2m1 11081  ax-1ne0 11082  ax-1rid 11083  ax-rnegex 11084  ax-rrecex 11085  ax-cnre 11086  ax-pre-lttri 11087  ax-pre-lttrn 11088  ax-pre-ltadd 11089  ax-pre-mulgt0 11090
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2537  df-eu 2566  df-clab 2712  df-cleq 2725  df-clel 2808  df-nfc 2882  df-ne 2930  df-nel 3034  df-ral 3049  df-rex 3058  df-reu 3348  df-rab 3397  df-v 3439  df-sbc 3738  df-csb 3847  df-dif 3901  df-un 3903  df-in 3905  df-ss 3915  df-pss 3918  df-nul 4283  df-if 4475  df-pw 4551  df-sn 4576  df-pr 4578  df-op 4582  df-uni 4859  df-int 4898  df-iun 4943  df-br 5094  df-opab 5156  df-mpt 5175  df-tr 5201  df-id 5514  df-eprel 5519  df-po 5527  df-so 5528  df-fr 5572  df-we 5574  df-xp 5625  df-rel 5626  df-cnv 5627  df-co 5628  df-dm 5629  df-rn 5630  df-res 5631  df-ima 5632  df-pred 6253  df-ord 6314  df-on 6315  df-lim 6316  df-suc 6317  df-iota 6442  df-fun 6488  df-fn 6489  df-f 6490  df-f1 6491  df-fo 6492  df-f1o 6493  df-fv 6494  df-riota 7309  df-ov 7355  df-oprab 7356  df-mpo 7357  df-om 7803  df-1st 7927  df-2nd 7928  df-frecs 8217  df-wrecs 8248  df-recs 8297  df-rdg 8335  df-1o 8391  df-er 8628  df-en 8876  df-dom 8877  df-sdom 8878  df-fin 8879  df-card 9839  df-pnf 11155  df-mnf 11156  df-xr 11157  df-ltxr 11158  df-le 11159  df-sub 11353  df-neg 11354  df-nn 12133  df-n0 12389  df-z 12476  df-uz 12739  df-fz 13410  df-fzo 13557  df-hash 14240  df-word 14423  df-substr 14551  df-pfx 14581
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator