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

Theorem 4sqlem12 12540
Description: Lemma for 4sq 12548. For any odd prime  P, there is a  k  <  P such that  k P  -  1 is a sum of two squares. (Contributed by Mario Carneiro, 15-Jul-2014.)
Hypotheses
Ref Expression
4sqlem11.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
4sqlem12  |-  ( ph  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i]  ( ( ( abs `  u
) ^ 2 )  +  1 )  =  ( k  x.  P
) )
Distinct variable groups:    A, k, v   
m, N, u    P, k, v, m, u    ph, k,
v, m, u    n, N, v, m, u    P, n    k, m, n, u,
ph
Allowed substitution hints:    ph( x, y, z, w)    A( x, y, z, w, u, m, n)    P( x, y, z, w)    S( x, y, z, w, v, u, k, m, n)    F( x, y, z, w, v, u, k, m, n)    N( x, y, z, w, k)

Proof of Theorem 4sqlem12
Dummy variable  j is distinct from all other variables.
StepHypRef Expression
1 4sqlem11.1 . . . 4  |-  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 ) ) ) }
2 4sq.2 . . . 4  |-  ( ph  ->  N  e.  NN )
3 4sq.3 . . . 4  |-  ( ph  ->  P  =  ( ( 2  x.  N )  +  1 ) )
4 4sq.4 . . . 4  |-  ( ph  ->  P  e.  Prime )
5 4sqlem11.5 . . . 4  |-  A  =  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P ) }
6 4sqlem11.6 . . . 4  |-  F  =  ( v  e.  A  |->  ( ( P  - 
1 )  -  v
) )
71, 2, 3, 4, 5, 64sqlem11 12539 . . 3  |-  ( ph  ->  ( A  i^i  ran  F )  =/=  (/) )
8 prmnn 12248 . . . . . 6  |-  ( P  e.  Prime  ->  P  e.  NN )
94, 8syl 14 . . . . 5  |-  ( ph  ->  P  e.  NN )
102, 9, 5, 64sqleminfi 12535 . . . 4  |-  ( ph  ->  ( A  i^i  ran  F )  e.  Fin )
11 fin0 6941 . . . 4  |-  ( ( A  i^i  ran  F
)  e.  Fin  ->  ( ( A  i^i  ran  F )  =/=  (/)  <->  E. j 
j  e.  ( A  i^i  ran  F )
) )
1210, 11syl 14 . . 3  |-  ( ph  ->  ( ( A  i^i  ran 
F )  =/=  (/)  <->  E. j 
j  e.  ( A  i^i  ran  F )
) )
137, 12mpbid 147 . 2  |-  ( ph  ->  E. j  j  e.  ( A  i^i  ran  F ) )
14 vex 2763 . . . . . . . 8  |-  j  e. 
_V
15 eqeq1 2200 . . . . . . . . 9  |-  ( u  =  j  ->  (
u  =  ( ( m ^ 2 )  mod  P )  <->  j  =  ( ( m ^
2 )  mod  P
) ) )
1615rexbidv 2495 . . . . . . . 8  |-  ( u  =  j  ->  ( E. m  e.  (
0 ... N ) u  =  ( ( m ^ 2 )  mod 
P )  <->  E. m  e.  ( 0 ... N
) j  =  ( ( m ^ 2 )  mod  P ) ) )
1714, 16, 5elab2 2908 . . . . . . 7  |-  ( j  e.  A  <->  E. m  e.  ( 0 ... N
) j  =  ( ( m ^ 2 )  mod  P ) )
1817a1i 9 . . . . . 6  |-  ( ph  ->  ( j  e.  A  <->  E. m  e.  ( 0 ... N ) j  =  ( ( m ^ 2 )  mod 
P ) ) )
19 abid 2181 . . . . . . . . 9  |-  ( j  e.  { j  |  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) }  <->  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) )
205rexeqi 2695 . . . . . . . . 9  |-  ( E. v  e.  A  j  =  ( ( P  -  1 )  -  v )  <->  E. v  e.  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P ) } j  =  ( ( P  -  1 )  -  v ) )
21 oveq1 5925 . . . . . . . . . . . . . 14  |-  ( m  =  n  ->  (
m ^ 2 )  =  ( n ^
2 ) )
2221oveq1d 5933 . . . . . . . . . . . . 13  |-  ( m  =  n  ->  (
( m ^ 2 )  mod  P )  =  ( ( n ^ 2 )  mod 
P ) )
2322eqeq2d 2205 . . . . . . . . . . . 12  |-  ( m  =  n  ->  (
u  =  ( ( m ^ 2 )  mod  P )  <->  u  =  ( ( n ^
2 )  mod  P
) ) )
2423cbvrexvw 2731 . . . . . . . . . . 11  |-  ( E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P )  <->  E. n  e.  ( 0 ... N
) u  =  ( ( n ^ 2 )  mod  P ) )
25 eqeq1 2200 . . . . . . . . . . . 12  |-  ( u  =  v  ->  (
u  =  ( ( n ^ 2 )  mod  P )  <->  v  =  ( ( n ^
2 )  mod  P
) ) )
2625rexbidv 2495 . . . . . . . . . . 11  |-  ( u  =  v  ->  ( E. n  e.  (
0 ... N ) u  =  ( ( n ^ 2 )  mod 
P )  <->  E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P ) ) )
2724, 26bitrid 192 . . . . . . . . . 10  |-  ( u  =  v  ->  ( E. m  e.  (
0 ... N ) u  =  ( ( m ^ 2 )  mod 
P )  <->  E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P ) ) )
2827rexab 2922 . . . . . . . . 9  |-  ( E. v  e.  { u  |  E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod  P ) } j  =  ( ( P  -  1 )  -  v )  <->  E. v
( E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
2919, 20, 283bitri 206 . . . . . . . 8  |-  ( j  e.  { j  |  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) }  <->  E. v ( E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
306rnmpt 4910 . . . . . . . . 9  |-  ran  F  =  { j  |  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) }
3130eleq2i 2260 . . . . . . . 8  |-  ( j  e.  ran  F  <->  j  e.  { j  |  E. v  e.  A  j  =  ( ( P  - 
1 )  -  v
) } )
32 rexcom4 2783 . . . . . . . . 9  |-  ( E. n  e.  ( 0 ... N ) E. v ( v  =  ( ( n ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  v
) )  <->  E. v E. n  e.  (
0 ... N ) ( v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
33 r19.41v 2650 . . . . . . . . . 10  |-  ( E. n  e.  ( 0 ... N ) ( v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) )  <-> 
( E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
3433exbii 1616 . . . . . . . . 9  |-  ( E. v E. n  e.  ( 0 ... N
) ( v  =  ( ( n ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  v
) )  <->  E. v
( E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
3532, 34bitri 184 . . . . . . . 8  |-  ( E. n  e.  ( 0 ... N ) E. v ( v  =  ( ( n ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  v
) )  <->  E. v
( E. n  e.  ( 0 ... N
) v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
3629, 31, 353bitr4i 212 . . . . . . 7  |-  ( j  e.  ran  F  <->  E. n  e.  ( 0 ... N
) E. v ( v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) ) )
37 elfzelz 10091 . . . . . . . . . . . 12  |-  ( n  e.  ( 0 ... N )  ->  n  e.  ZZ )
3837adantl 277 . . . . . . . . . . 11  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  n  e.  ZZ )
39 zsqcl 10681 . . . . . . . . . . 11  |-  ( n  e.  ZZ  ->  (
n ^ 2 )  e.  ZZ )
4038, 39syl 14 . . . . . . . . . 10  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  (
n ^ 2 )  e.  ZZ )
419adantr 276 . . . . . . . . . 10  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  P  e.  NN )
4240, 41zmodcld 10416 . . . . . . . . 9  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  (
( n ^ 2 )  mod  P )  e.  NN0 )
43 oveq2 5926 . . . . . . . . . . 11  |-  ( v  =  ( ( n ^ 2 )  mod 
P )  ->  (
( P  -  1 )  -  v )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )
4443eqeq2d 2205 . . . . . . . . . 10  |-  ( v  =  ( ( n ^ 2 )  mod 
P )  ->  (
j  =  ( ( P  -  1 )  -  v )  <->  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) ) )
4544ceqsexgv 2889 . . . . . . . . 9  |-  ( ( ( n ^ 2 )  mod  P )  e.  NN0  ->  ( E. v ( v  =  ( ( n ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  v
) )  <->  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) ) )
4642, 45syl 14 . . . . . . . 8  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  ( E. v ( v  =  ( ( n ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  v
) )  <->  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) ) )
4746rexbidva 2491 . . . . . . 7  |-  ( ph  ->  ( E. n  e.  ( 0 ... N
) E. v ( v  =  ( ( n ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  v ) )  <->  E. n  e.  (
0 ... N ) j  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) ) )
4836, 47bitrid 192 . . . . . 6  |-  ( ph  ->  ( j  e.  ran  F  <->  E. n  e.  (
0 ... N ) j  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) ) )
4918, 48anbi12d 473 . . . . 5  |-  ( ph  ->  ( ( j  e.  A  /\  j  e. 
ran  F )  <->  ( E. m  e.  ( 0 ... N ) j  =  ( ( m ^ 2 )  mod 
P )  /\  E. n  e.  ( 0 ... N ) j  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) ) ) )
50 elin 3342 . . . . 5  |-  ( j  e.  ( A  i^i  ran 
F )  <->  ( j  e.  A  /\  j  e.  ran  F ) )
51 reeanv 2664 . . . . 5  |-  ( E. m  e.  ( 0 ... N ) E. n  e.  ( 0 ... N ) ( j  =  ( ( m ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod 
P ) ) )  <-> 
( E. m  e.  ( 0 ... N
) j  =  ( ( m ^ 2 )  mod  P )  /\  E. n  e.  ( 0 ... N
) j  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod  P ) ) ) )
5249, 50, 513bitr4g 223 . . . 4  |-  ( ph  ->  ( j  e.  ( A  i^i  ran  F
)  <->  E. m  e.  ( 0 ... N ) E. n  e.  ( 0 ... N ) ( j  =  ( ( m ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod  P ) ) ) ) )
53 eqtr2 2212 . . . . . 6  |-  ( ( j  =  ( ( m ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod 
P ) ) )  ->  ( ( m ^ 2 )  mod 
P )  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod  P ) ) )
549nnzd 9438 . . . . . . . . . . . . . . . . . . 19  |-  ( ph  ->  P  e.  ZZ )
55 peano2zm 9355 . . . . . . . . . . . . . . . . . . 19  |-  ( P  e.  ZZ  ->  ( P  -  1 )  e.  ZZ )
5654, 55syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( ph  ->  ( P  -  1 )  e.  ZZ )
57 zq 9691 . . . . . . . . . . . . . . . . . 18  |-  ( ( P  -  1 )  e.  ZZ  ->  ( P  -  1 )  e.  QQ )
5856, 57syl 14 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  ( P  -  1 )  e.  QQ )
59583ad2ant1 1020 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  -  1 )  e.  QQ )
60 zq 9691 . . . . . . . . . . . . . . . . . 18  |-  ( P  e.  ZZ  ->  P  e.  QQ )
6154, 60syl 14 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  P  e.  QQ )
62613ad2ant1 1020 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  QQ )
6343ad2ant1 1020 . . . . . . . . . . . . . . . . . . 19  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  Prime )
6463, 8syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  NN )
65 nnm1nn0 9281 . . . . . . . . . . . . . . . . . 18  |-  ( P  e.  NN  ->  ( P  -  1 )  e.  NN0 )
6664, 65syl 14 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  -  1 )  e.  NN0 )
6766nn0ge0d 9296 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <_  ( P  -  1 ) )
6864nnred 8995 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  RR )
6968ltm1d 8951 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  -  1 )  <  P )
70 modqid 10420 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( P  - 
1 )  e.  QQ  /\  P  e.  QQ )  /\  ( 0  <_ 
( P  -  1 )  /\  ( P  -  1 )  < 
P ) )  -> 
( ( P  - 
1 )  mod  P
)  =  ( P  -  1 ) )
7159, 62, 67, 69, 70syl22anc 1250 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( P  - 
1 )  mod  P
)  =  ( P  -  1 ) )
7271oveq1d 5933 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( P  -  1 )  mod 
P )  -  (
( n ^ 2 )  mod  P ) )  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod 
P ) ) )
73 simp2r 1026 . . . . . . . . . . . . . . . . . . . . 21  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  n  e.  ( 0 ... N ) )
7473elfzelzd 10092 . . . . . . . . . . . . . . . . . . . 20  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  n  e.  ZZ )
7574, 39syl 14 . . . . . . . . . . . . . . . . . . 19  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  e.  ZZ )
76 zq 9691 . . . . . . . . . . . . . . . . . . 19  |-  ( ( n ^ 2 )  e.  ZZ  ->  (
n ^ 2 )  e.  QQ )
7775, 76syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  e.  QQ )
7864nngt0d 9026 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <  P )
79 modqlt 10404 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( n ^ 2 )  e.  QQ  /\  P  e.  QQ  /\  0  <  P )  ->  (
( n ^ 2 )  mod  P )  <  P )
8077, 62, 78, 79syl3anc 1249 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( n ^
2 )  mod  P
)  <  P )
8175, 64zmodcld 10416 . . . . . . . . . . . . . . . . . . 19  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( n ^
2 )  mod  P
)  e.  NN0 )
8281nn0zd 9437 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( n ^
2 )  mod  P
)  e.  ZZ )
83 prmz 12249 . . . . . . . . . . . . . . . . . . 19  |-  ( P  e.  Prime  ->  P  e.  ZZ )
8463, 83syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  ZZ )
85 zltlem1 9374 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( ( n ^
2 )  mod  P
)  e.  ZZ  /\  P  e.  ZZ )  ->  ( ( ( n ^ 2 )  mod 
P )  <  P  <->  ( ( n ^ 2 )  mod  P )  <_  ( P  - 
1 ) ) )
8682, 84, 85syl2anc 411 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( n ^ 2 )  mod 
P )  <  P  <->  ( ( n ^ 2 )  mod  P )  <_  ( P  - 
1 ) ) )
8780, 86mpbid 147 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( n ^
2 )  mod  P
)  <_  ( P  -  1 ) )
8887, 71breqtrrd 4057 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( n ^
2 )  mod  P
)  <_  ( ( P  -  1 )  mod  P ) )
89 modqsubdir 10464 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( P  - 
1 )  e.  QQ  /\  ( n ^ 2 )  e.  QQ )  /\  ( P  e.  QQ  /\  0  < 
P ) )  -> 
( ( ( n ^ 2 )  mod 
P )  <_  (
( P  -  1 )  mod  P )  <-> 
( ( ( P  -  1 )  -  ( n ^ 2 ) )  mod  P
)  =  ( ( ( P  -  1 )  mod  P )  -  ( ( n ^ 2 )  mod 
P ) ) ) )
9059, 77, 62, 78, 89syl22anc 1250 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( n ^ 2 )  mod 
P )  <_  (
( P  -  1 )  mod  P )  <-> 
( ( ( P  -  1 )  -  ( n ^ 2 ) )  mod  P
)  =  ( ( ( P  -  1 )  mod  P )  -  ( ( n ^ 2 )  mod 
P ) ) ) )
9188, 90mpbid 147 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( P  -  1 )  -  ( n ^ 2 ) )  mod  P
)  =  ( ( ( P  -  1 )  mod  P )  -  ( ( n ^ 2 )  mod 
P ) ) )
92 simp3 1001 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  mod  P
)  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod 
P ) ) )
9372, 91, 923eqtr4rd 2237 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  mod  P
)  =  ( ( ( P  -  1 )  -  ( n ^ 2 ) )  mod  P ) )
94 simp2l 1025 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  m  e.  ( 0 ... N ) )
9594elfzelzd 10092 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  m  e.  ZZ )
96 zsqcl 10681 . . . . . . . . . . . . . . 15  |-  ( m  e.  ZZ  ->  (
m ^ 2 )  e.  ZZ )
9795, 96syl 14 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m ^ 2 )  e.  ZZ )
9866nn0zd 9437 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  -  1 )  e.  ZZ )
9998, 75zsubcld 9444 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( P  - 
1 )  -  (
n ^ 2 ) )  e.  ZZ )
100 moddvds 11942 . . . . . . . . . . . . . 14  |-  ( ( P  e.  NN  /\  ( m ^ 2 )  e.  ZZ  /\  ( ( P  - 
1 )  -  (
n ^ 2 ) )  e.  ZZ )  ->  ( ( ( m ^ 2 )  mod  P )  =  ( ( ( P  -  1 )  -  ( n ^ 2 ) )  mod  P
)  <->  P  ||  ( ( m ^ 2 )  -  ( ( P  -  1 )  -  ( n ^ 2 ) ) ) ) )
10164, 97, 99, 100syl3anc 1249 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( ( P  - 
1 )  -  (
n ^ 2 ) )  mod  P )  <-> 
P  ||  ( (
m ^ 2 )  -  ( ( P  -  1 )  -  ( n ^ 2 ) ) ) ) )
10293, 101mpbid 147 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  ||  ( ( m ^ 2 )  -  ( ( P  - 
1 )  -  (
n ^ 2 ) ) ) )
103 zsqcl2 10688 . . . . . . . . . . . . . . . 16  |-  ( m  e.  ZZ  ->  (
m ^ 2 )  e.  NN0 )
10495, 103syl 14 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m ^ 2 )  e.  NN0 )
105104nn0cnd 9295 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m ^ 2 )  e.  CC )
10666nn0cnd 9295 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  -  1 )  e.  CC )
107 zsqcl2 10688 . . . . . . . . . . . . . . . 16  |-  ( n  e.  ZZ  ->  (
n ^ 2 )  e.  NN0 )
10874, 107syl 14 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  e.  NN0 )
109108nn0cnd 9295 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  e.  CC )
110105, 106, 109subsub3d 8360 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  -  (
( P  -  1 )  -  ( n ^ 2 ) ) )  =  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  -  ( P  - 
1 ) ) )
111104, 108nn0addcld 9297 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  e.  NN0 )
112111nn0cnd 9295 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  e.  CC )
11364nncnd 8996 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  CC )
114 1cnd 8035 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
1  e.  CC )
115112, 113, 114subsub3d 8360 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  -  ( P  -  1 ) )  =  ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  -  P ) )
116110, 115eqtrd 2226 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  -  (
( P  -  1 )  -  ( n ^ 2 ) ) )  =  ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  -  P ) )
117102, 116breqtrd 4055 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  ||  ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  -  P ) )
118 nn0p1nn 9279 . . . . . . . . . . . . . 14  |-  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  e.  NN0  ->  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  NN )
119111, 118syl 14 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  NN )
120119nnzd 9438 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  ZZ )
121 dvdssubr 11982 . . . . . . . . . . . 12  |-  ( ( P  e.  ZZ  /\  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  ZZ )  ->  ( P  ||  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  <->  P  ||  ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  -  P ) ) )
12284, 120, 121syl2anc 411 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  ||  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  <-> 
P  ||  ( (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  -  P ) ) )
123117, 122mpbird 167 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  ||  ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 ) )
12464nnne0d 9027 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  =/=  0 )
125 dvdsval2 11933 . . . . . . . . . . 11  |-  ( ( P  e.  ZZ  /\  P  =/=  0  /\  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  e.  ZZ )  -> 
( P  ||  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  <-> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  ZZ ) )
12684, 124, 120, 125syl3anc 1249 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  ||  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  <-> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  ZZ ) )
127123, 126mpbid 147 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  ZZ )
128 nnrp 9729 . . . . . . . . . . . . . 14  |-  ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  e.  NN  ->  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  e.  RR+ )
129 nnrp 9729 . . . . . . . . . . . . . 14  |-  ( P  e.  NN  ->  P  e.  RR+ )
130 rpdivcl 9745 . . . . . . . . . . . . . 14  |-  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  RR+  /\  P  e.  RR+ )  ->  (
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  RR+ )
131128, 129, 130syl2an 289 . . . . . . . . . . . . 13  |-  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  NN  /\  P  e.  NN )  ->  ( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  RR+ )
132119, 64, 131syl2anc 411 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  RR+ )
133132rpgt0d 9765 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <  ( (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P ) )
134 elnnz 9327 . . . . . . . . . . 11  |-  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  NN  <->  ( (
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  ZZ  /\  0  <  ( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
) ) )
135127, 133, 134sylanbrc 417 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  NN )
136135nnge1d 9025 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
1  <_  ( (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P ) )
137111nn0red 9294 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  e.  RR )
138 2nn 9143 . . . . . . . . . . . . . . . 16  |-  2  e.  NN
13923ad2ant1 1020 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  N  e.  NN )
140 nnmulcl 9003 . . . . . . . . . . . . . . . 16  |-  ( ( 2  e.  NN  /\  N  e.  NN )  ->  ( 2  x.  N
)  e.  NN )
141138, 139, 140sylancr 414 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  N
)  e.  NN )
142141nnred 8995 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  N
)  e.  RR )
143142resqcld 10770 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( 2  x.  N ) ^ 2 )  e.  RR )
144 nnmulcl 9003 . . . . . . . . . . . . . . 15  |-  ( ( 2  e.  NN  /\  ( 2  x.  N
)  e.  NN )  ->  ( 2  x.  ( 2  x.  N
) )  e.  NN )
145138, 141, 144sylancr 414 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  (
2  x.  N ) )  e.  NN )
146145nnred 8995 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  (
2  x.  N ) )  e.  RR )
147143, 146readdcld 8049 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( 2  x.  N ) ^
2 )  +  ( 2  x.  ( 2  x.  N ) ) )  e.  RR )
148 1red 8034 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
1  e.  RR )
149139nnsqcld 10765 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( N ^ 2 )  e.  NN )
150 nnmulcl 9003 . . . . . . . . . . . . . . . 16  |-  ( ( 2  e.  NN  /\  ( N ^ 2 )  e.  NN )  -> 
( 2  x.  ( N ^ 2 ) )  e.  NN )
151138, 149, 150sylancr 414 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  ( N ^ 2 ) )  e.  NN )
152151nnred 8995 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  ( N ^ 2 ) )  e.  RR )
153104nn0red 9294 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m ^ 2 )  e.  RR )
154108nn0red 9294 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  e.  RR )
155149nnred 8995 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( N ^ 2 )  e.  RR )
15695zred 9439 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  m  e.  RR )
157 elfzle1 10093 . . . . . . . . . . . . . . . . . 18  |-  ( m  e.  ( 0 ... N )  ->  0  <_  m )
15894, 157syl 14 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <_  m )
159139nnred 8995 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  N  e.  RR )
160 elfzle2 10094 . . . . . . . . . . . . . . . . . 18  |-  ( m  e.  ( 0 ... N )  ->  m  <_  N )
16194, 160syl 14 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  m  <_  N )
162 le2sq2 10686 . . . . . . . . . . . . . . . . 17  |-  ( ( ( m  e.  RR  /\  0  <_  m )  /\  ( N  e.  RR  /\  m  <_  N )
)  ->  ( m ^ 2 )  <_ 
( N ^ 2 ) )
163156, 158, 159, 161, 162syl22anc 1250 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m ^ 2 )  <_  ( N ^ 2 ) )
16474zred 9439 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  n  e.  RR )
165 elfzle1 10093 . . . . . . . . . . . . . . . . . 18  |-  ( n  e.  ( 0 ... N )  ->  0  <_  n )
16673, 165syl 14 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <_  n )
167 elfzle2 10094 . . . . . . . . . . . . . . . . . 18  |-  ( n  e.  ( 0 ... N )  ->  n  <_  N )
16873, 167syl 14 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  n  <_  N )
169 le2sq2 10686 . . . . . . . . . . . . . . . . 17  |-  ( ( ( n  e.  RR  /\  0  <_  n )  /\  ( N  e.  RR  /\  n  <_  N )
)  ->  ( n ^ 2 )  <_ 
( N ^ 2 ) )
170164, 166, 159, 168, 169syl22anc 1250 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( n ^ 2 )  <_  ( N ^ 2 ) )
171153, 154, 155, 155, 163, 170le2addd 8582 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  <_  ( ( N ^ 2 )  +  ( N ^ 2 ) ) )
172149nncnd 8996 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( N ^ 2 )  e.  CC )
1731722timesd 9225 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  ( N ^ 2 ) )  =  ( ( N ^ 2 )  +  ( N ^ 2 ) ) )
174171, 173breqtrrd 4057 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  <_  ( 2  x.  ( N ^
2 ) ) )
175 2lt4 9155 . . . . . . . . . . . . . . . 16  |-  2  <  4
176 2re 9052 . . . . . . . . . . . . . . . . . 18  |-  2  e.  RR
177176a1i 9 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
2  e.  RR )
178 4re 9059 . . . . . . . . . . . . . . . . . 18  |-  4  e.  RR
179178a1i 9 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
4  e.  RR )
180149nngt0d 9026 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <  ( N ^ 2 ) )
181 ltmul1 8611 . . . . . . . . . . . . . . . . 17  |-  ( ( 2  e.  RR  /\  4  e.  RR  /\  (
( N ^ 2 )  e.  RR  /\  0  <  ( N ^
2 ) ) )  ->  ( 2  <  4  <->  ( 2  x.  ( N ^ 2 ) )  <  (
4  x.  ( N ^ 2 ) ) ) )
182177, 179, 155, 180, 181syl112anc 1253 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  <  4  <->  ( 2  x.  ( N ^ 2 ) )  <  ( 4  x.  ( N ^ 2 ) ) ) )
183175, 182mpbii 148 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  ( N ^ 2 ) )  <  ( 4  x.  ( N ^ 2 ) ) )
184 2cn 9053 . . . . . . . . . . . . . . . . 17  |-  2  e.  CC
185139nncnd 8996 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  N  e.  CC )
186 sqmul 10672 . . . . . . . . . . . . . . . . 17  |-  ( ( 2  e.  CC  /\  N  e.  CC )  ->  ( ( 2  x.  N ) ^ 2 )  =  ( ( 2 ^ 2 )  x.  ( N ^
2 ) ) )
187184, 185, 186sylancr 414 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( 2  x.  N ) ^ 2 )  =  ( ( 2 ^ 2 )  x.  ( N ^
2 ) ) )
188 sq2 10706 . . . . . . . . . . . . . . . . 17  |-  ( 2 ^ 2 )  =  4
189188oveq1i 5928 . . . . . . . . . . . . . . . 16  |-  ( ( 2 ^ 2 )  x.  ( N ^
2 ) )  =  ( 4  x.  ( N ^ 2 ) )
190187, 189eqtrdi 2242 . . . . . . . . . . . . . . 15  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( 2  x.  N ) ^ 2 )  =  ( 4  x.  ( N ^
2 ) ) )
191183, 190breqtrrd 4057 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  ( N ^ 2 ) )  <  ( ( 2  x.  N ) ^
2 ) )
192137, 152, 143, 174, 191lelttrd 8144 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  <  ( ( 2  x.  N ) ^ 2 ) )
193145nnrpd 9760 . . . . . . . . . . . . . 14  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  (
2  x.  N ) )  e.  RR+ )
194143, 193ltaddrpd 9796 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( 2  x.  N ) ^ 2 )  <  ( ( ( 2  x.  N
) ^ 2 )  +  ( 2  x.  ( 2  x.  N
) ) ) )
195137, 143, 147, 192, 194lttrd 8145 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( m ^
2 )  +  ( n ^ 2 ) )  <  ( ( ( 2  x.  N
) ^ 2 )  +  ( 2  x.  ( 2  x.  N
) ) ) )
196137, 147, 148, 195ltadd1dd 8575 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  <  ( ( ( ( 2  x.  N ) ^ 2 )  +  ( 2  x.  ( 2  x.  N ) ) )  +  1 ) )
19733ad2ant1 1020 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  =  ( (
2  x.  N )  +  1 ) )
198197oveq1d 5933 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P ^ 2 )  =  ( ( ( 2  x.  N
)  +  1 ) ^ 2 ) )
199113sqvald 10741 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P ^ 2 )  =  ( P  x.  P ) )
200141nncnd 8996 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( 2  x.  N
)  e.  CC )
201 binom21 10723 . . . . . . . . . . . . 13  |-  ( ( 2  x.  N )  e.  CC  ->  (
( ( 2  x.  N )  +  1 ) ^ 2 )  =  ( ( ( ( 2  x.  N
) ^ 2 )  +  ( 2  x.  ( 2  x.  N
) ) )  +  1 ) )
202200, 201syl 14 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( 2  x.  N )  +  1 ) ^ 2 )  =  ( ( ( ( 2  x.  N ) ^ 2 )  +  ( 2  x.  ( 2  x.  N ) ) )  +  1 ) )
203198, 199, 2023eqtr3d 2234 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( P  x.  P
)  =  ( ( ( ( 2  x.  N ) ^ 2 )  +  ( 2  x.  ( 2  x.  N ) ) )  +  1 ) )
204196, 203breqtrrd 4057 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  <  ( P  x.  P ) )
205119nnred 8995 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  RR )
206 ltdivmul 8895 . . . . . . . . . . 11  |-  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  RR  /\  P  e.  RR  /\  ( P  e.  RR  /\  0  <  P ) )  -> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  <  P  <->  ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  <  ( P  x.  P ) ) )
207205, 68, 68, 78, 206syl112anc 1253 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  <  P  <->  ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  <  ( P  x.  P ) ) )
208204, 207mpbird 167 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  <  P )
209 1z 9343 . . . . . . . . . 10  |-  1  e.  ZZ
210 elfzm11 10157 . . . . . . . . . 10  |-  ( ( 1  e.  ZZ  /\  P  e.  ZZ )  ->  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  ( 1 ... ( P  -  1 ) )  <-> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  ZZ  /\  1  <_  ( (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  /\  ( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  <  P )
) )
211209, 84, 210sylancr 414 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  ( 1 ... ( P  -  1 ) )  <-> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  e.  ZZ  /\  1  <_  ( (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  /\  ( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  <  P )
) )
212127, 136, 208, 211mpbir3and 1182 . . . . . . . 8  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  ( 1 ... ( P  - 
1 ) ) )
213 gzreim 12517 . . . . . . . . 9  |-  ( ( m  e.  ZZ  /\  n  e.  ZZ )  ->  ( m  +  ( _i  x.  n ) )  e.  ZZ[_i] )
21495, 74, 213syl2anc 411 . . . . . . . 8  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m  +  ( _i  x.  n ) )  e.  ZZ[_i] )
215 gzcn 12510 . . . . . . . . . . . . 13  |-  ( ( m  +  ( _i  x.  n ) )  e.  ZZ[_i]  ->  ( m  +  ( _i  x.  n ) )  e.  CC )
216214, 215syl 14 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( m  +  ( _i  x.  n ) )  e.  CC )
217216absvalsq2d 11327 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( abs `  (
m  +  ( _i  x.  n ) ) ) ^ 2 )  =  ( ( ( Re `  ( m  +  ( _i  x.  n ) ) ) ^ 2 )  +  ( ( Im `  ( m  +  (
_i  x.  n )
) ) ^ 2 ) ) )
218156, 164crred 11120 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( Re `  (
m  +  ( _i  x.  n ) ) )  =  m )
219218oveq1d 5933 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( Re `  ( m  +  (
_i  x.  n )
) ) ^ 2 )  =  ( m ^ 2 ) )
220156, 164crimd 11121 . . . . . . . . . . . . 13  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( Im `  (
m  +  ( _i  x.  n ) ) )  =  n )
221220oveq1d 5933 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( Im `  ( m  +  (
_i  x.  n )
) ) ^ 2 )  =  ( n ^ 2 ) )
222219, 221oveq12d 5936 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( Re
`  ( m  +  ( _i  x.  n
) ) ) ^
2 )  +  ( ( Im `  (
m  +  ( _i  x.  n ) ) ) ^ 2 ) )  =  ( ( m ^ 2 )  +  ( n ^
2 ) ) )
223217, 222eqtrd 2226 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( abs `  (
m  +  ( _i  x.  n ) ) ) ^ 2 )  =  ( ( m ^ 2 )  +  ( n ^ 2 ) ) )
224223oveq1d 5933 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 )  =  ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 ) )
225119nncnd 8996 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  e.  CC )
22664nnap0d 9028 . . . . . . . . . 10  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P #  0 )
227225, 113, 226divcanap1d 8810 . . . . . . . . 9  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P
)  =  ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 ) )
228224, 227eqtr4d 2229 . . . . . . . 8  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
( ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 )  =  ( ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P ) )
229 oveq1 5925 . . . . . . . . . 10  |-  ( k  =  ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  ->  (
k  x.  P )  =  ( ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P ) )
230229eqeq2d 2205 . . . . . . . . 9  |-  ( k  =  ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  ->  (
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P )  <->  ( (
( abs `  u
) ^ 2 )  +  1 )  =  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P
) ) )
231 fveq2 5554 . . . . . . . . . . . 12  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  ( abs `  u )  =  ( abs `  (
m  +  ( _i  x.  n ) ) ) )
232231oveq1d 5933 . . . . . . . . . . 11  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  (
( abs `  u
) ^ 2 )  =  ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 ) )
233232oveq1d 5933 . . . . . . . . . 10  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  (
( ( abs `  u
) ^ 2 )  +  1 )  =  ( ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 ) )
234233eqeq1d 2202 . . . . . . . . 9  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  (
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P )  <->  ( (
( abs `  (
m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 )  =  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P
) ) )
235230, 234rspc2ev 2879 . . . . . . . 8  |-  ( ( ( ( ( ( m ^ 2 )  +  ( n ^
2 ) )  +  1 )  /  P
)  e.  ( 1 ... ( P  - 
1 ) )  /\  ( m  +  (
_i  x.  n )
)  e.  ZZ[_i]  /\  (
( ( abs `  (
m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 )  =  ( ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P
) )  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i] 
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P ) )
236212, 214, 228, 235syl3anc 1249 . . . . . . 7  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  E. k  e.  (
1 ... ( P  - 
1 ) ) E. u  e.  ZZ[_i]  ( (
( abs `  u
) ^ 2 )  +  1 )  =  ( k  x.  P
) )
2372363expia 1207 . . . . . 6  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) ) )  -> 
( ( ( m ^ 2 )  mod 
P )  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod  P ) )  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i]  ( ( ( abs `  u
) ^ 2 )  +  1 )  =  ( k  x.  P
) ) )
23853, 237syl5 32 . . . . 5  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) ) )  -> 
( ( j  =  ( ( m ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) )  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i] 
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P ) ) )
239238rexlimdvva 2619 . . . 4  |-  ( ph  ->  ( E. m  e.  ( 0 ... N
) E. n  e.  ( 0 ... N
) ( j  =  ( ( m ^
2 )  mod  P
)  /\  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) )  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i] 
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P ) ) )
24052, 239sylbid 150 . . 3  |-  ( ph  ->  ( j  e.  ( A  i^i  ran  F
)  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i] 
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P ) ) )
241240exlimdv 1830 . 2  |-  ( ph  ->  ( E. j  j  e.  ( A  i^i  ran 
F )  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i] 
( ( ( abs `  u ) ^ 2 )  +  1 )  =  ( k  x.  P ) ) )
24213, 241mpd 13 1  |-  ( ph  ->  E. k  e.  ( 1 ... ( P  -  1 ) ) E. u  e.  ZZ[_i]  ( ( ( abs `  u
) ^ 2 )  +  1 )  =  ( k  x.  P
) )
Colors of variables: wff set class
Syntax hints:    -> wi 4    /\ wa 104    <-> wb 105    /\ w3a 980    = wceq 1364   E.wex 1503    e. wcel 2164   {cab 2179    =/= wne 2364   E.wrex 2473    i^i cin 3152   (/)c0 3446   class class class wbr 4029    |-> cmpt 4090   ran crn 4660   ` cfv 5254  (class class class)co 5918   Fincfn 6794   CCcc 7870   RRcr 7871   0cc0 7872   1c1 7873   _ici 7874    + caddc 7875    x. cmul 7877    < clt 8054    <_ cle 8055    - cmin 8190    / cdiv 8691   NNcn 8982   2c2 9033   4c4 9035   NN0cn0 9240   ZZcz 9317   QQcq 9684   RR+crp 9719   ...cfz 10074    mod cmo 10393   ^cexp 10609   Recre 10984   Imcim 10985   abscabs 11141    || cdvds 11930   Primecprime 12245   ZZ[_i]cgz 12507
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 615  ax-in2 616  ax-io 710  ax-5 1458  ax-7 1459  ax-gen 1460  ax-ie1 1504  ax-ie2 1505  ax-8 1515  ax-10 1516  ax-11 1517  ax-i12 1518  ax-bndl 1520  ax-4 1521  ax-17 1537  ax-i9 1541  ax-ial 1545  ax-i5r 1546  ax-13 2166  ax-14 2167  ax-ext 2175  ax-coll 4144  ax-sep 4147  ax-nul 4155  ax-pow 4203  ax-pr 4238  ax-un 4464  ax-setind 4569  ax-iinf 4620  ax-cnex 7963  ax-resscn 7964  ax-1cn 7965  ax-1re 7966  ax-icn 7967  ax-addcl 7968  ax-addrcl 7969  ax-mulcl 7970  ax-mulrcl 7971  ax-addcom 7972  ax-mulcom 7973  ax-addass 7974  ax-mulass 7975  ax-distr 7976  ax-i2m1 7977  ax-0lt1 7978  ax-1rid 7979  ax-0id 7980  ax-rnegex 7981  ax-precex 7982  ax-cnre 7983  ax-pre-ltirr 7984  ax-pre-ltwlin 7985  ax-pre-lttrn 7986  ax-pre-apti 7987  ax-pre-ltadd 7988  ax-pre-mulgt0 7989  ax-pre-mulext 7990  ax-arch 7991  ax-caucvg 7992
This theorem depends on definitions:  df-bi 117  df-stab 832  df-dc 836  df-3or 981  df-3an 982  df-tru 1367  df-fal 1370  df-nf 1472  df-sb 1774  df-eu 2045  df-mo 2046  df-clab 2180  df-cleq 2186  df-clel 2189  df-nfc 2325  df-ne 2365  df-nel 2460  df-ral 2477  df-rex 2478  df-reu 2479  df-rmo 2480  df-rab 2481  df-v 2762  df-sbc 2986  df-csb 3081  df-dif 3155  df-un 3157  df-in 3159  df-ss 3166  df-nul 3447  df-if 3558  df-pw 3603  df-sn 3624  df-pr 3625  df-op 3627  df-uni 3836  df-int 3871  df-iun 3914  df-br 4030  df-opab 4091  df-mpt 4092  df-tr 4128  df-id 4324  df-po 4327  df-iso 4328  df-iord 4397  df-on 4399  df-ilim 4400  df-suc 4402  df-iom 4623  df-xp 4665  df-rel 4666  df-cnv 4667  df-co 4668  df-dm 4669  df-rn 4670  df-res 4671  df-ima 4672  df-iota 5215  df-fun 5256  df-fn 5257  df-f 5258  df-f1 5259  df-fo 5260  df-f1o 5261  df-fv 5262  df-riota 5873  df-ov 5921  df-oprab 5922  df-mpo 5923  df-1st 6193  df-2nd 6194  df-recs 6358  df-irdg 6423  df-frec 6444  df-1o 6469  df-2o 6470  df-oadd 6473  df-er 6587  df-en 6795  df-dom 6796  df-fin 6797  df-sup 7043  df-pnf 8056  df-mnf 8057  df-xr 8058  df-ltxr 8059  df-le 8060  df-sub 8192  df-neg 8193  df-reap 8594  df-ap 8601  df-div 8692  df-inn 8983  df-2 9041  df-3 9042  df-4 9043  df-n0 9241  df-z 9318  df-uz 9593  df-q 9685  df-rp 9720  df-fz 10075  df-fzo 10209  df-fl 10339  df-mod 10394  df-seqfrec 10519  df-exp 10610  df-ihash 10847  df-cj 10986  df-re 10987  df-im 10988  df-rsqrt 11142  df-abs 11143  df-dvds 11931  df-gcd 12080  df-prm 12246  df-gz 12508
This theorem is referenced by:  4sqlem13m  12541
  Copyright terms: Public domain W3C validator