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

Theorem 4sqlem12 12758
Description: Lemma for 4sq 12766. 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 12757 . . 3  |-  ( ph  ->  ( A  i^i  ran  F )  =/=  (/) )
8 prmnn 12465 . . . . . 6  |-  ( P  e.  Prime  ->  P  e.  NN )
94, 8syl 14 . . . . 5  |-  ( ph  ->  P  e.  NN )
102, 9, 5, 64sqleminfi 12753 . . . 4  |-  ( ph  ->  ( A  i^i  ran  F )  e.  Fin )
11 fin0 6984 . . . 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 2775 . . . . . . . 8  |-  j  e. 
_V
15 eqeq1 2212 . . . . . . . . 9  |-  ( u  =  j  ->  (
u  =  ( ( m ^ 2 )  mod  P )  <->  j  =  ( ( m ^
2 )  mod  P
) ) )
1615rexbidv 2507 . . . . . . . 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 2921 . . . . . . 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 2193 . . . . . . . . 9  |-  ( j  e.  { j  |  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) }  <->  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) )
205rexeqi 2707 . . . . . . . . 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 5953 . . . . . . . . . . . . . 14  |-  ( m  =  n  ->  (
m ^ 2 )  =  ( n ^
2 ) )
2221oveq1d 5961 . . . . . . . . . . . . 13  |-  ( m  =  n  ->  (
( m ^ 2 )  mod  P )  =  ( ( n ^ 2 )  mod 
P ) )
2322eqeq2d 2217 . . . . . . . . . . . 12  |-  ( m  =  n  ->  (
u  =  ( ( m ^ 2 )  mod  P )  <->  u  =  ( ( n ^
2 )  mod  P
) ) )
2423cbvrexvw 2743 . . . . . . . . . . 11  |-  ( E. m  e.  ( 0 ... N ) u  =  ( ( m ^ 2 )  mod 
P )  <->  E. n  e.  ( 0 ... N
) u  =  ( ( n ^ 2 )  mod  P ) )
25 eqeq1 2212 . . . . . . . . . . . 12  |-  ( u  =  v  ->  (
u  =  ( ( n ^ 2 )  mod  P )  <->  v  =  ( ( n ^
2 )  mod  P
) ) )
2625rexbidv 2507 . . . . . . . . . . 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 2935 . . . . . . . . 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 4927 . . . . . . . . 9  |-  ran  F  =  { j  |  E. v  e.  A  j  =  ( ( P  -  1 )  -  v ) }
3130eleq2i 2272 . . . . . . . 8  |-  ( j  e.  ran  F  <->  j  e.  { j  |  E. v  e.  A  j  =  ( ( P  - 
1 )  -  v
) } )
32 rexcom4 2795 . . . . . . . . 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 2662 . . . . . . . . . 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 1628 . . . . . . . . 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 10149 . . . . . . . . . . . 12  |-  ( n  e.  ( 0 ... N )  ->  n  e.  ZZ )
3837adantl 277 . . . . . . . . . . 11  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  n  e.  ZZ )
39 zsqcl 10757 . . . . . . . . . . 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 10492 . . . . . . . . 9  |-  ( (
ph  /\  n  e.  ( 0 ... N
) )  ->  (
( n ^ 2 )  mod  P )  e.  NN0 )
43 oveq2 5954 . . . . . . . . . . 11  |-  ( v  =  ( ( n ^ 2 )  mod 
P )  ->  (
( P  -  1 )  -  v )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )
4443eqeq2d 2217 . . . . . . . . . 10  |-  ( v  =  ( ( n ^ 2 )  mod 
P )  ->  (
j  =  ( ( P  -  1 )  -  v )  <->  j  =  ( ( P  - 
1 )  -  (
( n ^ 2 )  mod  P ) ) ) )
4544ceqsexgv 2902 . . . . . . . . 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 2503 . . . . . . 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 3356 . . . . 5  |-  ( j  e.  ( A  i^i  ran 
F )  <->  ( j  e.  A  /\  j  e.  ran  F ) )
51 reeanv 2676 . . . . 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 2224 . . . . . 6  |-  ( ( j  =  ( ( m ^ 2 )  mod  P )  /\  j  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod 
P ) ) )  ->  ( ( m ^ 2 )  mod 
P )  =  ( ( P  -  1 )  -  ( ( n ^ 2 )  mod  P ) ) )
549nnzd 9496 . . . . . . . . . . . . . . . . . . 19  |-  ( ph  ->  P  e.  ZZ )
55 peano2zm 9412 . . . . . . . . . . . . . . . . . . 19  |-  ( P  e.  ZZ  ->  ( P  -  1 )  e.  ZZ )
5654, 55syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( ph  ->  ( P  -  1 )  e.  ZZ )
57 zq 9749 . . . . . . . . . . . . . . . . . 18  |-  ( ( P  -  1 )  e.  ZZ  ->  ( P  -  1 )  e.  QQ )
5856, 57syl 14 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  ( P  -  1 )  e.  QQ )
59583ad2ant1 1021 . . . . . . . . . . . . . . . 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 9749 . . . . . . . . . . . . . . . . . 18  |-  ( P  e.  ZZ  ->  P  e.  QQ )
6154, 60syl 14 . . . . . . . . . . . . . . . . 17  |-  ( ph  ->  P  e.  QQ )
62613ad2ant1 1021 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  QQ )
6343ad2ant1 1021 . . . . . . . . . . . . . . . . . . 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 9338 . . . . . . . . . . . . . . . . . 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 9353 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <_  ( P  -  1 ) )
6864nnred 9051 . . . . . . . . . . . . . . . . 17  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  e.  RR )
6968ltm1d 9007 . . . . . . . . . . . . . . . 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 10496 . . . . . . . . . . . . . . . 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 1251 . . . . . . . . . . . . . . 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 5961 . . . . . . . . . . . . . 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 1027 . . . . . . . . . . . . . . . . . . . . 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 10150 . . . . . . . . . . . . . . . . . . . 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 9749 . . . . . . . . . . . . . . . . . . 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 9082 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
0  <  P )
79 modqlt 10480 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( n ^ 2 )  e.  QQ  /\  P  e.  QQ  /\  0  <  P )  ->  (
( n ^ 2 )  mod  P )  <  P )
8077, 62, 78, 79syl3anc 1250 . . . . . . . . . . . . . . . . 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 10492 . . . . . . . . . . . . . . . . . . 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 9495 . . . . . . . . . . . . . . . . . 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 12466 . . . . . . . . . . . . . . . . . . 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 9432 . . . . . . . . . . . . . . . . . 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 4073 . . . . . . . . . . . . . . 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 10540 . . . . . . . . . . . . . . . 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 1251 . . . . . . . . . . . . . . 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 1002 . . . . . . . . . . . . . 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 2249 . . . . . . . . . . . . 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 1026 . . . . . . . . . . . . . . . 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 10150 . . . . . . . . . . . . . . 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 10757 . . . . . . . . . . . . . . 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 9495 . . . . . . . . . . . . . . 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 9502 . . . . . . . . . . . . . 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 12143 . . . . . . . . . . . . . 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 1250 . . . . . . . . . . . . 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 10764 . . . . . . . . . . . . . . . 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 9352 . . . . . . . . . . . . . 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 9352 . . . . . . . . . . . . . 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 10764 . . . . . . . . . . . . . . . 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 9352 . . . . . . . . . . . . . 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 8415 . . . . . . . . . . . . 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 9354 . . . . . . . . . . . . . . 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 9352 . . . . . . . . . . . . . 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 9052 . . . . . . . . . . . . . 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 8090 . . . . . . . . . . . . . 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 8415 . . . . . . . . . . . . 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 2238 . . . . . . . . . . . 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 4071 . . . . . . . . . . 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 9336 . . . . . . . . . . . . . 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 9496 . . . . . . . . . . . 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 12183 . . . . . . . . . . . 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 9083 . . . . . . . . . . 11  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  ->  P  =/=  0 )
125 dvdsval2 12134 . . . . . . . . . . 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 1250 . . . . . . . . . 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 9787 . . . . . . . . . . . . . 14  |-  ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  e.  NN  ->  (
( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  e.  RR+ )
129 nnrp 9787 . . . . . . . . . . . . . 14  |-  ( P  e.  NN  ->  P  e.  RR+ )
130 rpdivcl 9803 . . . . . . . . . . . . . 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 9823 . . . . . . . . . . 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 9384 . . . . . . . . . . 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 9081 . . . . . . . . 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 9351 . . . . . . . . . . . 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 9200 . . . . . . . . . . . . . . . 16  |-  2  e.  NN
13923ad2ant1 1021 . . . . . . . . . . . . . . . 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 9059 . . . . . . . . . . . . . . . 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 9051 . . . . . . . . . . . . . 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 10846 . . . . . . . . . . . . 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 9059 . . . . . . . . . . . . . . 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 9051 . . . . . . . . . . . . 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 8104 . . . . . . . . . . . 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 8089 . . . . . . . . . . . 12  |-  ( (
ph  /\  ( m  e.  ( 0 ... N
)  /\  n  e.  ( 0 ... N
) )  /\  (
( m ^ 2 )  mod  P )  =  ( ( P  -  1 )  -  ( ( n ^
2 )  mod  P
) ) )  -> 
1  e.  RR )
149139nnsqcld 10841 . . . . . . . . . . . . . . . 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 9059 . . . . . . . . . . . . . . . 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 9051 . . . . . . . . . . . . . 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 9351 . . . . . . . . . . . . . . . 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 9351 . . . . . . . . . . . . . . . 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 9051 . . . . . . . . . . . . . . . 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 9497 . . . . . . . . . . . . . . . . 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 10151 . . . . . . . . . . . . . . . . . 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 9051 . . . . . . . . . . . . . . . . 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 10152 . . . . . . . . . . . . . . . . . 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 10762 . . . . . . . . . . . . . . . . 17  |-  ( ( ( m  e.  RR  /\  0  <_  m )  /\  ( N  e.  RR  /\  m  <_  N )
)  ->  ( m ^ 2 )  <_ 
( N ^ 2 ) )
163156, 158, 159, 161, 162syl22anc 1251 . . . . . . . . . . . . . . . 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 9497 . . . . . . . . . . . . . . . . 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 10151 . . . . . . . . . . . . . . . . . 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 10152 . . . . . . . . . . . . . . . . . 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 10762 . . . . . . . . . . . . . . . . 17  |-  ( ( ( n  e.  RR  /\  0  <_  n )  /\  ( N  e.  RR  /\  n  <_  N )
)  ->  ( n ^ 2 )  <_ 
( N ^ 2 ) )
170164, 166, 159, 168, 169syl22anc 1251 . . . . . . . . . . . . . . . 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 8638 . . . . . . . . . . . . . . 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 9052 . . . . . . . . . . . . . . . 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 9282 . . . . . . . . . . . . . . 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 4073 . . . . . . . . . . . . . 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 9212 . . . . . . . . . . . . . . . 16  |-  2  <  4
176 2re 9108 . . . . . . . . . . . . . . . . . 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 9115 . . . . . . . . . . . . . . . . . 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 9082 . . . . . . . . . . . . . . . . 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 8667 . . . . . . . . . . . . . . . . 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 1254 . . . . . . . . . . . . . . . 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 9109 . . . . . . . . . . . . . . . . 17  |-  2  e.  CC
185139nncnd 9052 . . . . . . . . . . . . . . . . 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 10748 . . . . . . . . . . . . . . . . 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 10782 . . . . . . . . . . . . . . . . 17  |-  ( 2 ^ 2 )  =  4
189188oveq1i 5956 . . . . . . . . . . . . . . . 16  |-  ( ( 2 ^ 2 )  x.  ( N ^
2 ) )  =  ( 4  x.  ( N ^ 2 ) )
190187, 189eqtrdi 2254 . . . . . . . . . . . . . . 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 4073 . . . . . . . . . . . . . 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 8199 . . . . . . . . . . . . 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 9818 . . . . . . . . . . . . . 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 9854 . . . . . . . . . . . . 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 8200 . . . . . . . . . . . 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 8631 . . . . . . . . . . 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 1021 . . . . . . . . . . . . 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 5961 . . . . . . . . . . . 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 10817 . . . . . . . . . . . 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 9052 . . . . . . . . . . . . 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 10799 . . . . . . . . . . . . 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 2246 . . . . . . . . . . 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 4073 . . . . . . . . . 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 9051 . . . . . . . . . . 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 8951 . . . . . . . . . . 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 1254 . . . . . . . . . 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 9400 . . . . . . . . . 10  |-  1  e.  ZZ
210 elfzm11 10215 . . . . . . . . . 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 1183 . . . . . . . 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 12735 . . . . . . . . 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 12728 . . . . . . . . . . . . 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 11527 . . . . . . . . . . 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 11320 . . . . . . . . . . . . 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 5961 . . . . . . . . . . . 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 11321 . . . . . . . . . . . . 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 5961 . . . . . . . . . . . 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 5964 . . . . . . . . . . 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 2238 . . . . . . . . . 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 5961 . . . . . . . . 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 9052 . . . . . . . . . 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 9084 . . . . . . . . . 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 8866 . . . . . . . . 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 2241 . . . . . . . 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 5953 . . . . . . . . . 10  |-  ( k  =  ( ( ( ( m ^ 2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  ->  (
k  x.  P )  =  ( ( ( ( ( m ^
2 )  +  ( n ^ 2 ) )  +  1 )  /  P )  x.  P ) )
230229eqeq2d 2217 . . . . . . . . 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 5578 . . . . . . . . . . . 12  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  ( abs `  u )  =  ( abs `  (
m  +  ( _i  x.  n ) ) ) )
232231oveq1d 5961 . . . . . . . . . . 11  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  (
( abs `  u
) ^ 2 )  =  ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 ) )
233232oveq1d 5961 . . . . . . . . . 10  |-  ( u  =  ( m  +  ( _i  x.  n
) )  ->  (
( ( abs `  u
) ^ 2 )  +  1 )  =  ( ( ( abs `  ( m  +  ( _i  x.  n ) ) ) ^ 2 )  +  1 ) )
234233eqeq1d 2214 . . . . . . . . 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 2892 . . . . . . . 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 1250 . . . . . . 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 1208 . . . . . 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 2631 . . . 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 1842 . 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 981    = wceq 1373   E.wex 1515    e. wcel 2176   {cab 2191    =/= wne 2376   E.wrex 2485    i^i cin 3165   (/)c0 3460   class class class wbr 4045    |-> cmpt 4106   ran crn 4677   ` cfv 5272  (class class class)co 5946   Fincfn 6829   CCcc 7925   RRcr 7926   0cc0 7927   1c1 7928   _ici 7929    + caddc 7930    x. cmul 7932    < clt 8109    <_ cle 8110    - cmin 8245    / cdiv 8747   NNcn 9038   2c2 9089   4c4 9091   NN0cn0 9297   ZZcz 9374   QQcq 9742   RR+crp 9777   ...cfz 10132    mod cmo 10469   ^cexp 10685   Recre 11184   Imcim 11185   abscabs 11341    || cdvds 12131   Primecprime 12462   ZZ[_i]cgz 12725
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 711  ax-5 1470  ax-7 1471  ax-gen 1472  ax-ie1 1516  ax-ie2 1517  ax-8 1527  ax-10 1528  ax-11 1529  ax-i12 1530  ax-bndl 1532  ax-4 1533  ax-17 1549  ax-i9 1553  ax-ial 1557  ax-i5r 1558  ax-13 2178  ax-14 2179  ax-ext 2187  ax-coll 4160  ax-sep 4163  ax-nul 4171  ax-pow 4219  ax-pr 4254  ax-un 4481  ax-setind 4586  ax-iinf 4637  ax-cnex 8018  ax-resscn 8019  ax-1cn 8020  ax-1re 8021  ax-icn 8022  ax-addcl 8023  ax-addrcl 8024  ax-mulcl 8025  ax-mulrcl 8026  ax-addcom 8027  ax-mulcom 8028  ax-addass 8029  ax-mulass 8030  ax-distr 8031  ax-i2m1 8032  ax-0lt1 8033  ax-1rid 8034  ax-0id 8035  ax-rnegex 8036  ax-precex 8037  ax-cnre 8038  ax-pre-ltirr 8039  ax-pre-ltwlin 8040  ax-pre-lttrn 8041  ax-pre-apti 8042  ax-pre-ltadd 8043  ax-pre-mulgt0 8044  ax-pre-mulext 8045  ax-arch 8046  ax-caucvg 8047
This theorem depends on definitions:  df-bi 117  df-stab 833  df-dc 837  df-3or 982  df-3an 983  df-tru 1376  df-fal 1379  df-nf 1484  df-sb 1786  df-eu 2057  df-mo 2058  df-clab 2192  df-cleq 2198  df-clel 2201  df-nfc 2337  df-ne 2377  df-nel 2472  df-ral 2489  df-rex 2490  df-reu 2491  df-rmo 2492  df-rab 2493  df-v 2774  df-sbc 2999  df-csb 3094  df-dif 3168  df-un 3170  df-in 3172  df-ss 3179  df-nul 3461  df-if 3572  df-pw 3618  df-sn 3639  df-pr 3640  df-op 3642  df-uni 3851  df-int 3886  df-iun 3929  df-br 4046  df-opab 4107  df-mpt 4108  df-tr 4144  df-id 4341  df-po 4344  df-iso 4345  df-iord 4414  df-on 4416  df-ilim 4417  df-suc 4419  df-iom 4640  df-xp 4682  df-rel 4683  df-cnv 4684  df-co 4685  df-dm 4686  df-rn 4687  df-res 4688  df-ima 4689  df-iota 5233  df-fun 5274  df-fn 5275  df-f 5276  df-f1 5277  df-fo 5278  df-f1o 5279  df-fv 5280  df-riota 5901  df-ov 5949  df-oprab 5950  df-mpo 5951  df-1st 6228  df-2nd 6229  df-recs 6393  df-irdg 6458  df-frec 6479  df-1o 6504  df-2o 6505  df-oadd 6508  df-er 6622  df-en 6830  df-dom 6831  df-fin 6832  df-sup 7088  df-pnf 8111  df-mnf 8112  df-xr 8113  df-ltxr 8114  df-le 8115  df-sub 8247  df-neg 8248  df-reap 8650  df-ap 8657  df-div 8748  df-inn 9039  df-2 9097  df-3 9098  df-4 9099  df-n0 9298  df-z 9375  df-uz 9651  df-q 9743  df-rp 9778  df-fz 10133  df-fzo 10267  df-fl 10415  df-mod 10470  df-seqfrec 10595  df-exp 10686  df-ihash 10923  df-cj 11186  df-re 11187  df-im 11188  df-rsqrt 11342  df-abs 11343  df-dvds 12132  df-gcd 12308  df-prm 12463  df-gz 12726
This theorem is referenced by:  4sqlem13m  12759
  Copyright terms: Public domain W3C validator