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

Theorem ccatcl 11169
Description: The concatenation of two words is a word. (Contributed by FL, 2-Feb-2014.) (Proof shortened by Stefan O'Rear, 15-Aug-2015.) (Proof shortened by AV, 29-Apr-2020.)
Assertion
Ref Expression
ccatcl  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( S ++  T )  e. Word  B )

Proof of Theorem ccatcl
Dummy variable  x is distinct from all other variables.
StepHypRef Expression
1 wrdfin 11131 . . 3  |-  ( S  e. Word  B  ->  S  e.  Fin )
2 wrdfin 11131 . . 3  |-  ( T  e. Word  B  ->  T  e.  Fin )
3 ccatfvalfi 11168 . . 3  |-  ( ( 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 . 2  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( S ++  T )  =  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) )
5 wrdf 11118 . . . . . . 7  |-  ( S  e. Word  B  ->  S : ( 0..^ ( `  S ) ) --> B )
65ad2antrr 488 . . . . . 6  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  S : ( 0..^ ( `  S
) ) --> B )
76ffvelcdmda 5782 . . . . 5  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  x  e.  ( 0..^ ( `  S
) ) )  -> 
( S `  x
)  e.  B )
8 wrdf 11118 . . . . . . 7  |-  ( T  e. Word  B  ->  T : ( 0..^ ( `  T ) ) --> B )
98ad3antlr 493 . . . . . 6  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  -.  x  e.  ( 0..^ ( `  S
) ) )  ->  T : ( 0..^ ( `  T ) ) --> B )
10 simpr 110 . . . . . . . 8  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )
1110anim1i 340 . . . . . . 7  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  -.  x  e.  ( 0..^ ( `  S
) ) )  -> 
( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  /\  -.  x  e.  (
0..^ ( `  S )
) ) )
12 lencl 11116 . . . . . . . . . 10  |-  ( S  e. Word  B  ->  ( `  S )  e.  NN0 )
1312nn0zd 9599 . . . . . . . . 9  |-  ( S  e. Word  B  ->  ( `  S )  e.  ZZ )
14 lencl 11116 . . . . . . . . . 10  |-  ( T  e. Word  B  ->  ( `  T )  e.  NN0 )
1514nn0zd 9599 . . . . . . . . 9  |-  ( T  e. Word  B  ->  ( `  T )  e.  ZZ )
1613, 15anim12i 338 . . . . . . . 8  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( ( `  S
)  e.  ZZ  /\  ( `  T )  e.  ZZ ) )
1716ad2antrr 488 . . . . . . 7  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  -.  x  e.  ( 0..^ ( `  S
) ) )  -> 
( ( `  S
)  e.  ZZ  /\  ( `  T )  e.  ZZ ) )
18 fzocatel 10443 . . . . . . 7  |-  ( ( ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  /\  -.  x  e.  (
0..^ ( `  S )
) )  /\  (
( `  S )  e.  ZZ  /\  ( `  T
)  e.  ZZ ) )  ->  ( x  -  ( `  S )
)  e.  ( 0..^ ( `  T )
) )
1911, 17, 18syl2anc 411 . . . . . 6  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  -.  x  e.  ( 0..^ ( `  S
) ) )  -> 
( x  -  ( `  S ) )  e.  ( 0..^ ( `  T
) ) )
209, 19ffvelcdmd 5783 . . . . 5  |-  ( ( ( ( S  e. Word  B  /\  T  e. Word  B
)  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  /\  -.  x  e.  ( 0..^ ( `  S
) ) )  -> 
( T `  (
x  -  ( `  S
) ) )  e.  B )
21 elfzoelz 10381 . . . . . . 7  |-  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T )
) )  ->  x  e.  ZZ )
2221adantl 277 . . . . . 6  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  x  e.  ZZ )
23 0zd 9490 . . . . . 6  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  0  e.  ZZ )
2413ad2antrr 488 . . . . . 6  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  ( `  S )  e.  ZZ )
25 fzodcel 10387 . . . . . 6  |-  ( ( x  e.  ZZ  /\  0  e.  ZZ  /\  ( `  S )  e.  ZZ )  -> DECID 
x  e.  ( 0..^ ( `  S )
) )
2622, 23, 24, 25syl3anc 1273 . . . . 5  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  -> DECID 
x  e.  ( 0..^ ( `  S )
) )
277, 20, 26ifcldadc 3635 . . . 4  |-  ( ( ( S  e. Word  B  /\  T  e. Word  B )  /\  x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) )  ->  if ( x  e.  ( 0..^ ( `  S ) ) ,  ( S `  x
) ,  ( T `
 ( x  -  ( `  S ) ) ) )  e.  B
)
2827fmpttd 5802 . . 3  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) : ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) --> B )
2912adantr 276 . . . 4  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( `  S )  e.  NN0 )
3014adantl 277 . . . 4  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( `  T )  e.  NN0 )
3129, 30nn0addcld 9458 . . 3  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( ( `  S
)  +  ( `  T
) )  e.  NN0 )
32 iswrdinn0 11117 . . 3  |-  ( ( ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) ) : ( 0..^ ( ( `  S
)  +  ( `  T
) ) ) --> B  /\  ( ( `  S
)  +  ( `  T
) )  e.  NN0 )  ->  ( x  e.  ( 0..^ ( ( `  S )  +  ( `  T ) ) ) 
|->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) )  e. Word  B
)
3328, 31, 32syl2anc 411 . 2  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( x  e.  ( 0..^ ( ( `  S
)  +  ( `  T
) ) )  |->  if ( x  e.  ( 0..^ ( `  S
) ) ,  ( S `  x ) ,  ( T `  ( x  -  ( `  S ) ) ) ) )  e. Word  B
)
344, 33eqeltrd 2308 1  |-  ( ( S  e. Word  B  /\  T  e. Word  B )  ->  ( S ++  T )  e. Word  B )
Colors of variables: wff set class
Syntax hints:   -. wn 3    -> wi 4    /\ wa 104  DECID wdc 841    = wceq 1397    e. wcel 2202   ifcif 3605    |-> cmpt 4150   -->wf 5322   ` cfv 5326  (class class class)co 6017   Fincfn 6908   0cc0 8031    + caddc 8034    - cmin 8349   NN0cn0 9401   ZZcz 9478  ..^cfzo 10376  ♯chash 11036  Word cword 11112   ++ cconcat 11166
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 716  ax-5 1495  ax-7 1496  ax-gen 1497  ax-ie1 1541  ax-ie2 1542  ax-8 1552  ax-10 1553  ax-11 1554  ax-i12 1555  ax-bndl 1557  ax-4 1558  ax-17 1574  ax-i9 1578  ax-ial 1582  ax-i5r 1583  ax-13 2204  ax-14 2205  ax-ext 2213  ax-coll 4204  ax-sep 4207  ax-nul 4215  ax-pow 4264  ax-pr 4299  ax-un 4530  ax-setind 4635  ax-iinf 4686  ax-cnex 8122  ax-resscn 8123  ax-1cn 8124  ax-1re 8125  ax-icn 8126  ax-addcl 8127  ax-addrcl 8128  ax-mulcl 8129  ax-addcom 8131  ax-addass 8133  ax-distr 8135  ax-i2m1 8136  ax-0lt1 8137  ax-0id 8139  ax-rnegex 8140  ax-cnre 8142  ax-pre-ltirr 8143  ax-pre-ltwlin 8144  ax-pre-lttrn 8145  ax-pre-apti 8146  ax-pre-ltadd 8147
This theorem depends on definitions:  df-bi 117  df-dc 842  df-3or 1005  df-3an 1006  df-tru 1400  df-fal 1403  df-nf 1509  df-sb 1811  df-eu 2082  df-mo 2083  df-clab 2218  df-cleq 2224  df-clel 2227  df-nfc 2363  df-ne 2403  df-nel 2498  df-ral 2515  df-rex 2516  df-reu 2517  df-rab 2519  df-v 2804  df-sbc 3032  df-csb 3128  df-dif 3202  df-un 3204  df-in 3206  df-ss 3213  df-nul 3495  df-if 3606  df-pw 3654  df-sn 3675  df-pr 3676  df-op 3678  df-uni 3894  df-int 3929  df-iun 3972  df-br 4089  df-opab 4151  df-mpt 4152  df-tr 4188  df-id 4390  df-iord 4463  df-on 4465  df-ilim 4466  df-suc 4468  df-iom 4689  df-xp 4731  df-rel 4732  df-cnv 4733  df-co 4734  df-dm 4735  df-rn 4736  df-res 4737  df-ima 4738  df-iota 5286  df-fun 5328  df-fn 5329  df-f 5330  df-f1 5331  df-fo 5332  df-f1o 5333  df-fv 5334  df-riota 5970  df-ov 6020  df-oprab 6021  df-mpo 6022  df-1st 6302  df-2nd 6303  df-recs 6470  df-frec 6556  df-1o 6581  df-er 6701  df-en 6909  df-dom 6910  df-fin 6911  df-pnf 8215  df-mnf 8216  df-xr 8217  df-ltxr 8218  df-le 8219  df-sub 8351  df-neg 8352  df-inn 9143  df-n0 9402  df-z 9479  df-uz 9755  df-fz 10243  df-fzo 10377  df-ihash 11037  df-word 11113  df-concat 11167
This theorem is referenced by:  ccatclab  11170  ccatsymb  11178  ccatass  11184  lswccatn0lsw  11187  ccatalpha  11189  ccatws1cl  11208  ccatswrd  11250  swrdccat2  11251  ccatpfx  11281  pfxccat1  11282  swrdccatfn  11304  swrdccatin1  11305  swrdccatin2  11309  pfxccatin12lem2c  11310  pfxccatpfx1  11316  pfxccatpfx2  11317  cats1cld  11343  cats2catd  11349  clwwlkccat  16251
  Copyright terms: Public domain W3C validator