ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  ccatlen GIF version

Theorem ccatlen 11283
Description: The length of a concatenated word. (Contributed by Stefan O'Rear, 15-Aug-2015.) (Revised by JJ, 1-Jan-2024.)
Assertion
Ref Expression
ccatlen ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘(𝑆 ++ 𝑇)) = ((♯‘𝑆) + (♯‘𝑇)))

Proof of Theorem ccatlen
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 wrdfin 11243 . . . 4 (𝑆 ∈ Word 𝐴𝑆 ∈ Fin)
2 wrdfin 11243 . . . 4 (𝑇 ∈ Word 𝐵𝑇 ∈ Fin)
3 ccatfvalfi 11280 . . . 4 ((𝑆 ∈ Fin ∧ 𝑇 ∈ Fin) → (𝑆 ++ 𝑇) = (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))))
41, 2, 3syl2an 289 . . 3 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (𝑆 ++ 𝑇) = (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))))
54fveq2d 5674 . 2 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘(𝑆 ++ 𝑇)) = (♯‘(𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))))))
6 fvexg 5689 . . . . . . 7 ((𝑆 ∈ Word 𝐴𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (𝑆𝑥) ∈ V)
76adantlr 477 . . . . . 6 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (𝑆𝑥) ∈ V)
8 simplr 529 . . . . . . 7 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → 𝑇 ∈ Word 𝐵)
9 elfzoelz 10481 . . . . . . . . 9 (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) → 𝑥 ∈ ℤ)
109adantl 277 . . . . . . . 8 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → 𝑥 ∈ ℤ)
11 lencl 11228 . . . . . . . . . 10 (𝑆 ∈ Word 𝐴 → (♯‘𝑆) ∈ ℕ0)
1211ad2antrr 488 . . . . . . . . 9 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (♯‘𝑆) ∈ ℕ0)
1312nn0zd 9698 . . . . . . . 8 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (♯‘𝑆) ∈ ℤ)
1410, 13zsubcld 9705 . . . . . . 7 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (𝑥 − (♯‘𝑆)) ∈ ℤ)
15 fvexg 5689 . . . . . . 7 ((𝑇 ∈ Word 𝐵 ∧ (𝑥 − (♯‘𝑆)) ∈ ℤ) → (𝑇‘(𝑥 − (♯‘𝑆))) ∈ V)
168, 14, 15syl2anc 411 . . . . . 6 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → (𝑇‘(𝑥 − (♯‘𝑆))) ∈ V)
177, 16ifexd 4605 . . . . 5 (((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) ∧ 𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))) → if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))) ∈ V)
1817ralrimiva 2615 . . . 4 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → ∀𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))) ∈ V)
19 eqid 2232 . . . . 5 (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))) = (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))))
2019fnmpt 5485 . . . 4 (∀𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇)))if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))) ∈ V → (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))) Fn (0..^((♯‘𝑆) + (♯‘𝑇))))
2118, 20syl 14 . . 3 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))) Fn (0..^((♯‘𝑆) + (♯‘𝑇))))
22 0zd 9589 . . . 4 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → 0 ∈ ℤ)
2311adantr 276 . . . . . 6 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘𝑆) ∈ ℕ0)
2423nn0zd 9698 . . . . 5 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘𝑆) ∈ ℤ)
25 lencl 11228 . . . . . . 7 (𝑇 ∈ Word 𝐵 → (♯‘𝑇) ∈ ℕ0)
2625nn0zd 9698 . . . . . 6 (𝑇 ∈ Word 𝐵 → (♯‘𝑇) ∈ ℤ)
2726adantl 277 . . . . 5 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘𝑇) ∈ ℤ)
2824, 27zaddcld 9704 . . . 4 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → ((♯‘𝑆) + (♯‘𝑇)) ∈ ℤ)
29 fzofig 10794 . . . 4 ((0 ∈ ℤ ∧ ((♯‘𝑆) + (♯‘𝑇)) ∈ ℤ) → (0..^((♯‘𝑆) + (♯‘𝑇))) ∈ Fin)
3022, 28, 29syl2anc 411 . . 3 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (0..^((♯‘𝑆) + (♯‘𝑇))) ∈ Fin)
31 fihashfn 11164 . . 3 (((𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆))))) Fn (0..^((♯‘𝑆) + (♯‘𝑇))) ∧ (0..^((♯‘𝑆) + (♯‘𝑇))) ∈ Fin) → (♯‘(𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))))) = (♯‘(0..^((♯‘𝑆) + (♯‘𝑇)))))
3221, 30, 31syl2anc 411 . 2 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘(𝑥 ∈ (0..^((♯‘𝑆) + (♯‘𝑇))) ↦ if(𝑥 ∈ (0..^(♯‘𝑆)), (𝑆𝑥), (𝑇‘(𝑥 − (♯‘𝑆)))))) = (♯‘(0..^((♯‘𝑆) + (♯‘𝑇)))))
33 nn0addcl 9531 . . . 4 (((♯‘𝑆) ∈ ℕ0 ∧ (♯‘𝑇) ∈ ℕ0) → ((♯‘𝑆) + (♯‘𝑇)) ∈ ℕ0)
3411, 25, 33syl2an 289 . . 3 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → ((♯‘𝑆) + (♯‘𝑇)) ∈ ℕ0)
35 hashfzo0 11188 . . 3 (((♯‘𝑆) + (♯‘𝑇)) ∈ ℕ0 → (♯‘(0..^((♯‘𝑆) + (♯‘𝑇)))) = ((♯‘𝑆) + (♯‘𝑇)))
3634, 35syl 14 . 2 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘(0..^((♯‘𝑆) + (♯‘𝑇)))) = ((♯‘𝑆) + (♯‘𝑇)))
375, 32, 363eqtrd 2269 1 ((𝑆 ∈ Word 𝐴𝑇 ∈ Word 𝐵) → (♯‘(𝑆 ++ 𝑇)) = ((♯‘𝑆) + (♯‘𝑇)))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 104   = wceq 1398  wcel 2203  wral 2520  Vcvv 2813  ifcif 3620  cmpt 4171   Fn wfn 5347  cfv 5352  (class class class)co 6050  Fincfn 6975  0cc0 8127   + caddc 8130  cmin 8444  0cn0 9496  cz 9577  ..^cfzo 10476  chash 11138  Word cword 11224   ++ cconcat 11278
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 619  ax-in2 620  ax-io 717  ax-5 1496  ax-7 1497  ax-gen 1498  ax-ie1 1542  ax-ie2 1543  ax-8 1553  ax-10 1554  ax-11 1555  ax-i12 1556  ax-bndl 1558  ax-4 1559  ax-17 1575  ax-i9 1579  ax-ial 1583  ax-i5r 1584  ax-13 2205  ax-14 2206  ax-ext 2214  ax-coll 4225  ax-sep 4228  ax-nul 4236  ax-pow 4287  ax-pr 4322  ax-un 4554  ax-setind 4659  ax-iinf 4710  ax-cnex 8218  ax-resscn 8219  ax-1cn 8220  ax-1re 8221  ax-icn 8222  ax-addcl 8223  ax-addrcl 8224  ax-mulcl 8225  ax-addcom 8227  ax-addass 8229  ax-distr 8231  ax-i2m1 8232  ax-0lt1 8233  ax-0id 8235  ax-rnegex 8236  ax-cnre 8238  ax-pre-ltirr 8239  ax-pre-ltwlin 8240  ax-pre-lttrn 8241  ax-pre-apti 8242  ax-pre-ltadd 8243
This theorem depends on definitions:  df-bi 117  df-dc 843  df-3or 1006  df-3an 1007  df-tru 1401  df-fal 1404  df-nf 1510  df-sb 1812  df-eu 2083  df-mo 2084  df-clab 2219  df-cleq 2225  df-clel 2228  df-nfc 2373  df-ne 2413  df-nel 2508  df-ral 2525  df-rex 2526  df-reu 2527  df-rab 2529  df-v 2815  df-sbc 3043  df-csb 3139  df-dif 3213  df-un 3215  df-in 3217  df-ss 3224  df-nul 3509  df-if 3621  df-pw 3671  df-sn 3695  df-pr 3696  df-op 3698  df-uni 3915  df-int 3950  df-iun 3993  df-br 4110  df-opab 4172  df-mpt 4173  df-tr 4209  df-id 4414  df-iord 4487  df-on 4489  df-ilim 4490  df-suc 4492  df-iom 4713  df-xp 4755  df-rel 4756  df-cnv 4757  df-co 4758  df-dm 4759  df-rn 4760  df-res 4761  df-ima 4762  df-iota 5312  df-fun 5354  df-fn 5355  df-f 5356  df-f1 5357  df-fo 5358  df-f1o 5359  df-fv 5360  df-riota 6003  df-ov 6053  df-oprab 6054  df-mpo 6055  df-1st 6334  df-2nd 6335  df-recs 6536  df-frec 6622  df-1o 6647  df-er 6767  df-en 6976  df-dom 6977  df-fin 6978  df-pnf 8310  df-mnf 8311  df-xr 8312  df-ltxr 8313  df-le 8314  df-sub 8446  df-neg 8447  df-inn 9238  df-n0 9497  df-z 9578  df-uz 9854  df-fz 10343  df-fzo 10477  df-ihash 11139  df-word 11225  df-concat 11279
This theorem is referenced by:  ccat0  11284  elfzelfzccat  11288  ccatsymb  11290  ccatass  11296  lswccatn0lsw  11299  ccatws1leng  11322  ccatswrd  11362  swrdccat2  11363  ccatpfx  11393  pfxccat1  11394  lenrevpfxcctswrd  11404  ccatopth  11408  ccatopth2  11409  swrdccatfn  11416  swrdccatin2  11421  pfxccatin12lem2c  11422  cats1lend  11459  clwwlkccatlem  16395  clwwlknccat  16418
  Copyright terms: Public domain W3C validator