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

Theorem 4sqlem11 15659
Description: Lemma for 4sq 15668. Use the pigeonhole principle to show that the sets  { m ^
2  |  m  e.  ( 0 ... N
) } and  { -u 1  -  n ^ 2  |  n  e.  ( 0 ... N ) } have a common element,  mod  P. (Contributed by Mario Carneiro, 15-Jul-2014.)
Hypotheses
Ref Expression
4sq.1  |-  S  =  { n  |  E. x  e.  ZZ  E. y  e.  ZZ  E. z  e.  ZZ  E. w  e.  ZZ  n  =  ( ( ( x ^
2 )  +  ( y ^ 2 ) )  +  ( ( z ^ 2 )  +  ( w ^
2 ) ) ) }
4sq.2  |-  ( ph  ->  N  e.  NN )
4sq.3  |-  ( ph  ->  P  =  ( ( 2  x.  N )  +  1 ) )
4sq.4  |-  ( ph  ->  P  e.  Prime )
4sqlem11.5  |-  A  =  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P ) }
4sqlem11.6  |-  F  =  ( v  e.  A  |->  ( ( P  - 
1 )  -  v
) )
Assertion
Ref Expression
4sqlem11  |-  ( ph  ->  ( A  i^i  ran  F )  =/=  (/) )
Distinct variable groups:    w, n, x, y, z    v, n, A    n, F    u, n, m, v, N    P, m, n, u, v    ph, m, n, u, v    S, m, n, u, v
Allowed substitution hints:    ph( x, y, z, w)    A( x, y, z, w, u, m)    P( x, y, z, w)    S( x, y, z, w)    F( x, y, z, w, v, u, m)    N( x, y, z, w)

Proof of Theorem 4sqlem11
Dummy variable  k is distinct from all other variables.
StepHypRef Expression
1 fzfid 12772 . . . . . 6  |-  ( ph  ->  ( 0 ... ( P  -  1 ) )  e.  Fin )
2 4sqlem11.5 . . . . . . . 8  |-  A  =  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P ) }
3 elfzelz 12342 . . . . . . . . . . . . 13  |-  ( m  e.  ( 0 ... N )  ->  m  e.  ZZ )
4 zsqcl 12934 . . . . . . . . . . . . 13  |-  ( m  e.  ZZ  ->  (
m ^ 2 )  e.  ZZ )
53, 4syl 17 . . . . . . . . . . . 12  |-  ( m  e.  ( 0 ... N )  ->  (
m ^ 2 )  e.  ZZ )
6 4sq.4 . . . . . . . . . . . . 13  |-  ( ph  ->  P  e.  Prime )
7 prmnn 15388 . . . . . . . . . . . . 13  |-  ( P  e.  Prime  ->  P  e.  NN )
86, 7syl 17 . . . . . . . . . . . 12  |-  ( ph  ->  P  e.  NN )
9 zmodfz 12692 . . . . . . . . . . . 12  |-  ( ( ( m ^ 2 )  e.  ZZ  /\  P  e.  NN )  ->  ( ( m ^
2 )  mod  P
)  e.  ( 0 ... ( P  - 
1 ) ) )
105, 8, 9syl2anr 495 . . . . . . . . . . 11  |-  ( (
ph  /\  m  e.  ( 0 ... N
) )  ->  (
( m ^ 2 )  mod  P )  e.  ( 0 ... ( P  -  1 ) ) )
11 eleq1a 2696 . . . . . . . . . . 11  |-  ( ( ( m ^ 2 )  mod  P )  e.  ( 0 ... ( P  -  1 ) )  ->  (
u  =  ( ( m ^ 2 )  mod  P )  ->  u  e.  ( 0 ... ( P  - 
1 ) ) ) )
1210, 11syl 17 . . . . . . . . . 10  |-  ( (
ph  /\  m  e.  ( 0 ... N
) )  ->  (
u  =  ( ( m ^ 2 )  mod  P )  ->  u  e.  ( 0 ... ( P  - 
1 ) ) ) )
1312rexlimdva 3031 . . . . . . . . 9  |-  ( ph  ->  ( E. m  e.  ( 0 ... N
) u  =  ( ( m ^ 2 )  mod  P )  ->  u  e.  ( 0 ... ( P  -  1 ) ) ) )
1413abssdv 3676 . . . . . . . 8  |-  ( ph  ->  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P ) }  C_  ( 0 ... ( P  -  1 ) ) )
152, 14syl5eqss 3649 . . . . . . 7  |-  ( ph  ->  A  C_  ( 0 ... ( P  - 
1 ) ) )
16 prmz 15389 . . . . . . . . . . . . . . . 16  |-  ( P  e.  Prime  ->  P  e.  ZZ )
176, 16syl 17 . . . . . . . . . . . . . . 15  |-  ( ph  ->  P  e.  ZZ )
18 peano2zm 11420 . . . . . . . . . . . . . . 15  |-  ( P  e.  ZZ  ->  ( P  -  1 )  e.  ZZ )
1917, 18syl 17 . . . . . . . . . . . . . 14  |-  ( ph  ->  ( P  -  1 )  e.  ZZ )
2019zcnd 11483 . . . . . . . . . . . . 13  |-  ( ph  ->  ( P  -  1 )  e.  CC )
2120addid2d 10237 . . . . . . . . . . . 12  |-  ( ph  ->  ( 0  +  ( P  -  1 ) )  =  ( P  -  1 ) )
2221oveq1d 6665 . . . . . . . . . . 11  |-  ( ph  ->  ( ( 0  +  ( P  -  1 ) )  -  v
)  =  ( ( P  -  1 )  -  v ) )
2322adantr 481 . . . . . . . . . 10  |-  ( (
ph  /\  v  e.  A )  ->  (
( 0  +  ( P  -  1 ) )  -  v )  =  ( ( P  -  1 )  -  v ) )
2415sselda 3603 . . . . . . . . . . 11  |-  ( (
ph  /\  v  e.  A )  ->  v  e.  ( 0 ... ( P  -  1 ) ) )
25 fzrev3i 12407 . . . . . . . . . . 11  |-  ( v  e.  ( 0 ... ( P  -  1 ) )  ->  (
( 0  +  ( P  -  1 ) )  -  v )  e.  ( 0 ... ( P  -  1 ) ) )
2624, 25syl 17 . . . . . . . . . 10  |-  ( (
ph  /\  v  e.  A )  ->  (
( 0  +  ( P  -  1 ) )  -  v )  e.  ( 0 ... ( P  -  1 ) ) )
2723, 26eqeltrrd 2702 . . . . . . . . 9  |-  ( (
ph  /\  v  e.  A )  ->  (
( P  -  1 )  -  v )  e.  ( 0 ... ( P  -  1 ) ) )
28 4sqlem11.6 . . . . . . . . 9  |-  F  =  ( v  e.  A  |->  ( ( P  - 
1 )  -  v
) )
2927, 28fmptd 6385 . . . . . . . 8  |-  ( ph  ->  F : A --> ( 0 ... ( P  - 
1 ) ) )
30 frn 6053 . . . . . . . 8  |-  ( F : A --> ( 0 ... ( P  - 
1 ) )  ->  ran  F  C_  ( 0 ... ( P  - 
1 ) ) )
3129, 30syl 17 . . . . . . 7  |-  ( ph  ->  ran  F  C_  (
0 ... ( P  - 
1 ) ) )
3215, 31unssd 3789 . . . . . 6  |-  ( ph  ->  ( A  u.  ran  F )  C_  ( 0 ... ( P  - 
1 ) ) )
33 ssdomg 8001 . . . . . 6  |-  ( ( 0 ... ( P  -  1 ) )  e.  Fin  ->  (
( A  u.  ran  F )  C_  ( 0 ... ( P  - 
1 ) )  -> 
( A  u.  ran  F )  ~<_  ( 0 ... ( P  -  1 ) ) ) )
341, 32, 33sylc 65 . . . . 5  |-  ( ph  ->  ( A  u.  ran  F )  ~<_  ( 0 ... ( P  -  1 ) ) )
35 ssfi 8180 . . . . . . 7  |-  ( ( ( 0 ... ( P  -  1 ) )  e.  Fin  /\  ( A  u.  ran  F )  C_  ( 0 ... ( P  - 
1 ) ) )  ->  ( A  u.  ran  F )  e.  Fin )
361, 32, 35syl2anc 693 . . . . . 6  |-  ( ph  ->  ( A  u.  ran  F )  e.  Fin )
37 hashdom 13168 . . . . . 6  |-  ( ( ( A  u.  ran  F )  e.  Fin  /\  ( 0 ... ( P  -  1 ) )  e.  Fin )  ->  ( ( # `  ( A  u.  ran  F ) )  <_  ( # `  (
0 ... ( P  - 
1 ) ) )  <-> 
( A  u.  ran  F )  ~<_  ( 0 ... ( P  -  1 ) ) ) )
3836, 1, 37syl2anc 693 . . . . 5  |-  ( ph  ->  ( ( # `  ( A  u.  ran  F ) )  <_  ( # `  (
0 ... ( P  - 
1 ) ) )  <-> 
( A  u.  ran  F )  ~<_  ( 0 ... ( P  -  1 ) ) ) )
3934, 38mpbird 247 . . . 4  |-  ( ph  ->  ( # `  ( A  u.  ran  F ) )  <_  ( # `  (
0 ... ( P  - 
1 ) ) ) )
40 fz01en 12369 . . . . . . 7  |-  ( P  e.  ZZ  ->  (
0 ... ( P  - 
1 ) )  ~~  ( 1 ... P
) )
4117, 40syl 17 . . . . . 6  |-  ( ph  ->  ( 0 ... ( P  -  1 ) )  ~~  ( 1 ... P ) )
42 fzfid 12772 . . . . . . 7  |-  ( ph  ->  ( 1 ... P
)  e.  Fin )
43 hashen 13135 . . . . . . 7  |-  ( ( ( 0 ... ( P  -  1 ) )  e.  Fin  /\  ( 1 ... P
)  e.  Fin )  ->  ( ( # `  (
0 ... ( P  - 
1 ) ) )  =  ( # `  (
1 ... P ) )  <-> 
( 0 ... ( P  -  1 ) )  ~~  ( 1 ... P ) ) )
441, 42, 43syl2anc 693 . . . . . 6  |-  ( ph  ->  ( ( # `  (
0 ... ( P  - 
1 ) ) )  =  ( # `  (
1 ... P ) )  <-> 
( 0 ... ( P  -  1 ) )  ~~  ( 1 ... P ) ) )
4541, 44mpbird 247 . . . . 5  |-  ( ph  ->  ( # `  (
0 ... ( P  - 
1 ) ) )  =  ( # `  (
1 ... P ) ) )
468nnnn0d 11351 . . . . . 6  |-  ( ph  ->  P  e.  NN0 )
47 hashfz1 13134 . . . . . 6  |-  ( P  e.  NN0  ->  ( # `  ( 1 ... P
) )  =  P )
4846, 47syl 17 . . . . 5  |-  ( ph  ->  ( # `  (
1 ... P ) )  =  P )
4945, 48eqtrd 2656 . . . 4  |-  ( ph  ->  ( # `  (
0 ... ( P  - 
1 ) ) )  =  P )
5039, 49breqtrd 4679 . . 3  |-  ( ph  ->  ( # `  ( A  u.  ran  F ) )  <_  P )
51 hashcl 13147 . . . . . 6  |-  ( ( A  u.  ran  F
)  e.  Fin  ->  (
# `  ( A  u.  ran  F ) )  e.  NN0 )
5236, 51syl 17 . . . . 5  |-  ( ph  ->  ( # `  ( A  u.  ran  F ) )  e.  NN0 )
5352nn0red 11352 . . . 4  |-  ( ph  ->  ( # `  ( A  u.  ran  F ) )  e.  RR )
5417zred 11482 . . . 4  |-  ( ph  ->  P  e.  RR )
5553, 54lenltd 10183 . . 3  |-  ( ph  ->  ( ( # `  ( A  u.  ran  F ) )  <_  P  <->  -.  P  <  ( # `  ( A  u.  ran  F ) ) ) )
5650, 55mpbid 222 . 2  |-  ( ph  ->  -.  P  <  ( # `
 ( A  u.  ran  F ) ) )
5754adantr 481 . . . . . 6  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  P  e.  RR )
5857ltp1d 10954 . . . . 5  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  P  < 
( P  +  1 ) )
59 4sq.2 . . . . . . . . . 10  |-  ( ph  ->  N  e.  NN )
6059nncnd 11036 . . . . . . . . 9  |-  ( ph  ->  N  e.  CC )
61 1cnd 10056 . . . . . . . . 9  |-  ( ph  ->  1  e.  CC )
6260, 60, 61, 61add4d 10264 . . . . . . . 8  |-  ( ph  ->  ( ( N  +  N )  +  ( 1  +  1 ) )  =  ( ( N  +  1 )  +  ( N  + 
1 ) ) )
63 4sq.3 . . . . . . . . . 10  |-  ( ph  ->  P  =  ( ( 2  x.  N )  +  1 ) )
6463oveq1d 6665 . . . . . . . . 9  |-  ( ph  ->  ( P  +  1 )  =  ( ( ( 2  x.  N
)  +  1 )  +  1 ) )
65 2cn 11091 . . . . . . . . . . 11  |-  2  e.  CC
66 mulcl 10020 . . . . . . . . . . 11  |-  ( ( 2  e.  CC  /\  N  e.  CC )  ->  ( 2  x.  N
)  e.  CC )
6765, 60, 66sylancr 695 . . . . . . . . . 10  |-  ( ph  ->  ( 2  x.  N
)  e.  CC )
6867, 61, 61addassd 10062 . . . . . . . . 9  |-  ( ph  ->  ( ( ( 2  x.  N )  +  1 )  +  1 )  =  ( ( 2  x.  N )  +  ( 1  +  1 ) ) )
69602timesd 11275 . . . . . . . . . 10  |-  ( ph  ->  ( 2  x.  N
)  =  ( N  +  N ) )
7069oveq1d 6665 . . . . . . . . 9  |-  ( ph  ->  ( ( 2  x.  N )  +  ( 1  +  1 ) )  =  ( ( N  +  N )  +  ( 1  +  1 ) ) )
7164, 68, 703eqtrd 2660 . . . . . . . 8  |-  ( ph  ->  ( P  +  1 )  =  ( ( N  +  N )  +  ( 1  +  1 ) ) )
7210ex 450 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  ( m  e.  ( 0 ... N )  ->  ( ( m ^ 2 )  mod 
P )  e.  ( 0 ... ( P  -  1 ) ) ) )
738adantr 481 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  P  e.  NN )
743ad2antrl 764 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  m  e.  ZZ )
7574, 4syl 17 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m ^ 2 )  e.  ZZ )
76 elfzelz 12342 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( u  e.  ( 0 ... N )  ->  u  e.  ZZ )
7776ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  u  e.  ZZ )
78 zsqcl 12934 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( u  e.  ZZ  ->  (
u ^ 2 )  e.  ZZ )
7977, 78syl 17 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( u ^ 2 )  e.  ZZ )
80 moddvds 14991 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( P  e.  NN  /\  ( m ^ 2 )  e.  ZZ  /\  ( u ^ 2 )  e.  ZZ )  ->  ( ( ( m ^ 2 )  mod  P )  =  ( ( u ^
2 )  mod  P
)  <->  P  ||  ( ( m ^ 2 )  -  ( u ^
2 ) ) ) )
8173, 75, 79, 80syl3anc 1326 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( u ^ 2 )  mod  P )  <-> 
P  ||  ( (
m ^ 2 )  -  ( u ^
2 ) ) ) )
8274zcnd 11483 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  m  e.  CC )
8377zcnd 11483 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  u  e.  CC )
84 subsq 12972 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( m  e.  CC  /\  u  e.  CC )  ->  ( ( m ^
2 )  -  (
u ^ 2 ) )  =  ( ( m  +  u )  x.  ( m  -  u ) ) )
8582, 83, 84syl2anc 693 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( m ^
2 )  -  (
u ^ 2 ) )  =  ( ( m  +  u )  x.  ( m  -  u ) ) )
8685breq2d 4665 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  (
( m ^ 2 )  -  ( u ^ 2 ) )  <-> 
P  ||  ( (
m  +  u )  x.  ( m  -  u ) ) ) )
876adantr 481 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  P  e.  Prime )
8874, 77zaddcld 11486 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  +  u
)  e.  ZZ )
8974, 77zsubcld 11487 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  -  u
)  e.  ZZ )
90 euclemma 15425 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( P  e.  Prime  /\  (
m  +  u )  e.  ZZ  /\  (
m  -  u )  e.  ZZ )  -> 
( P  ||  (
( m  +  u
)  x.  ( m  -  u ) )  <-> 
( P  ||  (
m  +  u )  \/  P  ||  (
m  -  u ) ) ) )
9187, 88, 89, 90syl3anc 1326 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  (
( m  +  u
)  x.  ( m  -  u ) )  <-> 
( P  ||  (
m  +  u )  \/  P  ||  (
m  -  u ) ) ) )
9281, 86, 913bitrd 294 . . . . . . . . . . . . . . . . . . . 20  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( u ^ 2 )  mod  P )  <-> 
( P  ||  (
m  +  u )  \/  P  ||  (
m  -  u ) ) ) )
9388zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  +  u
)  e.  RR )
94 2re 11090 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  2  e.  RR
9559nnred 11035 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ph  ->  N  e.  RR )
96 remulcl 10021 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ( 2  e.  RR  /\  N  e.  RR )  ->  ( 2  x.  N
)  e.  RR )
9794, 95, 96sylancr 695 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( ph  ->  ( 2  x.  N
)  e.  RR )
9897adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( 2  x.  N
)  e.  RR )
9987, 16syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  P  e.  ZZ )
10099zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  P  e.  RR )
10174zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  m  e.  RR )
10277zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  u  e.  RR )
10395adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  N  e.  RR )
104 elfzle2 12345 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( m  e.  ( 0 ... N )  ->  m  <_  N )
105104ad2antrl 764 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  m  <_  N )
106 elfzle2 12345 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( u  e.  ( 0 ... N )  ->  u  <_  N )
107106ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  u  <_  N )
108101, 102, 103, 103, 105, 107le2addd 10646 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  +  u
)  <_  ( N  +  N ) )
10960adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  N  e.  CC )
1101092timesd 11275 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( 2  x.  N
)  =  ( N  +  N ) )
111108, 110breqtrrd 4681 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  +  u
)  <_  ( 2  x.  N ) )
11297ltp1d 10954 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ph  ->  ( 2  x.  N
)  <  ( (
2  x.  N )  +  1 ) )
113112, 63breqtrrd 4681 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( ph  ->  ( 2  x.  N
)  <  P )
114113adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( 2  x.  N
)  <  P )
11593, 98, 100, 111, 114lelttrd 10195 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  +  u
)  <  P )
11693, 100ltnled 10184 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( m  +  u )  <  P  <->  -.  P  <_  ( m  +  u ) ) )
117115, 116mpbid 222 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  -.  P  <_  ( m  +  u ) )
118117adantr 481 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  -.  P  <_  ( m  +  u ) )
11917ad2antrr 762 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  P  e.  ZZ )
12088adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  (
m  +  u )  e.  ZZ )
121 1red 10055 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  1  e.  RR )
122 nn0abscl 14052 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( ( m  -  u )  e.  ZZ  ->  ( abs `  ( m  -  u ) )  e. 
NN0 )
12389, 122syl 17 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  u ) )  e.  NN0 )
124123nn0red 11352 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  u ) )  e.  RR )
125124adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  e.  RR )
126120zred 11482 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  (
m  +  u )  e.  RR )
127123adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  e. 
NN0 )
128127nn0zd 11480 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  e.  ZZ )
12989zcnd 11483 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  -  u
)  e.  CC )
130129adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  (
m  -  u )  e.  CC )
13182, 83subeq0ad 10402 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( m  -  u )  =  0  <-> 
m  =  u ) )
132131necon3bid 2838 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( m  -  u )  =/=  0  <->  m  =/=  u ) )
133132biimpar 502 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  (
m  -  u )  =/=  0 )
134130, 133absrpcld 14187 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  e.  RR+ )
135134rpgt0d 11875 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  0  <  ( abs `  (
m  -  u ) ) )
136 elnnz 11387 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ( abs `  ( m  -  u ) )  e.  NN  <->  ( ( abs `  ( m  -  u ) )  e.  ZZ  /\  0  < 
( abs `  (
m  -  u ) ) ) )
137128, 135, 136sylanbrc 698 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  e.  NN )
138137nnge1d 11063 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  1  <_  ( abs `  (
m  -  u ) ) )
139 0cnd 10033 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
0  e.  CC )
14082, 83, 139abs3difd 14199 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  u ) )  <_  ( ( abs `  ( m  - 
0 ) )  +  ( abs `  (
0  -  u ) ) ) )
14182subid1d 10381 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  -  0 )  =  m )
142141fveq2d 6195 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  0 ) )  =  ( abs `  m ) )
143 elfzle1 12344 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( m  e.  ( 0 ... N )  ->  0  <_  m )
144143ad2antrl 764 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
0  <_  m )
145101, 144absidd 14161 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  m
)  =  m )
146142, 145eqtrd 2656 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  0 ) )  =  m )
147 0cn 10032 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  0  e.  CC
148 abssub 14066 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( ( 0  e.  CC  /\  u  e.  CC )  ->  ( abs `  (
0  -  u ) )  =  ( abs `  ( u  -  0 ) ) )
149147, 83, 148sylancr 695 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
0  -  u ) )  =  ( abs `  ( u  -  0 ) ) )
15083subid1d 10381 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( u  -  0 )  =  u )
151150fveq2d 6195 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
u  -  0 ) )  =  ( abs `  u ) )
152 elfzle1 12344 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33  |-  ( u  e.  ( 0 ... N )  ->  0  <_  u )
153152ad2antll 765 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
0  <_  u )
154102, 153absidd 14161 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  u
)  =  u )
155149, 151, 1543eqtrd 2660 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
0  -  u ) )  =  u )
156146, 155oveq12d 6668 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( abs `  (
m  -  0 ) )  +  ( abs `  ( 0  -  u
) ) )  =  ( m  +  u
) )
157140, 156breqtrd 4679 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( abs `  (
m  -  u ) )  <_  ( m  +  u ) )
158157adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( abs `  ( m  -  u ) )  <_ 
( m  +  u
) )
159121, 125, 126, 138, 158letrd 10194 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  1  <_  ( m  +  u
) )
160 elnnz1 11403 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( ( m  +  u )  e.  NN  <->  ( (
m  +  u )  e.  ZZ  /\  1  <_  ( m  +  u
) ) )
161120, 159, 160sylanbrc 698 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  (
m  +  u )  e.  NN )
162 dvdsle 15032 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ( P  e.  ZZ  /\  ( m  +  u
)  e.  NN )  ->  ( P  ||  ( m  +  u
)  ->  P  <_  ( m  +  u ) ) )
163119, 161, 162syl2anc 693 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( P  ||  ( m  +  u )  ->  P  <_  ( m  +  u
) ) )
164118, 163mtod 189 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  -.  P  ||  ( m  +  u ) )
165164ex 450 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  =/=  u  ->  -.  P  ||  (
m  +  u ) ) )
166165necon4ad 2813 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  (
m  +  u )  ->  m  =  u ) )
167 dvdsabsb 15001 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( P  e.  ZZ  /\  ( m  -  u
)  e.  ZZ )  ->  ( P  ||  ( m  -  u
)  <->  P  ||  ( abs `  ( m  -  u
) ) ) )
16899, 89, 167syl2anc 693 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  (
m  -  u )  <-> 
P  ||  ( abs `  ( m  -  u
) ) ) )
169 letr 10131 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29  |-  ( ( P  e.  RR  /\  ( abs `  ( m  -  u ) )  e.  RR  /\  (
m  +  u )  e.  RR )  -> 
( ( P  <_ 
( abs `  (
m  -  u ) )  /\  ( abs `  ( m  -  u
) )  <_  (
m  +  u ) )  ->  P  <_  ( m  +  u ) ) )
170100, 124, 93, 169syl3anc 1326 . . . . . . . . . . . . . . . . . . . . . . . . . . . 28  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( P  <_ 
( abs `  (
m  -  u ) )  /\  ( abs `  ( m  -  u
) )  <_  (
m  +  u ) )  ->  P  <_  ( m  +  u ) ) )
171157, 170mpan2d 710 . . . . . . . . . . . . . . . . . . . . . . . . . . 27  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  <_  ( abs `  ( m  -  u ) )  ->  P  <_  ( m  +  u ) ) )
172117, 171mtod 189 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  ->  -.  P  <_  ( abs `  ( m  -  u
) ) )
173172adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  -.  P  <_  ( abs `  (
m  -  u ) ) )
17499adantr 481 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  P  e.  ZZ )
175 dvdsle 15032 . . . . . . . . . . . . . . . . . . . . . . . . . 26  |-  ( ( P  e.  ZZ  /\  ( abs `  ( m  -  u ) )  e.  NN )  -> 
( P  ||  ( abs `  ( m  -  u ) )  ->  P  <_  ( abs `  (
m  -  u ) ) ) )
176174, 137, 175syl2anc 693 . . . . . . . . . . . . . . . . . . . . . . . . 25  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  ( P  ||  ( abs `  (
m  -  u ) )  ->  P  <_  ( abs `  ( m  -  u ) ) ) )
177173, 176mtod 189 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( ( ph  /\  (
m  e.  ( 0 ... N )  /\  u  e.  ( 0 ... N ) ) )  /\  m  =/=  u )  ->  -.  P  ||  ( abs `  (
m  -  u ) ) )
178177ex 450 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( m  =/=  u  ->  -.  P  ||  ( abs `  ( m  -  u ) ) ) )
179178necon4ad 2813 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  ( abs `  ( m  -  u ) )  ->  m  =  u )
)
180168, 179sylbid 230 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( P  ||  (
m  -  u )  ->  m  =  u ) )
181166, 180jaod 395 . . . . . . . . . . . . . . . . . . . 20  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( P  ||  ( m  +  u
)  \/  P  ||  ( m  -  u
) )  ->  m  =  u ) )
18292, 181sylbid 230 . . . . . . . . . . . . . . . . . . 19  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( u ^ 2 )  mod  P )  ->  m  =  u ) )
183 oveq1 6657 . . . . . . . . . . . . . . . . . . . 20  |-  ( m  =  u  ->  (
m ^ 2 )  =  ( u ^
2 ) )
184183oveq1d 6665 . . . . . . . . . . . . . . . . . . 19  |-  ( m  =  u  ->  (
( m ^ 2 )  mod  P )  =  ( ( u ^ 2 )  mod 
P ) )
185182, 184impbid1 215 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( u ^ 2 )  mod  P )  <-> 
m  =  u ) )
186185ex 450 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  ( ( m  e.  ( 0 ... N
)  /\  u  e.  ( 0 ... N
) )  ->  (
( ( m ^
2 )  mod  P
)  =  ( ( u ^ 2 )  mod  P )  <->  m  =  u ) ) )
18772, 186dom2lem 7995 . . . . . . . . . . . . . . . 16  |-  ( ph  ->  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) : ( 0 ... N )
-1-1-> ( 0 ... ( P  -  1 ) ) )
188 f1f1orn 6148 . . . . . . . . . . . . . . . 16  |-  ( ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) ) : ( 0 ... N ) -1-1-> ( 0 ... ( P  -  1 ) )  ->  ( m  e.  ( 0 ... N
)  |->  ( ( m ^ 2 )  mod 
P ) ) : ( 0 ... N
)
-1-1-onto-> ran  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) )
189187, 188syl 17 . . . . . . . . . . . . . . 15  |-  ( ph  ->  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) : ( 0 ... N ) -1-1-onto-> ran  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) )
190 eqid 2622 . . . . . . . . . . . . . . . . . 18  |-  ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) )  =  ( m  e.  ( 0 ... N
)  |->  ( ( m ^ 2 )  mod 
P ) )
191190rnmpt 5371 . . . . . . . . . . . . . . . . 17  |-  ran  (
m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) )  =  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod  P ) }
1922, 191eqtr4i 2647 . . . . . . . . . . . . . . . 16  |-  A  =  ran  ( m  e.  ( 0 ... N
)  |->  ( ( m ^ 2 )  mod 
P ) )
193 f1oeq3 6129 . . . . . . . . . . . . . . . 16  |-  ( A  =  ran  ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) )  ->  ( ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) ) : ( 0 ... N ) -1-1-onto-> A  <->  ( m  e.  ( 0 ... N
)  |->  ( ( m ^ 2 )  mod 
P ) ) : ( 0 ... N
)
-1-1-onto-> ran  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) ) )
194192, 193ax-mp 5 . . . . . . . . . . . . . . 15  |-  ( ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) ) : ( 0 ... N ) -1-1-onto-> A  <->  ( m  e.  ( 0 ... N
)  |->  ( ( m ^ 2 )  mod 
P ) ) : ( 0 ... N
)
-1-1-onto-> ran  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) )
195189, 194sylibr 224 . . . . . . . . . . . . . 14  |-  ( ph  ->  ( m  e.  ( 0 ... N ) 
|->  ( ( m ^
2 )  mod  P
) ) : ( 0 ... N ) -1-1-onto-> A )
196 ovex 6678 . . . . . . . . . . . . . . 15  |-  ( 0 ... N )  e. 
_V
197196f1oen 7976 . . . . . . . . . . . . . 14  |-  ( ( m  e.  ( 0 ... N )  |->  ( ( m ^ 2 )  mod  P ) ) : ( 0 ... N ) -1-1-onto-> A  -> 
( 0 ... N
)  ~~  A )
198195, 197syl 17 . . . . . . . . . . . . 13  |-  ( ph  ->  ( 0 ... N
)  ~~  A )
199198ensymd 8007 . . . . . . . . . . . 12  |-  ( ph  ->  A  ~~  ( 0 ... N ) )
200 ax-1cn 9994 . . . . . . . . . . . . . . 15  |-  1  e.  CC
201 pncan 10287 . . . . . . . . . . . . . . 15  |-  ( ( N  e.  CC  /\  1  e.  CC )  ->  ( ( N  + 
1 )  -  1 )  =  N )
20260, 200, 201sylancl 694 . . . . . . . . . . . . . 14  |-  ( ph  ->  ( ( N  + 
1 )  -  1 )  =  N )
203202oveq2d 6666 . . . . . . . . . . . . 13  |-  ( ph  ->  ( 0 ... (
( N  +  1 )  -  1 ) )  =  ( 0 ... N ) )
20459nnnn0d 11351 . . . . . . . . . . . . . . . 16  |-  ( ph  ->  N  e.  NN0 )
205 peano2nn0 11333 . . . . . . . . . . . . . . . 16  |-  ( N  e.  NN0  ->  ( N  +  1 )  e. 
NN0 )
206204, 205syl 17 . . . . . . . . . . . . . . 15  |-  ( ph  ->  ( N  +  1 )  e.  NN0 )
207206nn0zd 11480 . . . . . . . . . . . . . 14  |-  ( ph  ->  ( N  +  1 )  e.  ZZ )
208 fz01en 12369 . . . . . . . . . . . . . 14  |-  ( ( N  +  1 )  e.  ZZ  ->  (
0 ... ( ( N  +  1 )  - 
1 ) )  ~~  ( 1 ... ( N  +  1 ) ) )
209207, 208syl 17 . . . . . . . . . . . . 13  |-  ( ph  ->  ( 0 ... (
( N  +  1 )  -  1 ) )  ~~  ( 1 ... ( N  + 
1 ) ) )
210203, 209eqbrtrrd 4677 . . . . . . . . . . . 12  |-  ( ph  ->  ( 0 ... N
)  ~~  ( 1 ... ( N  + 
1 ) ) )
211 entr 8008 . . . . . . . . . . . 12  |-  ( ( A  ~~  ( 0 ... N )  /\  ( 0 ... N
)  ~~  ( 1 ... ( N  + 
1 ) ) )  ->  A  ~~  (
1 ... ( N  + 
1 ) ) )
212199, 210, 211syl2anc 693 . . . . . . . . . . 11  |-  ( ph  ->  A  ~~  ( 1 ... ( N  + 
1 ) ) )
213 ssfi 8180 . . . . . . . . . . . . 13  |-  ( ( ( 0 ... ( P  -  1 ) )  e.  Fin  /\  A  C_  ( 0 ... ( P  -  1 ) ) )  ->  A  e.  Fin )
2141, 15, 213syl2anc 693 . . . . . . . . . . . 12  |-  ( ph  ->  A  e.  Fin )
215 fzfid 12772 . . . . . . . . . . . 12  |-  ( ph  ->  ( 1 ... ( N  +  1 ) )  e.  Fin )
216 hashen 13135 . . . . . . . . . . . 12  |-  ( ( A  e.  Fin  /\  ( 1 ... ( N  +  1 ) )  e.  Fin )  ->  ( ( # `  A
)  =  ( # `  ( 1 ... ( N  +  1 ) ) )  <->  A  ~~  ( 1 ... ( N  +  1 ) ) ) )
217214, 215, 216syl2anc 693 . . . . . . . . . . 11  |-  ( ph  ->  ( ( # `  A
)  =  ( # `  ( 1 ... ( N  +  1 ) ) )  <->  A  ~~  ( 1 ... ( N  +  1 ) ) ) )
218212, 217mpbird 247 . . . . . . . . . 10  |-  ( ph  ->  ( # `  A
)  =  ( # `  ( 1 ... ( N  +  1 ) ) ) )
219 hashfz1 13134 . . . . . . . . . . 11  |-  ( ( N  +  1 )  e.  NN0  ->  ( # `  ( 1 ... ( N  +  1 ) ) )  =  ( N  +  1 ) )
220206, 219syl 17 . . . . . . . . . 10  |-  ( ph  ->  ( # `  (
1 ... ( N  + 
1 ) ) )  =  ( N  + 
1 ) )
221218, 220eqtrd 2656 . . . . . . . . 9  |-  ( ph  ->  ( # `  A
)  =  ( N  +  1 ) )
22227ex 450 . . . . . . . . . . . . . . 15  |-  ( ph  ->  ( v  e.  A  ->  ( ( P  - 
1 )  -  v
)  e.  ( 0 ... ( P  - 
1 ) ) ) )
22320adantr 481 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( v  e.  A  /\  k  e.  A ) )  -> 
( P  -  1 )  e.  CC )
224 fzssuz 12382 . . . . . . . . . . . . . . . . . . . . 21  |-  ( 0 ... ( P  - 
1 ) )  C_  ( ZZ>= `  0 )
225 uzssz 11707 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ZZ>= ` 
0 )  C_  ZZ
226 zsscn 11385 . . . . . . . . . . . . . . . . . . . . . 22  |-  ZZ  C_  CC
227225, 226sstri 3612 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ZZ>= ` 
0 )  C_  CC
228224, 227sstri 3612 . . . . . . . . . . . . . . . . . . . 20  |-  ( 0 ... ( P  - 
1 ) )  C_  CC
22915, 228syl6ss 3615 . . . . . . . . . . . . . . . . . . 19  |-  ( ph  ->  A  C_  CC )
230229sselda 3603 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  v  e.  A )  ->  v  e.  CC )
231230adantrr 753 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( v  e.  A  /\  k  e.  A ) )  -> 
v  e.  CC )
232229sselda 3603 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  k  e.  A )  ->  k  e.  CC )
233232adantrl 752 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( v  e.  A  /\  k  e.  A ) )  -> 
k  e.  CC )
234223, 231, 233subcanad 10435 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( v  e.  A  /\  k  e.  A ) )  -> 
( ( ( P  -  1 )  -  v )  =  ( ( P  -  1 )  -  k )  <-> 
v  =  k ) )
235234ex 450 . . . . . . . . . . . . . . 15  |-  ( ph  ->  ( ( v  e.  A  /\  k  e.  A )  ->  (
( ( P  - 
1 )  -  v
)  =  ( ( P  -  1 )  -  k )  <->  v  =  k ) ) )
236222, 235dom2lem 7995 . . . . . . . . . . . . . 14  |-  ( ph  ->  ( v  e.  A  |->  ( ( P  - 
1 )  -  v
) ) : A -1-1-> ( 0 ... ( P  -  1 ) ) )
237 f1eq1 6096 . . . . . . . . . . . . . . 15  |-  ( F  =  ( v  e.  A  |->  ( ( P  -  1 )  -  v ) )  -> 
( F : A -1-1-> ( 0 ... ( P  -  1 ) )  <-> 
( v  e.  A  |->  ( ( P  - 
1 )  -  v
) ) : A -1-1-> ( 0 ... ( P  -  1 ) ) ) )
23828, 237ax-mp 5 . . . . . . . . . . . . . 14  |-  ( F : A -1-1-> ( 0 ... ( P  - 
1 ) )  <->  ( v  e.  A  |->  ( ( P  -  1 )  -  v ) ) : A -1-1-> ( 0 ... ( P  - 
1 ) ) )
239236, 238sylibr 224 . . . . . . . . . . . . 13  |-  ( ph  ->  F : A -1-1-> ( 0 ... ( P  -  1 ) ) )
240 f1f1orn 6148 . . . . . . . . . . . . 13  |-  ( F : A -1-1-> ( 0 ... ( P  - 
1 ) )  ->  F : A -1-1-onto-> ran  F )
241239, 240syl 17 . . . . . . . . . . . 12  |-  ( ph  ->  F : A -1-1-onto-> ran  F
)
242 f1oeng 7974 . . . . . . . . . . . 12  |-  ( ( A  e.  Fin  /\  F : A -1-1-onto-> ran  F )  ->  A  ~~  ran  F )
243214, 241, 242syl2anc 693 . . . . . . . . . . 11  |-  ( ph  ->  A  ~~  ran  F
)
244 ssfi 8180 . . . . . . . . . . . . 13  |-  ( ( ( 0 ... ( P  -  1 ) )  e.  Fin  /\  ran  F  C_  ( 0 ... ( P  - 
1 ) ) )  ->  ran  F  e.  Fin )
2451, 31, 244syl2anc 693 . . . . . . . . . . . 12  |-  ( ph  ->  ran  F  e.  Fin )
246 hashen 13135 . . . . . . . . . . . 12  |-  ( ( A  e.  Fin  /\  ran  F  e.  Fin )  ->  ( ( # `  A
)  =  ( # `  ran  F )  <->  A  ~~  ran  F ) )
247214, 245, 246syl2anc 693 . . . . . . . . . . 11  |-  ( ph  ->  ( ( # `  A
)  =  ( # `  ran  F )  <->  A  ~~  ran  F ) )
248243, 247mpbird 247 . . . . . . . . . 10  |-  ( ph  ->  ( # `  A
)  =  ( # `  ran  F ) )
249248, 221eqtr3d 2658 . . . . . . . . 9  |-  ( ph  ->  ( # `  ran  F )  =  ( N  +  1 ) )
250221, 249oveq12d 6668 . . . . . . . 8  |-  ( ph  ->  ( ( # `  A
)  +  ( # `  ran  F ) )  =  ( ( N  +  1 )  +  ( N  +  1 ) ) )
25162, 71, 2503eqtr4d 2666 . . . . . . 7  |-  ( ph  ->  ( P  +  1 )  =  ( (
# `  A )  +  ( # `  ran  F ) ) )
252251adantr 481 . . . . . 6  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  ( P  +  1 )  =  ( ( # `  A
)  +  ( # `  ran  F ) ) )
253214adantr 481 . . . . . . 7  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  A  e. 
Fin )
254245adantr 481 . . . . . . 7  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  ran  F  e.  Fin )
255 simpr 477 . . . . . . 7  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  ( A  i^i  ran  F )  =  (/) )
256 hashun 13171 . . . . . . 7  |-  ( ( A  e.  Fin  /\  ran  F  e.  Fin  /\  ( A  i^i  ran  F
)  =  (/) )  -> 
( # `  ( A  u.  ran  F ) )  =  ( (
# `  A )  +  ( # `  ran  F ) ) )
257253, 254, 255, 256syl3anc 1326 . . . . . 6  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  ( # `  ( A  u.  ran  F ) )  =  ( ( # `  A
)  +  ( # `  ran  F ) ) )
258252, 257eqtr4d 2659 . . . . 5  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  ( P  +  1 )  =  ( # `  ( A  u.  ran  F ) ) )
25958, 258breqtrd 4679 . . . 4  |-  ( (
ph  /\  ( A  i^i  ran  F )  =  (/) )  ->  P  < 
( # `  ( A  u.  ran  F ) ) )
260259ex 450 . . 3  |-  ( ph  ->  ( ( A  i^i  ran 
F )  =  (/)  ->  P  <  ( # `  ( A  u.  ran  F ) ) ) )
261260necon3bd 2808 . 2  |-  ( ph  ->  ( -.  P  < 
( # `  ( A  u.  ran  F ) )  ->  ( A  i^i  ran  F )  =/=  (/) ) )
26256, 261mpd 15 1  |-  ( ph  ->  ( A  i^i  ran  F )  =/=  (/) )
Colors of variables: wff setvar class
Syntax hints:   -. wn 3    -> wi 4    <-> wb 196    \/ wo 383    /\ wa 384    = wceq 1483    e. wcel 1990   {cab 2608    =/= wne 2794   E.wrex 2913    u. cun 3572    i^i cin 3573    C_ wss 3574   (/)c0 3915   class class class wbr 4653    |-> cmpt 4729   ran crn 5115   -->wf 5884   -1-1->wf1 5885   -1-1-onto->wf1o 5887   ` cfv 5888  (class class class)co 6650    ~~ cen 7952    ~<_ cdom 7953   Fincfn 7955   CCcc 9934   RRcr 9935   0cc0 9936   1c1 9937    + caddc 9939    x. cmul 9941    < clt 10074    <_ cle 10075    - cmin 10266   NNcn 11020   2c2 11070   NN0cn0 11292   ZZcz 11377   ZZ>=cuz 11687   ...cfz 12326    mod cmo 12668   ^cexp 12860   #chash 13117   abscabs 13974    || cdvds 14983   Primecprime 15385
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-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-2o 7561  df-oadd 7564  df-er 7742  df-en 7956  df-dom 7957  df-sdom 7958  df-fin 7959  df-sup 8348  df-inf 8349  df-card 8765  df-cda 8990  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-3 11080  df-n0 11293  df-xnn0 11364  df-z 11378  df-uz 11688  df-rp 11833  df-fz 12327  df-fl 12593  df-mod 12669  df-seq 12802  df-exp 12861  df-hash 13118  df-cj 13839  df-re 13840  df-im 13841  df-sqrt 13975  df-abs 13976  df-dvds 14984  df-gcd 15217  df-prm 15386
This theorem is referenced by:  4sqlem12  15660
  Copyright terms: Public domain W3C validator