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

Theorem eucrctshift 27103
Description: Cyclically shifting the indices of an Eulerian circuit 
<. F ,  P >. results in an Eulerian circuit  <. H ,  Q >.. (Contributed by AV, 15-Mar-2021.) (Proof shortened by AV, 30-Oct-2021.)
Hypotheses
Ref Expression
eucrctshift.v  |-  V  =  (Vtx `  G )
eucrctshift.i  |-  I  =  (iEdg `  G )
eucrctshift.c  |-  ( ph  ->  F (Circuits `  G
) P )
eucrctshift.n  |-  N  =  ( # `  F
)
eucrctshift.s  |-  ( ph  ->  S  e.  ( 0..^ N ) )
eucrctshift.h  |-  H  =  ( F cyclShift  S )
eucrctshift.q  |-  Q  =  ( x  e.  ( 0 ... N ) 
|->  if ( x  <_ 
( N  -  S
) ,  ( P `
 ( x  +  S ) ) ,  ( P `  (
( x  +  S
)  -  N ) ) ) )
eucrctshift.e  |-  ( ph  ->  F (EulerPaths `  G
) P )
Assertion
Ref Expression
eucrctshift  |-  ( ph  ->  ( H (EulerPaths `  G
) Q  /\  H
(Circuits `  G ) Q ) )
Distinct variable groups:    x, F    x, H    x, I    x, N    x, P    x, S    x, V    ph, x
Allowed substitution hints:    Q( x)    G( x)

Proof of Theorem eucrctshift
Dummy variables  i 
y  z are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 eucrctshift.v . . . . 5  |-  V  =  (Vtx `  G )
2 eucrctshift.i . . . . 5  |-  I  =  (iEdg `  G )
3 eucrctshift.c . . . . 5  |-  ( ph  ->  F (Circuits `  G
) P )
4 eucrctshift.n . . . . 5  |-  N  =  ( # `  F
)
5 eucrctshift.s . . . . 5  |-  ( ph  ->  S  e.  ( 0..^ N ) )
6 eucrctshift.h . . . . 5  |-  H  =  ( F cyclShift  S )
7 eucrctshift.q . . . . 5  |-  Q  =  ( x  e.  ( 0 ... N ) 
|->  if ( x  <_ 
( N  -  S
) ,  ( P `
 ( x  +  S ) ) ,  ( P `  (
( x  +  S
)  -  N ) ) ) )
81, 2, 3, 4, 5, 6, 7crctcshtrl 26715 . . . 4  |-  ( ph  ->  H (Trails `  G
) Q )
9 simpr 477 . . . . 5  |-  ( (
ph  /\  H (Trails `  G ) Q )  ->  H (Trails `  G ) Q )
10 eucrctshift.e . . . . . . . 8  |-  ( ph  ->  F (EulerPaths `  G
) P )
112eupthf1o 27064 . . . . . . . 8  |-  ( F (EulerPaths `  G ) P  ->  F : ( 0..^ ( # `  F
) ) -1-1-onto-> dom  I )
1210, 11syl 17 . . . . . . 7  |-  ( ph  ->  F : ( 0..^ ( # `  F
) ) -1-1-onto-> dom  I )
1312adantr 481 . . . . . 6  |-  ( (
ph  /\  H (Trails `  G ) Q )  ->  F : ( 0..^ ( # `  F
) ) -1-1-onto-> dom  I )
14 trliswlk 26594 . . . . . . . . 9  |-  ( H (Trails `  G ) Q  ->  H (Walks `  G ) Q )
152wlkf 26510 . . . . . . . . 9  |-  ( H (Walks `  G ) Q  ->  H  e. Word  dom  I )
16 wrdf 13310 . . . . . . . . 9  |-  ( H  e. Word  dom  I  ->  H : ( 0..^ (
# `  H )
) --> dom  I )
1714, 15, 163syl 18 . . . . . . . 8  |-  ( H (Trails `  G ) Q  ->  H : ( 0..^ ( # `  H
) ) --> dom  I
)
18 df-f1o 5895 . . . . . . . . . 10  |-  ( F : ( 0..^ (
# `  F )
)
-1-1-onto-> dom  I  <->  ( F :
( 0..^ ( # `  F ) ) -1-1-> dom  I  /\  F : ( 0..^ ( # `  F
) ) -onto-> dom  I
) )
19 dffo3 6374 . . . . . . . . . . 11  |-  ( F : ( 0..^ (
# `  F )
) -onto-> dom  I  <->  ( F : ( 0..^ (
# `  F )
) --> dom  I  /\  A. i  e.  dom  I E. y  e.  (
0..^ ( # `  F
) ) i  =  ( F `  y
) ) )
20 crctiswlk 26691 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( F (Circuits `  G ) P  ->  F (Walks `  G ) P )
212wlkf 26510 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( F (Walks `  G ) P  ->  F  e. Word  dom  I )
22 lencl 13324 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( F  e. Word  dom  I  ->  (
# `  F )  e.  NN0 )
234oveq2i 6661 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( 0..^ N )  =  ( 0..^ ( # `  F
) )
2423eleq2i 2693 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( S  e.  ( 0..^ N )  <->  S  e.  (
0..^ ( # `  F
) ) )
25 elfzonn0 12512 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  S  e.  NN0 )
2625adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  ->  S  e.  NN0 )
27 elfzonn0 12512 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  y  e.  NN0 )
28 nn0sub 11343 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( S  e.  NN0  /\  y  e.  NN0 )  -> 
( S  <_  y  <->  ( y  -  S )  e.  NN0 ) )
2926, 27, 28syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( S  <_  y  <->  ( y  -  S )  e.  NN0 ) )
3029biimpac 503 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  -  S )  e.  NN0 )
31 elfzo0 12508 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( y  e.  ( 0..^ (
# `  F )
)  <->  ( y  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) ) )
32 simp2 1062 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  ( # `
 F )  e.  NN )
3331, 32sylbi 207 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  ( # `  F
)  e.  NN )
3433ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( # `  F
)  e.  NN )
35 nn0re 11301 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( y  e.  NN0  ->  y  e.  RR )
3635ad2antrr 762 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
y  e.  RR )
37 nnre 11027 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( (
# `  F )  e.  NN  ->  ( # `  F
)  e.  RR )
3837adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN )  -> 
( # `  F )  e.  RR )
3938adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( # `  F )  e.  RR )
40 elfzoelz 12470 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  S  e.  ZZ )
4140zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  S  e.  RR )
42 readdcl 10019 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( ( # `  F
)  e.  RR  /\  S  e.  RR )  ->  ( ( # `  F
)  +  S )  e.  RR )
4338, 41, 42syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( ( # `  F
)  +  S )  e.  RR )
4436, 39, 433jca 1242 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( y  e.  RR  /\  ( # `  F
)  e.  RR  /\  ( ( # `  F
)  +  S )  e.  RR ) )
45 elfzole1 12478 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  0  <_  S )
4645adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
0  <_  S )
47 addge01 10538 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( ( # `  F
)  e.  RR  /\  S  e.  RR )  ->  ( 0  <_  S  <->  (
# `  F )  <_  ( ( # `  F
)  +  S ) ) )
4838, 41, 47syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( 0  <_  S  <->  (
# `  F )  <_  ( ( # `  F
)  +  S ) ) )
4946, 48mpbid 222 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( # `  F )  <_  ( ( # `  F )  +  S
) )
5044, 49lelttrdi 10199 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN )  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( y  <  ( # `
 F )  -> 
y  <  ( ( # `
 F )  +  S ) ) )
5150ex 450 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN )  -> 
( S  e.  ( 0..^ ( # `  F
) )  ->  (
y  <  ( # `  F
)  ->  y  <  ( ( # `  F
)  +  S ) ) ) )
5251com23 86 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN )  -> 
( y  <  ( # `
 F )  -> 
( S  e.  ( 0..^ ( # `  F
) )  ->  y  <  ( ( # `  F
)  +  S ) ) ) )
53523impia 1261 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  ( S  e.  ( 0..^ ( # `  F
) )  ->  y  <  ( ( # `  F
)  +  S ) ) )
5453adantld 483 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  (
( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
y  <  ( ( # `
 F )  +  S ) ) )
5554imp 445 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  y  <  ( ( # `  F
)  +  S ) )
56353ad2ant1 1082 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  y  e.  RR )
5756adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  y  e.  RR )
5841ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  S  e.  RR )
59 elfzoel2 12469 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  ( # `  F
)  e.  ZZ )
6059zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  ( # `  F
)  e.  RR )
6160ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  ( # `  F
)  e.  RR )
6257, 58, 61ltsubaddd 10623 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  ( (
y  -  S )  <  ( # `  F
)  <->  y  <  (
( # `  F )  +  S ) ) )
6355, 62mpbird 247 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( ( y  e.  NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) )  /\  (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) ) )  ->  ( y  -  S )  <  ( # `
 F ) )
6463ex 450 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  (
( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( y  -  S
)  <  ( # `  F
) ) )
6531, 64sylbi 207 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  ( (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) )  ->  ( y  -  S )  <  ( # `
 F ) ) )
6665impcom 446 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( y  -  S
)  <  ( # `  F
) )
6766adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  -  S )  <  ( # `
 F ) )
68 elfzo0 12508 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( y  -  S )  e.  ( 0..^ (
# `  F )
)  <->  ( ( y  -  S )  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  ( y  -  S
)  <  ( # `  F
) ) )
6930, 34, 67, 68syl3anbrc 1246 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  -  S )  e.  ( 0..^ ( # `  F
) ) )
70 oveq1 6657 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( z  =  ( y  -  S )  ->  (
z  +  S )  =  ( ( y  -  S )  +  S ) )
7170oveq1d 6665 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( z  =  ( y  -  S )  ->  (
( z  +  S
)  mod  ( # `  F
) )  =  ( ( ( y  -  S )  +  S
)  mod  ( # `  F
) ) )
7240zcnd 11483 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( S  e.  ( 0..^ (
# `  F )
)  ->  S  e.  CC )
7372adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  ->  S  e.  CC )
74 elfzoelz 12470 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  y  e.  ZZ )
7574zcnd 11483 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  y  e.  CC )
7673, 75anim12ci 591 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( y  e.  CC  /\  S  e.  CC ) )
7776adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  e.  CC  /\  S  e.  CC ) )
78 npcan 10290 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( y  e.  CC  /\  S  e.  CC )  ->  ( ( y  -  S )  +  S
)  =  y )
7977, 78syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( y  -  S )  +  S )  =  y )
8079oveq1d 6665 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( y  -  S )  +  S )  mod  ( # `  F
) )  =  ( y  mod  ( # `  F ) ) )
81 zmodidfzoimp 12700 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  ( y  mod  ( # `  F
) )  =  y )
8281ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  mod  ( # `  F
) )  =  y )
8380, 82eqtrd 2656 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( y  -  S )  +  S )  mod  ( # `  F
) )  =  y )
8471, 83sylan9eqr 2678 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  /\  z  =  ( y  -  S ) )  ->  ( (
z  +  S )  mod  ( # `  F
) )  =  y )
8584eqcomd 2628 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  /\  z  =  ( y  -  S ) )  ->  y  =  ( ( z  +  S )  mod  ( # `
 F ) ) )
8669, 85rspcedeq2vd 3319 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( ( S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  E. z  e.  ( 0..^ ( # `  F
) ) y  =  ( ( z  +  S )  mod  ( # `
 F ) ) )
87 elfzo0 12508 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( S  e.  ( 0..^ (
# `  F )
)  <->  ( S  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )
88 nn0cn 11302 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( y  e.  NN0  ->  y  e.  CC )
8988ad2antrr 762 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
y  e.  CC )
90 nn0cn 11302 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( S  e.  NN0  ->  S  e.  CC )
91903ad2ant1 1082 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F
) )  ->  S  e.  CC )
9291adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  ->  S  e.  CC )
93 nncn 11028 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( (
# `  F )  e.  NN  ->  ( # `  F
)  e.  CC )
94933ad2ant2 1083 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F
) )  ->  ( # `
 F )  e.  CC )
9594adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( # `  F )  e.  CC )
9689, 92, 95subadd23d 10414 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( y  -  S )  +  (
# `  F )
)  =  ( y  +  ( ( # `  F )  -  S
) ) )
97 simpll 790 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
y  e.  NN0 )
98 nn0z 11400 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49  |-  ( S  e.  NN0  ->  S  e.  ZZ )
99 nnz 11399 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49  |-  ( (
# `  F )  e.  NN  ->  ( # `  F
)  e.  ZZ )
100 znnsub 11423 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49  |-  ( ( S  e.  ZZ  /\  ( # `  F )  e.  ZZ )  -> 
( S  <  ( # `
 F )  <->  ( ( # `
 F )  -  S )  e.  NN ) )
10198, 99, 100syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN )  -> 
( S  <  ( # `
 F )  <->  ( ( # `
 F )  -  S )  e.  NN ) )
102101biimp3a 1432 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F
) )  ->  (
( # `  F )  -  S )  e.  NN )
103102adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( # `  F
)  -  S )  e.  NN )
104103nnnn0d 11351 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( # `  F
)  -  S )  e.  NN0 )
10597, 104nn0addcld 11355 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( y  +  ( ( # `  F
)  -  S ) )  e.  NN0 )
10696, 105eqeltrd 2701 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( y  -  S )  +  (
# `  F )
)  e.  NN0 )
107106adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( y  -  S
)  +  ( # `  F ) )  e. 
NN0 )
108 simplr2 1104 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  ( # `
 F )  e.  NN )
10988adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( y  e.  NN0  /\  y  <  ( # `  F
) )  ->  y  e.  CC )
110 subcl 10280 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( y  e.  CC  /\  S  e.  CC )  ->  ( y  -  S
)  e.  CC )
111109, 91, 110syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( y  -  S
)  e.  CC )
11295, 111jca 554 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( # `  F
)  e.  CC  /\  ( y  -  S
)  e.  CC ) )
113112adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( # `  F )  e.  CC  /\  (
y  -  S )  e.  CC ) )
114 addcom 10222 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( # `  F
)  e.  CC  /\  ( y  -  S
)  e.  CC )  ->  ( ( # `  F )  +  ( y  -  S ) )  =  ( ( y  -  S )  +  ( # `  F
) ) )
115113, 114syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( # `  F )  +  ( y  -  S ) )  =  ( ( y  -  S )  +  (
# `  F )
) )
11635adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( y  e.  NN0  /\  y  <  ( # `  F
) )  ->  y  e.  RR )
117 nn0re 11301 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( S  e.  NN0  ->  S  e.  RR )
1181173ad2ant1 1082 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F
) )  ->  S  e.  RR )
119 ltnle 10117 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  ( y  <  S  <->  -.  S  <_  y )
)
120 simpl 473 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  y  e.  RR )
121 simpr 477 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  S  e.  RR )
122120, 121sublt0d 10653 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  ( ( y  -  S )  <  0  <->  y  <  S ) )
123122biimprd 238 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  ( y  <  S  ->  ( y  -  S
)  <  0 ) )
124119, 123sylbird 250 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  ( -.  S  <_ 
y  ->  ( y  -  S )  <  0
) )
125116, 118, 124syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( -.  S  <_ 
y  ->  ( y  -  S )  <  0
) )
126125imp 445 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
y  -  S )  <  0 )
127 resubcl 10345 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( ( y  e.  RR  /\  S  e.  RR )  ->  ( y  -  S
)  e.  RR )
128116, 118, 127syl2an 494 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( y  -  S
)  e.  RR )
129373ad2ant2 1083 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48  |-  ( ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F
) )  ->  ( # `
 F )  e.  RR )
130129adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( # `  F )  e.  RR )
131128, 130jca 554 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46  |-  ( ( ( y  e.  NN0  /\  y  <  ( # `  F ) )  /\  ( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) ) )  -> 
( ( y  -  S )  e.  RR  /\  ( # `  F
)  e.  RR ) )
132131adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( y  -  S
)  e.  RR  /\  ( # `  F )  e.  RR ) )
133 ltaddneg 10251 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45  |-  ( ( ( y  -  S
)  e.  RR  /\  ( # `  F )  e.  RR )  -> 
( ( y  -  S )  <  0  <->  ( ( # `  F
)  +  ( y  -  S ) )  <  ( # `  F
) ) )
134132, 133syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( y  -  S
)  <  0  <->  ( ( # `
 F )  +  ( y  -  S
) )  <  ( # `
 F ) ) )
135126, 134mpbid 222 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( # `  F )  +  ( y  -  S ) )  < 
( # `  F ) )
136115, 135eqbrtrrd 4677 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( y  -  S
)  +  ( # `  F ) )  < 
( # `  F ) )
137107, 108, 1363jca 1242 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( ( ( ( y  e. 
NN0  /\  y  <  (
# `  F )
)  /\  ( S  e.  NN0  /\  ( # `  F )  e.  NN  /\  S  <  ( # `  F ) ) )  /\  -.  S  <_ 
y )  ->  (
( ( y  -  S )  +  (
# `  F )
)  e.  NN0  /\  ( # `  F )  e.  NN  /\  (
( y  -  S
)  +  ( # `  F ) )  < 
( # `  F ) ) )
138137exp31 630 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( y  e.  NN0  /\  y  <  ( # `  F
) )  ->  (
( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) )  ->  ( -.  S  <_  y  -> 
( ( ( y  -  S )  +  ( # `  F
) )  e.  NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) ) )
1391383adant2 1080 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  (
( S  e.  NN0  /\  ( # `  F
)  e.  NN  /\  S  <  ( # `  F
) )  ->  ( -.  S  <_  y  -> 
( ( ( y  -  S )  +  ( # `  F
) )  e.  NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) ) )
14087, 139syl5bi 232 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  ( S  e.  ( 0..^ ( # `  F
) )  ->  ( -.  S  <_  y  -> 
( ( ( y  -  S )  +  ( # `  F
) )  e.  NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) ) )
141140adantld 483 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  (
( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  -> 
( -.  S  <_ 
y  ->  ( (
( y  -  S
)  +  ( # `  F ) )  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) ) )
14231, 141sylbi 207 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  ( (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) )  ->  ( -.  S  <_  y  ->  ( (
( y  -  S
)  +  ( # `  F ) )  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) ) )
143142impcom 446 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( -.  S  <_ 
y  ->  ( (
( y  -  S
)  +  ( # `  F ) )  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) ) )
144143impcom 446 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( y  -  S )  +  ( # `  F
) )  e.  NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) )
145 elfzo0 12508 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( ( y  -  S
)  +  ( # `  F ) )  e.  ( 0..^ ( # `  F ) )  <->  ( (
( y  -  S
)  +  ( # `  F ) )  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  ( ( y  -  S )  +  (
# `  F )
)  <  ( # `  F
) ) )
146144, 145sylibr 224 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( y  -  S )  +  ( # `  F
) )  e.  ( 0..^ ( # `  F
) ) )
147 oveq1 6657 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( z  =  ( ( y  -  S )  +  ( # `  F
) )  ->  (
z  +  S )  =  ( ( ( y  -  S )  +  ( # `  F
) )  +  S
) )
148147oveq1d 6665 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( z  =  ( ( y  -  S )  +  ( # `  F
) )  ->  (
( z  +  S
)  mod  ( # `  F
) )  =  ( ( ( ( y  -  S )  +  ( # `  F
) )  +  S
)  mod  ( # `  F
) ) )
14973adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  ->  S  e.  CC )
15075adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
y  e.  CC )
151 nn0cn 11302 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41  |-  ( (
# `  F )  e.  NN0  ->  ( # `  F
)  e.  CC )
152151ad2antrr 762 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( # `  F )  e.  CC )
153149, 150, 1523jca 1242 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( S  e.  CC  /\  y  e.  CC  /\  ( # `  F )  e.  CC ) )
154153adantl 482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( S  e.  CC  /\  y  e.  CC  /\  ( # `  F )  e.  CC ) )
155 simp2 1062 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( S  e.  CC  /\  y  e.  CC  /\  ( # `
 F )  e.  CC )  ->  y  e.  CC )
156 simp3 1063 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( S  e.  CC  /\  y  e.  CC  /\  ( # `
 F )  e.  CC )  ->  ( # `
 F )  e.  CC )
157 simp1 1061 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40  |-  ( ( S  e.  CC  /\  y  e.  CC  /\  ( # `
 F )  e.  CC )  ->  S  e.  CC )
158155, 157, 156nppcand 10417 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39  |-  ( ( S  e.  CC  /\  y  e.  CC  /\  ( # `
 F )  e.  CC )  ->  (
( ( y  -  S )  +  (
# `  F )
)  +  S )  =  ( y  +  ( # `  F
) ) )
159155, 156, 158comraddd 10250 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( ( S  e.  CC  /\  y  e.  CC  /\  ( # `
 F )  e.  CC )  ->  (
( ( y  -  S )  +  (
# `  F )
)  +  S )  =  ( ( # `  F )  +  y ) )
160154, 159syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( y  -  S )  +  ( # `  F
) )  +  S
)  =  ( (
# `  F )  +  y ) )
161160oveq1d 6665 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( ( y  -  S
)  +  ( # `  F ) )  +  S )  mod  ( # `
 F ) )  =  ( ( (
# `  F )  +  y )  mod  ( # `  F
) ) )
16231biimpi 206 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38  |-  ( y  e.  ( 0..^ (
# `  F )
)  ->  ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F ) ) )
163162ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( y  e. 
NN0  /\  ( # `  F
)  e.  NN  /\  y  <  ( # `  F
) ) )
164 addmodid 12718 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37  |-  ( ( y  e.  NN0  /\  ( # `  F )  e.  NN  /\  y  <  ( # `  F
) )  ->  (
( ( # `  F
)  +  y )  mod  ( # `  F
) )  =  y )
165163, 164syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( (
# `  F )  +  y )  mod  ( # `  F
) )  =  y )
166161, 165eqtrd 2656 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  ( ( ( ( y  -  S
)  +  ( # `  F ) )  +  S )  mod  ( # `
 F ) )  =  y )
167148, 166sylan9eqr 2678 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34  |-  ( ( ( -.  S  <_ 
y  /\  ( (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  /\  z  =  ( ( y  -  S
)  +  ( # `  F ) ) )  ->  ( ( z  +  S )  mod  ( # `  F
) )  =  y )
168167eqcomd 2628 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( ( ( -.  S  <_ 
y  /\  ( (
( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F ) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  /\  z  =  ( ( y  -  S
)  +  ( # `  F ) ) )  ->  y  =  ( ( z  +  S
)  mod  ( # `  F
) ) )
169146, 168rspcedeq2vd 3319 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( ( -.  S  <_  y  /\  ( ( ( # `  F )  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) ) )  ->  E. z  e.  ( 0..^ ( # `  F
) ) y  =  ( ( z  +  S )  mod  ( # `
 F ) ) )
17086, 169pm2.61ian 831 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  ->  E. z  e.  (
0..^ ( # `  F
) ) y  =  ( ( z  +  S )  mod  ( # `
 F ) ) )
17123rexeqi 3143 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `
 F ) )  <->  E. z  e.  (
0..^ ( # `  F
) ) y  =  ( ( z  +  S )  mod  ( # `
 F ) ) )
172170, 171sylibr 224 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( ( ( ( # `  F
)  e.  NN0  /\  S  e.  ( 0..^ ( # `  F
) ) )  /\  y  e.  ( 0..^ ( # `  F
) ) )  ->  E. z  e.  (
0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) )
173172exp31 630 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
# `  F )  e.  NN0  ->  ( S  e.  ( 0..^ ( # `  F ) )  -> 
( y  e.  ( 0..^ ( # `  F
) )  ->  E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) ) )
17424, 173syl5bi 232 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
# `  F )  e.  NN0  ->  ( S  e.  ( 0..^ N )  ->  ( y  e.  ( 0..^ ( # `  F ) )  ->  E. z  e.  (
0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) ) )
17522, 174syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( F  e. Word  dom  I  ->  ( S  e.  ( 0..^ N )  ->  (
y  e.  ( 0..^ ( # `  F
) )  ->  E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) ) )
17620, 21, 1753syl 18 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( F (Circuits `  G ) P  ->  ( S  e.  ( 0..^ N )  ->  ( y  e.  ( 0..^ ( # `  F ) )  ->  E. z  e.  (
0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) ) )
1773, 5, 176sylc 65 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ph  ->  ( y  e.  ( 0..^ ( # `  F
) )  ->  E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) )
178177adantr 481 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( (
ph  /\  i  e.  dom  I )  ->  (
y  e.  ( 0..^ ( # `  F
) )  ->  E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) ) )
179178imp 445 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  ->  E. z  e.  (
0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) )
180179adantr 481 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  E. z  e.  (
0..^ N ) y  =  ( ( z  +  S )  mod  ( # `  F
) ) )
181 fveq2 6191 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( y  =  ( ( z  +  S )  mod  ( # `  F
) )  ->  ( F `  y )  =  ( F `  ( ( z  +  S )  mod  ( # `
 F ) ) ) )
182181reximi 3011 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( E. z  e.  ( 0..^ N ) y  =  ( ( z  +  S )  mod  ( # `
 F ) )  ->  E. z  e.  ( 0..^ N ) ( F `  y )  =  ( F `  ( ( z  +  S )  mod  ( # `
 F ) ) ) )
183180, 182syl 17 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  E. z  e.  (
0..^ N ) ( F `  y )  =  ( F `  ( ( z  +  S )  mod  ( # `
 F ) ) ) )
1843, 20, 213syl 18 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ph  ->  F  e. Word  dom  I
)
185184ad3antrrr 766 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  F  e. Word  dom  I )
186 elfzoelz 12470 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( S  e.  ( 0..^ N )  ->  S  e.  ZZ )
1875, 186syl 17 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ph  ->  S  e.  ZZ )
188187ad3antrrr 766 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  S  e.  ZZ )
18923eleq2i 2693 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( z  e.  ( 0..^ N )  <->  z  e.  ( 0..^ ( # `  F
) ) )
190189biimpi 206 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( z  e.  ( 0..^ N )  ->  z  e.  ( 0..^ ( # `  F
) ) )
191 cshwidxmod 13549 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( F  e. Word  dom  I  /\  S  e.  ZZ  /\  z  e.  ( 0..^ ( # `  F
) ) )  -> 
( ( F cyclShift  S ) `
 z )  =  ( F `  (
( z  +  S
)  mod  ( # `  F
) ) ) )
192185, 188, 190, 191syl2an3an 1386 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( ( ( ( ph  /\  i  e.  dom  I
)  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  /\  z  e.  ( 0..^ N ) )  -> 
( ( F cyclShift  S ) `
 z )  =  ( F `  (
( z  +  S
)  mod  ( # `  F
) ) ) )
193192eqeq2d 2632 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( ( ( ph  /\  i  e.  dom  I
)  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  /\  z  e.  ( 0..^ N ) )  -> 
( ( F `  y )  =  ( ( F cyclShift  S ) `  z )  <->  ( F `  y )  =  ( F `  ( ( z  +  S )  mod  ( # `  F
) ) ) ) )
194193rexbidva 3049 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
( E. z  e.  ( 0..^ N ) ( F `  y
)  =  ( ( F cyclShift  S ) `  z
)  <->  E. z  e.  ( 0..^ N ) ( F `  y )  =  ( F `  ( ( z  +  S )  mod  ( # `
 F ) ) ) ) )
195183, 194mpbird 247 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  E. z  e.  (
0..^ N ) ( F `  y )  =  ( ( F cyclShift  S ) `  z
) )
1961, 2, 3, 4, 5, 6crctcshlem2 26710 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ph  ->  ( # `  H
)  =  N )
197196oveq2d 6666 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ph  ->  ( 0..^ ( # `  H ) )  =  ( 0..^ N ) )
198197ad3antrrr 766 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
( 0..^ ( # `  H ) )  =  ( 0..^ N ) )
199 simpr 477 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
i  =  ( F `
 y ) )
2006fveq1i 6192 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( H `
 z )  =  ( ( F cyclShift  S ) `
 z )
201200a1i 11 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
( H `  z
)  =  ( ( F cyclShift  S ) `  z
) )
202199, 201eqeq12d 2637 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
( i  =  ( H `  z )  <-> 
( F `  y
)  =  ( ( F cyclShift  S ) `  z
) ) )
203198, 202rexeqbidv 3153 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  -> 
( E. z  e.  ( 0..^ ( # `  H ) ) i  =  ( H `  z )  <->  E. z  e.  ( 0..^ N ) ( F `  y
)  =  ( ( F cyclShift  S ) `  z
) ) )
204195, 203mpbird 247 . . . . . . . . . . . . . . . . . . 19  |-  ( ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  /\  i  =  ( F `  y ) )  ->  E. z  e.  (
0..^ ( # `  H
) ) i  =  ( H `  z
) )
205204ex 450 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( ph  /\  i  e.  dom  I )  /\  y  e.  ( 0..^ ( # `  F
) ) )  -> 
( i  =  ( F `  y )  ->  E. z  e.  ( 0..^ ( # `  H
) ) i  =  ( H `  z
) ) )
206205rexlimdva 3031 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  i  e.  dom  I )  ->  ( E. y  e.  (
0..^ ( # `  F
) ) i  =  ( F `  y
)  ->  E. z  e.  ( 0..^ ( # `  H ) ) i  =  ( H `  z ) ) )
207206ralimdva 2962 . . . . . . . . . . . . . . . 16  |-  ( ph  ->  ( A. i  e. 
dom  I E. y  e.  ( 0..^ ( # `  F ) ) i  =  ( F `  y )  ->  A. i  e.  dom  I E. z  e.  ( 0..^ ( # `  H ) ) i  =  ( H `  z ) ) )
208207impcom 446 . . . . . . . . . . . . . . 15  |-  ( ( A. i  e.  dom  I E. y  e.  ( 0..^ ( # `  F
) ) i  =  ( F `  y
)  /\  ph )  ->  A. i  e.  dom  I E. z  e.  ( 0..^ ( # `  H
) ) i  =  ( H `  z
) )
209208anim1i 592 . . . . . . . . . . . . . 14  |-  ( ( ( A. i  e. 
dom  I E. y  e.  ( 0..^ ( # `  F ) ) i  =  ( F `  y )  /\  ph )  /\  H : ( 0..^ ( # `  H
) ) --> dom  I
)  ->  ( A. i  e.  dom  I E. z  e.  ( 0..^ ( # `  H
) ) i  =  ( H `  z
)  /\  H :
( 0..^ ( # `  H ) ) --> dom  I ) )
210209ancomd 467 . . . . . . . . . . . . 13  |-  ( ( ( A. i  e. 
dom  I E. y  e.  ( 0..^ ( # `  F ) ) i  =  ( F `  y )  /\  ph )  /\  H : ( 0..^ ( # `  H
) ) --> dom  I
)  ->  ( H : ( 0..^ (
# `  H )
) --> dom  I  /\  A. i  e.  dom  I E. z  e.  (
0..^ ( # `  H
) ) i  =  ( H `  z
) ) )
211 dffo3 6374 . . . . . . . . . . . . 13  |-  ( H : ( 0..^ (
# `  H )
) -onto-> dom  I  <->  ( H : ( 0..^ (
# `  H )
) --> dom  I  /\  A. i  e.  dom  I E. z  e.  (
0..^ ( # `  H
) ) i  =  ( H `  z
) ) )
212210, 211sylibr 224 . . . . . . . . . . . 12  |-  ( ( ( A. i  e. 
dom  I E. y  e.  ( 0..^ ( # `  F ) ) i  =  ( F `  y )  /\  ph )  /\  H : ( 0..^ ( # `  H
) ) --> dom  I
)  ->  H :
( 0..^ ( # `  H ) ) -onto-> dom  I )
213212exp31 630 . . . . . . . . . . 11  |-  ( A. i  e.  dom  I E. y  e.  ( 0..^ ( # `  F
) ) i  =  ( F `  y
)  ->  ( ph  ->  ( H : ( 0..^ ( # `  H
) ) --> dom  I  ->  H : ( 0..^ ( # `  H
) ) -onto-> dom  I
) ) )
21419, 213simplbiim 659 . . . . . . . . . 10  |-  ( F : ( 0..^ (
# `  F )
) -onto-> dom  I  ->  ( ph  ->  ( H :
( 0..^ ( # `  H ) ) --> dom  I  ->  H :
( 0..^ ( # `  H ) ) -onto-> dom  I ) ) )
21518, 214simplbiim 659 . . . . . . . . 9  |-  ( F : ( 0..^ (
# `  F )
)
-1-1-onto-> dom  I  ->  ( ph  ->  ( H : ( 0..^ ( # `  H
) ) --> dom  I  ->  H : ( 0..^ ( # `  H
) ) -onto-> dom  I
) ) )
216215com13 88 . . . . . . . 8  |-  ( H : ( 0..^ (
# `  H )
) --> dom  I  ->  (
ph  ->  ( F :
( 0..^ ( # `  F ) ) -1-1-onto-> dom  I  ->  H : ( 0..^ ( # `  H
) ) -onto-> dom  I
) ) )
21717, 216syl 17 . . . . . . 7  |-  ( H (Trails `  G ) Q  ->  ( ph  ->  ( F : ( 0..^ ( # `  F
) ) -1-1-onto-> dom  I  ->  H : ( 0..^ (
# `  H )
) -onto-> dom  I ) ) )
218217impcom 446 . . . . . 6  |-  ( (
ph  /\  H (Trails `  G ) Q )  ->  ( F :
( 0..^ ( # `  F ) ) -1-1-onto-> dom  I  ->  H : ( 0..^ ( # `  H
) ) -onto-> dom  I
) )
21913, 218mpd 15 . . . . 5  |-  ( (
ph  /\  H (Trails `  G ) Q )  ->  H : ( 0..^ ( # `  H
) ) -onto-> dom  I
)
2209, 219jca 554 . . . 4  |-  ( (
ph  /\  H (Trails `  G ) Q )  ->  ( H (Trails `  G ) Q  /\  H : ( 0..^ (
# `  H )
) -onto-> dom  I ) )
2218, 220mpdan 702 . . 3  |-  ( ph  ->  ( H (Trails `  G ) Q  /\  H : ( 0..^ (
# `  H )
) -onto-> dom  I ) )
2222iseupth 27061 . . 3  |-  ( H (EulerPaths `  G ) Q  <-> 
( H (Trails `  G ) Q  /\  H : ( 0..^ (
# `  H )
) -onto-> dom  I ) )
223221, 222sylibr 224 . 2  |-  ( ph  ->  H (EulerPaths `  G
) Q )
2241, 2, 3, 4, 5, 6, 7crctcsh 26716 . 2  |-  ( ph  ->  H (Circuits `  G
) Q )
225223, 224jca 554 1  |-  ( ph  ->  ( H (EulerPaths `  G
) Q  /\  H
(Circuits `  G ) Q ) )
Colors of variables: wff setvar class
Syntax hints:   -. wn 3    -> wi 4    <-> wb 196    /\ wa 384    /\ w3a 1037    = wceq 1483    e. wcel 1990   A.wral 2912   E.wrex 2913   ifcif 4086   class class class wbr 4653    |-> cmpt 4729   dom cdm 5114   -->wf 5884   -1-1->wf1 5885   -onto->wfo 5886   -1-1-onto->wf1o 5887   ` cfv 5888  (class class class)co 6650   CCcc 9934   RRcr 9935   0cc0 9936    + caddc 9939    < clt 10074    <_ cle 10075    - cmin 10266   NNcn 11020   NN0cn0 11292   ZZcz 11377   ...cfz 12326  ..^cfzo 12465    mod cmo 12668   #chash 13117  Word cword 13291   cyclShift ccsh 13534  Vtxcvtx 25874  iEdgciedg 25875  Walkscwlks 26492  Trailsctrls 26587  Circuitsccrcts 26679  EulerPathsceupth 27057
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1722  ax-4 1737  ax-5 1839  ax-6 1888  ax-7 1935  ax-8 1992  ax-9 1999  ax-10 2019  ax-11 2034  ax-12 2047  ax-13 2246  ax-ext 2602  ax-rep 4771  ax-sep 4781  ax-nul 4789  ax-pow 4843  ax-pr 4906  ax-un 6949  ax-cnex 9992  ax-resscn 9993  ax-1cn 9994  ax-icn 9995  ax-addcl 9996  ax-addrcl 9997  ax-mulcl 9998  ax-mulrcl 9999  ax-mulcom 10000  ax-addass 10001  ax-mulass 10002  ax-distr 10003  ax-i2m1 10004  ax-1ne0 10005  ax-1rid 10006  ax-rnegex 10007  ax-rrecex 10008  ax-cnre 10009  ax-pre-lttri 10010  ax-pre-lttrn 10011  ax-pre-ltadd 10012  ax-pre-mulgt0 10013  ax-pre-sup 10014
This theorem depends on definitions:  df-bi 197  df-or 385  df-an 386  df-ifp 1013  df-3or 1038  df-3an 1039  df-tru 1486  df-ex 1705  df-nf 1710  df-sb 1881  df-eu 2474  df-mo 2475  df-clab 2609  df-cleq 2615  df-clel 2618  df-nfc 2753  df-ne 2795  df-nel 2898  df-ral 2917  df-rex 2918  df-reu 2919  df-rmo 2920  df-rab 2921  df-v 3202  df-sbc 3436  df-csb 3534  df-dif 3577  df-un 3579  df-in 3581  df-ss 3588  df-pss 3590  df-nul 3916  df-if 4087  df-pw 4160  df-sn 4178  df-pr 4180  df-tp 4182  df-op 4184  df-uni 4437  df-int 4476  df-iun 4522  df-br 4654  df-opab 4713  df-mpt 4730  df-tr 4753  df-id 5024  df-eprel 5029  df-po 5035  df-so 5036  df-fr 5073  df-we 5075  df-xp 5120  df-rel 5121  df-cnv 5122  df-co 5123  df-dm 5124  df-rn 5125  df-res 5126  df-ima 5127  df-pred 5680  df-ord 5726  df-on 5727  df-lim 5728  df-suc 5729  df-iota 5851  df-fun 5890  df-fn 5891  df-f 5892  df-f1 5893  df-fo 5894  df-f1o 5895  df-fv 5896  df-riota 6611  df-ov 6653  df-oprab 6654  df-mpt2 6655  df-om 7066  df-1st 7168  df-2nd 7169  df-wrecs 7407  df-recs 7468  df-rdg 7506  df-1o 7560  df-oadd 7564  df-er 7742  df-map 7859  df-pm 7860  df-en 7956  df-dom 7957  df-sdom 7958  df-fin 7959  df-sup 8348  df-inf 8349  df-card 8765  df-pnf 10076  df-mnf 10077  df-xr 10078  df-ltxr 10079  df-le 10080  df-sub 10268  df-neg 10269  df-div 10685  df-nn 11021  df-2 11079  df-n0 11293  df-z 11378  df-uz 11688  df-rp 11833  df-ico 12181  df-fz 12327  df-fzo 12466  df-fl 12593  df-mod 12669  df-hash 13118  df-word 13299  df-concat 13301  df-substr 13303  df-csh 13535  df-wlks 26495  df-trls 26589  df-crcts 26681  df-eupth 27058
This theorem is referenced by:  eucrct2eupth  27105
  Copyright terms: Public domain W3C validator