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

Theorem ccatlen 11138
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  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  ( S ++  T ) )  =  ( ( `  S
)  +  ( `  T
) ) )

Proof of Theorem ccatlen
Dummy variable  x is distinct from all other variables.
StepHypRef Expression
1 wrdfin 11098 . . . 4  |-  ( S  e. Word  A  ->  S  e.  Fin )
2 wrdfin 11098 . . . 4  |-  ( T  e. Word  B  ->  T  e.  Fin )
3 ccatfvalfi 11135 . . . 4  |-  ( ( S  e.  Fin  /\  T  e.  Fin )  ->  ( S ++  T )  =  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) )
41, 2, 3syl2an 289 . . 3  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( S ++  T )  =  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) )
54fveq2d 5633 . 2  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  ( S ++  T ) )  =  ( `  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) ) )
6 fvexg 5648 . . . . . . 7  |-  ( ( S  e. Word  A  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( S `  x )  e.  _V )
76adantlr 477 . . . . . 6  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( S `  x )  e.  _V )
8 simplr 528 . . . . . . 7  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  T  e. Word  B
)
9 elfzoelz 10351 . . . . . . . . 9  |-  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T )
) )  ->  x  e.  ZZ )
109adantl 277 . . . . . . . 8  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  x  e.  ZZ )
11 lencl 11083 . . . . . . . . . 10  |-  ( S  e. Word  A  ->  ( `  S )  e.  NN0 )
1211ad2antrr 488 . . . . . . . . 9  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( `  S )  e.  NN0 )
1312nn0zd 9575 . . . . . . . 8  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( `  S )  e.  ZZ )
1410, 13zsubcld 9582 . . . . . . 7  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( x  -  ( `  S ) )  e.  ZZ )
15 fvexg 5648 . . . . . . 7  |-  ( ( T  e. Word  B  /\  ( x  -  ( `  S ) )  e.  ZZ )  ->  ( T `  ( x  -  ( `  S )
) )  e.  _V )
168, 14, 15syl2anc 411 . . . . . 6  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( T `  ( x  -  ( `  S ) ) )  e.  _V )
177, 16ifexd 4575 . . . . 5  |-  ( ( ( S  e. Word  A  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  if ( x  e.  ( 0..^ ( `  S ) ) ,  ( S `  x
) ,  ( T `
 ( x  -  ( `  S ) ) ) )  e.  _V )
1817ralrimiva 2603 . . . 4  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  A. x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) )  e.  _V )
19 eqid 2229 . . . . 5  |-  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T )
) )  |->  if ( x  e.  ( 0..^ ( `  S )
) ,  ( S `
 x ) ,  ( T `  (
x  -  ( `  S
) ) ) ) )  =  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T )
) )  |->  if ( x  e.  ( 0..^ ( `  S )
) ,  ( S `
 x ) ,  ( T `  (
x  -  ( `  S
) ) ) ) )
2019fnmpt 5450 . . . 4  |-  ( A. x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) )  e.  _V  ->  ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) )  Fn  (
0..^ ( ( `  S
)  +  ( `  T
) ) ) )
2118, 20syl 14 . . 3  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) )  Fn  (
0..^ ( ( `  S
)  +  ( `  T
) ) ) )
22 0zd 9466 . . . 4  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  0  e.  ZZ )
2311adantr 276 . . . . . 6  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  S )  e.  NN0 )
2423nn0zd 9575 . . . . 5  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  S )  e.  ZZ )
25 lencl 11083 . . . . . . 7  |-  ( T  e. Word  B  ->  ( `  T )  e.  NN0 )
2625nn0zd 9575 . . . . . 6  |-  ( T  e. Word  B  ->  ( `  T )  e.  ZZ )
2726adantl 277 . . . . 5  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  T )  e.  ZZ )
2824, 27zaddcld 9581 . . . 4  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( ( `  S
)  +  ( `  T
) )  e.  ZZ )
29 fzofig 10662 . . . 4  |-  ( ( 0  e.  ZZ  /\  ( ( `  S )  +  ( `  T )
)  e.  ZZ )  ->  ( 0..^ ( ( `  S )  +  ( `  T )
) )  e.  Fin )
3022, 28, 29syl2anc 411 . . 3  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( 0..^ ( ( `  S )  +  ( `  T ) ) )  e.  Fin )
31 fihashfn 11030 . . 3  |-  ( ( ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) )  Fn  (
0..^ ( ( `  S
)  +  ( `  T
) ) )  /\  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  e. 
Fin )  ->  ( `  ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) )  =  ( `  ( 0..^ ( ( `  S )  +  ( `  T )
) ) ) )
3221, 30, 31syl2anc 411 . 2  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) )  =  ( `  ( 0..^ ( ( `  S )  +  ( `  T )
) ) ) )
33 nn0addcl 9412 . . . 4  |-  ( ( ( `  S )  e.  NN0  /\  ( `  T
)  e.  NN0 )  ->  ( ( `  S
)  +  ( `  T
) )  e.  NN0 )
3411, 25, 33syl2an 289 . . 3  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( ( `  S
)  +  ( `  T
) )  e.  NN0 )
35 hashfzo0 11053 . . 3  |-  ( ( ( `  S )  +  ( `  T )
)  e.  NN0  ->  ( `  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) )  =  ( ( `  S )  +  ( `  T ) ) )
3634, 35syl 14 . 2  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  ( 0..^ ( ( `  S )  +  ( `  T )
) ) )  =  ( ( `  S
)  +  ( `  T
) ) )
375, 32, 363eqtrd 2266 1  |-  ( ( S  e. Word  A  /\  T  e. Word  B )  ->  ( `  ( S ++  T ) )  =  ( ( `  S
)  +  ( `  T
) ) )
Colors of variables: wff set class
Syntax hints:    -> wi 4    /\ wa 104    = wceq 1395    e. wcel 2200   A.wral 2508   _Vcvv 2799   ifcif 3602    |-> cmpt 4145    Fn wfn 5313   ` cfv 5318  (class class class)co 6007   Fincfn 6895   0cc0 8007    + caddc 8010    - cmin 8325   NN0cn0 9377   ZZcz 9454  ..^cfzo 10346  ♯chash 11005  Word cword 11079   ++ cconcat 11133
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 617  ax-in2 618  ax-io 714  ax-5 1493  ax-7 1494  ax-gen 1495  ax-ie1 1539  ax-ie2 1540  ax-8 1550  ax-10 1551  ax-11 1552  ax-i12 1553  ax-bndl 1555  ax-4 1556  ax-17 1572  ax-i9 1576  ax-ial 1580  ax-i5r 1581  ax-13 2202  ax-14 2203  ax-ext 2211  ax-coll 4199  ax-sep 4202  ax-nul 4210  ax-pow 4258  ax-pr 4293  ax-un 4524  ax-setind 4629  ax-iinf 4680  ax-cnex 8098  ax-resscn 8099  ax-1cn 8100  ax-1re 8101  ax-icn 8102  ax-addcl 8103  ax-addrcl 8104  ax-mulcl 8105  ax-addcom 8107  ax-addass 8109  ax-distr 8111  ax-i2m1 8112  ax-0lt1 8113  ax-0id 8115  ax-rnegex 8116  ax-cnre 8118  ax-pre-ltirr 8119  ax-pre-ltwlin 8120  ax-pre-lttrn 8121  ax-pre-apti 8122  ax-pre-ltadd 8123
This theorem depends on definitions:  df-bi 117  df-dc 840  df-3or 1003  df-3an 1004  df-tru 1398  df-fal 1401  df-nf 1507  df-sb 1809  df-eu 2080  df-mo 2081  df-clab 2216  df-cleq 2222  df-clel 2225  df-nfc 2361  df-ne 2401  df-nel 2496  df-ral 2513  df-rex 2514  df-reu 2515  df-rab 2517  df-v 2801  df-sbc 3029  df-csb 3125  df-dif 3199  df-un 3201  df-in 3203  df-ss 3210  df-nul 3492  df-if 3603  df-pw 3651  df-sn 3672  df-pr 3673  df-op 3675  df-uni 3889  df-int 3924  df-iun 3967  df-br 4084  df-opab 4146  df-mpt 4147  df-tr 4183  df-id 4384  df-iord 4457  df-on 4459  df-ilim 4460  df-suc 4462  df-iom 4683  df-xp 4725  df-rel 4726  df-cnv 4727  df-co 4728  df-dm 4729  df-rn 4730  df-res 4731  df-ima 4732  df-iota 5278  df-fun 5320  df-fn 5321  df-f 5322  df-f1 5323  df-fo 5324  df-f1o 5325  df-fv 5326  df-riota 5960  df-ov 6010  df-oprab 6011  df-mpo 6012  df-1st 6292  df-2nd 6293  df-recs 6457  df-frec 6543  df-1o 6568  df-er 6688  df-en 6896  df-dom 6897  df-fin 6898  df-pnf 8191  df-mnf 8192  df-xr 8193  df-ltxr 8194  df-le 8195  df-sub 8327  df-neg 8328  df-inn 9119  df-n0 9378  df-z 9455  df-uz 9731  df-fz 10213  df-fzo 10347  df-ihash 11006  df-word 11080  df-concat 11134
This theorem is referenced by:  ccat0  11139  elfzelfzccat  11143  ccatsymb  11145  ccatass  11151  lswccatn0lsw  11154  ccatws1leng  11175  ccatswrd  11210  swrdccat2  11211  ccatpfx  11241  pfxccat1  11242  lenrevpfxcctswrd  11252  ccatopth  11256  ccatopth2  11257  swrdccatfn  11264  swrdccatin2  11269  pfxccatin12lem2c  11270  cats1lend  11307
  Copyright terms: Public domain W3C validator