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

Theorem lgseisen 15939
Description: Eisenstein's lemma, an expression for  ( P  /L Q ) when  P ,  Q are distinct odd primes. (Contributed by Mario Carneiro, 18-Jun-2015.)
Hypotheses
Ref Expression
lgseisen.1  |-  ( ph  ->  P  e.  ( Prime  \  { 2 } ) )
lgseisen.2  |-  ( ph  ->  Q  e.  ( Prime  \  { 2 } ) )
lgseisen.3  |-  ( ph  ->  P  =/=  Q )
Assertion
Ref Expression
lgseisen  |-  ( ph  ->  ( Q  /L
P )  =  (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) ) )
Distinct variable groups:    x, P    ph, x    x, Q

Proof of Theorem lgseisen
Dummy variable  y is distinct from all other variables.
StepHypRef Expression
1 lgseisen.2 . . . . 5  |-  ( ph  ->  Q  e.  ( Prime  \  { 2 } ) )
21eldifad 3221 . . . 4  |-  ( ph  ->  Q  e.  Prime )
3 prmz 12804 . . . 4  |-  ( Q  e.  Prime  ->  Q  e.  ZZ )
42, 3syl 14 . . 3  |-  ( ph  ->  Q  e.  ZZ )
5 lgseisen.1 . . 3  |-  ( ph  ->  P  e.  ( Prime  \  { 2 } ) )
6 lgsval3 15883 . . 3  |-  ( ( Q  e.  ZZ  /\  P  e.  ( Prime  \  { 2 } ) )  ->  ( Q  /L P )  =  ( ( ( ( Q ^ ( ( P  -  1 )  /  2 ) )  +  1 )  mod 
P )  -  1 ) )
74, 5, 6syl2anc 411 . 2  |-  ( ph  ->  ( Q  /L
P )  =  ( ( ( ( Q ^ ( ( P  -  1 )  / 
2 ) )  +  1 )  mod  P
)  -  1 ) )
81gausslemma2dlem0a 15914 . . . . . . 7  |-  ( ph  ->  Q  e.  NN )
9 oddprm 12953 . . . . . . . . 9  |-  ( P  e.  ( Prime  \  {
2 } )  -> 
( ( P  - 
1 )  /  2
)  e.  NN )
105, 9syl 14 . . . . . . . 8  |-  ( ph  ->  ( ( P  - 
1 )  /  2
)  e.  NN )
1110nnnn0d 9552 . . . . . . 7  |-  ( ph  ->  ( ( P  - 
1 )  /  2
)  e.  NN0 )
128, 11nnexpcld 11056 . . . . . 6  |-  ( ph  ->  ( Q ^ (
( P  -  1 )  /  2 ) )  e.  NN )
13 nnq 9964 . . . . . 6  |-  ( ( Q ^ ( ( P  -  1 )  /  2 ) )  e.  NN  ->  ( Q ^ ( ( P  -  1 )  / 
2 ) )  e.  QQ )
1412, 13syl 14 . . . . 5  |-  ( ph  ->  ( Q ^ (
( P  -  1 )  /  2 ) )  e.  QQ )
15 1zzd 9603 . . . . . . . 8  |-  ( ph  ->  1  e.  ZZ )
1615znegcld 9701 . . . . . . 7  |-  ( ph  -> 
-u 1  e.  ZZ )
17 zq 9957 . . . . . . 7  |-  ( -u
1  e.  ZZ  ->  -u
1  e.  QQ )
1816, 17syl 14 . . . . . 6  |-  ( ph  -> 
-u 1  e.  QQ )
19 neg1ne0 9343 . . . . . . 7  |-  -u 1  =/=  0
2019a1i 9 . . . . . 6  |-  ( ph  -> 
-u 1  =/=  0
)
2110nnzd 9698 . . . . . . . 8  |-  ( ph  ->  ( ( P  - 
1 )  /  2
)  e.  ZZ )
2215, 21fzfigd 10792 . . . . . . 7  |-  ( ph  ->  ( 1 ... (
( P  -  1 )  /  2 ) )  e.  Fin )
235gausslemma2dlem0a 15914 . . . . . . . . . 10  |-  ( ph  ->  P  e.  NN )
24 znq 9955 . . . . . . . . . 10  |-  ( ( Q  e.  ZZ  /\  P  e.  NN )  ->  ( Q  /  P
)  e.  QQ )
254, 23, 24syl2anc 411 . . . . . . . . 9  |-  ( ph  ->  ( Q  /  P
)  e.  QQ )
26 2z 9604 . . . . . . . . . . . 12  |-  2  e.  ZZ
2726a1i 9 . . . . . . . . . . 11  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  2  e.  ZZ )
28 elfznn 10387 . . . . . . . . . . . . 13  |-  ( x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) )  ->  x  e.  NN )
2928adantl 277 . . . . . . . . . . . 12  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  x  e.  NN )
3029nnzd 9698 . . . . . . . . . . 11  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  x  e.  ZZ )
3127, 30zmulcld 9705 . . . . . . . . . 10  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  (
2  x.  x )  e.  ZZ )
32 zq 9957 . . . . . . . . . 10  |-  ( ( 2  x.  x )  e.  ZZ  ->  (
2  x.  x )  e.  QQ )
3331, 32syl 14 . . . . . . . . 9  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  (
2  x.  x )  e.  QQ )
34 qmulcl 9968 . . . . . . . . 9  |-  ( ( ( Q  /  P
)  e.  QQ  /\  ( 2  x.  x
)  e.  QQ )  ->  ( ( Q  /  P )  x.  ( 2  x.  x
) )  e.  QQ )
3525, 33, 34syl2an2r 599 . . . . . . . 8  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  (
( Q  /  P
)  x.  ( 2  x.  x ) )  e.  QQ )
3635flqcld 10636 . . . . . . 7  |-  ( (
ph  /\  x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) )  ->  ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x
) ) )  e.  ZZ )
3722, 36fsumzcl 12084 . . . . . 6  |-  ( ph  -> 
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) )  e.  ZZ )
38 qexpclz 10921 . . . . . 6  |-  ( (
-u 1  e.  QQ  /\  -u 1  =/=  0  /\  sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) )  e.  ZZ )  ->  ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  e.  QQ )
3918, 20, 37, 38syl3anc 1274 . . . . 5  |-  ( ph  ->  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  QQ )
40 1z 9602 . . . . . 6  |-  1  e.  ZZ
41 zq 9957 . . . . . 6  |-  ( 1  e.  ZZ  ->  1  e.  QQ )
4240, 41mp1i 10 . . . . 5  |-  ( ph  ->  1  e.  QQ )
43 nnq 9964 . . . . . 6  |-  ( P  e.  NN  ->  P  e.  QQ )
4423, 43syl 14 . . . . 5  |-  ( ph  ->  P  e.  QQ )
4523nngt0d 9280 . . . . 5  |-  ( ph  ->  0  <  P )
46 lgseisen.3 . . . . . 6  |-  ( ph  ->  P  =/=  Q )
47 eqid 2232 . . . . . 6  |-  ( ( Q  x.  ( 2  x.  x ) )  mod  P )  =  ( ( Q  x.  ( 2  x.  x
) )  mod  P
)
48 eqid 2232 . . . . . 6  |-  ( x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) )  |->  ( ( ( ( -u 1 ^ ( ( Q  x.  ( 2  x.  x ) )  mod 
P ) )  x.  ( ( Q  x.  ( 2  x.  x
) )  mod  P
) )  mod  P
)  /  2 ) )  =  ( x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) )  |->  ( ( ( ( -u 1 ^ ( ( Q  x.  ( 2  x.  x ) )  mod 
P ) )  x.  ( ( Q  x.  ( 2  x.  x
) )  mod  P
) )  mod  P
)  /  2 ) )
49 eqid 2232 . . . . . 6  |-  ( ( Q  x.  ( 2  x.  y ) )  mod  P )  =  ( ( Q  x.  ( 2  x.  y
) )  mod  P
)
50 eqid 2232 . . . . . 6  |-  (ℤ/n `  P
)  =  (ℤ/n `  P
)
51 eqid 2232 . . . . . 6  |-  (mulGrp `  (ℤ/n `  P ) )  =  (mulGrp `  (ℤ/n `  P ) )
52 eqid 2232 . . . . . 6  |-  ( ZRHom `  (ℤ/n `  P ) )  =  ( ZRHom `  (ℤ/n `  P
) )
535, 1, 46, 47, 48, 49, 50, 51, 52lgseisenlem4 15938 . . . . 5  |-  ( ph  ->  ( ( Q ^
( ( P  - 
1 )  /  2
) )  mod  P
)  =  ( (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  mod  P ) )
5414, 39, 42, 44, 45, 53modqadd1 10722 . . . 4  |-  ( ph  ->  ( ( ( Q ^ ( ( P  -  1 )  / 
2 ) )  +  1 )  mod  P
)  =  ( ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  +  1 )  mod  P ) )
55 qaddcl 9966 . . . . . 6  |-  ( ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  QQ  /\  1  e.  QQ )  ->  ( ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  +  1 )  e.  QQ )
5639, 42, 55syl2anc 411 . . . . 5  |-  ( ph  ->  ( ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  +  1 )  e.  QQ )
57 df-neg 8446 . . . . . . 7  |-  -u 1  =  ( 0  -  1 )
58 neg1cn 9341 . . . . . . . . . . . 12  |-  -u 1  e.  CC
59 neg1ap0 9345 . . . . . . . . . . . 12  |-  -u 1 #  0
60 absexpzap 11761 . . . . . . . . . . . 12  |-  ( (
-u 1  e.  CC  /\  -u 1 #  0  /\  sum_
x  e.  ( 1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) )  e.  ZZ )  -> 
( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  =  ( ( abs `  -u 1 ) ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) ) )
6158, 59, 37, 60mp3an12i 1378 . . . . . . . . . . 11  |-  ( ph  ->  ( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  =  ( ( abs `  -u 1 ) ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) ) )
62 ax-1cn 8219 . . . . . . . . . . . . . . 15  |-  1  e.  CC
6362absnegi 11828 . . . . . . . . . . . . . 14  |-  ( abs `  -u 1 )  =  ( abs `  1
)
64 abs1 11753 . . . . . . . . . . . . . 14  |-  ( abs `  1 )  =  1
6563, 64eqtri 2253 . . . . . . . . . . . . 13  |-  ( abs `  -u 1 )  =  1
6665oveq1i 6059 . . . . . . . . . . . 12  |-  ( ( abs `  -u 1
) ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  =  ( 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )
67 1exp 10929 . . . . . . . . . . . . 13  |-  ( sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) )  e.  ZZ  ->  ( 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  =  1 )
6837, 67syl 14 . . . . . . . . . . . 12  |-  ( ph  ->  ( 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  =  1 )
6966, 68eqtrid 2277 . . . . . . . . . . 11  |-  ( ph  ->  ( ( abs `  -u 1
) ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  =  1 )
7061, 69eqtrd 2265 . . . . . . . . . 10  |-  ( ph  ->  ( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  =  1 )
71 1le1 8845 . . . . . . . . . 10  |-  1  <_  1
7270, 71eqbrtrdi 4147 . . . . . . . . 9  |-  ( ph  ->  ( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  <_  1 )
73 neg1rr 9342 . . . . . . . . . . . 12  |-  -u 1  e.  RR
7473a1i 9 . . . . . . . . . . 11  |-  ( ph  -> 
-u 1  e.  RR )
7559a1i 9 . . . . . . . . . . 11  |-  ( ph  -> 
-u 1 #  0 )
7674, 75, 37reexpclzapd 11059 . . . . . . . . . 10  |-  ( ph  ->  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  RR )
77 1re 8272 . . . . . . . . . 10  |-  1  e.  RR
78 absle 11770 . . . . . . . . . 10  |-  ( ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  RR  /\  1  e.  RR )  ->  ( ( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  <_  1  <->  ( -u 1  <_  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  /\  ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  <_ 
1 ) ) )
7976, 77, 78sylancl 413 . . . . . . . . 9  |-  ( ph  ->  ( ( abs `  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )  <_  1  <->  ( -u 1  <_  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  /\  ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  <_ 
1 ) ) )
8072, 79mpbid 147 . . . . . . . 8  |-  ( ph  ->  ( -u 1  <_ 
( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  /\  ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  <_  1
) )
8180simpld 112 . . . . . . 7  |-  ( ph  -> 
-u 1  <_  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )
8257, 81eqbrtrrid 4144 . . . . . 6  |-  ( ph  ->  ( 0  -  1 )  <_  ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) ) )
83 0red 8274 . . . . . . 7  |-  ( ph  ->  0  e.  RR )
84 1red 8288 . . . . . . 7  |-  ( ph  ->  1  e.  RR )
8583, 84, 76lesubaddd 8815 . . . . . 6  |-  ( ph  ->  ( ( 0  -  1 )  <_  ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  <->  0  <_  ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  +  1 ) ) )
8682, 85mpbid 147 . . . . 5  |-  ( ph  ->  0  <_  ( ( -u 1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 ) )
8723nnred 9249 . . . . . . . 8  |-  ( ph  ->  P  e.  RR )
88 peano2rem 8539 . . . . . . . 8  |-  ( P  e.  RR  ->  ( P  -  1 )  e.  RR )
8987, 88syl 14 . . . . . . 7  |-  ( ph  ->  ( P  -  1 )  e.  RR )
9080simprd 114 . . . . . . 7  |-  ( ph  ->  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  <_  1 )
91 df-2 9295 . . . . . . . . 9  |-  2  =  ( 1  +  1 )
92 eldifsni 3821 . . . . . . . . . . . 12  |-  ( P  e.  ( Prime  \  {
2 } )  ->  P  =/=  2 )
935, 92syl 14 . . . . . . . . . . 11  |-  ( ph  ->  P  =/=  2 )
9423nnzd 9698 . . . . . . . . . . . 12  |-  ( ph  ->  P  e.  ZZ )
95 zapne 9651 . . . . . . . . . . . 12  |-  ( ( P  e.  ZZ  /\  2  e.  ZZ )  ->  ( P #  2  <->  P  =/=  2 ) )
9694, 26, 95sylancl 413 . . . . . . . . . . 11  |-  ( ph  ->  ( P #  2  <->  P  =/=  2 ) )
9793, 96mpbird 167 . . . . . . . . . 10  |-  ( ph  ->  P #  2 )
98 2re 9306 . . . . . . . . . . . 12  |-  2  e.  RR
9998a1i 9 . . . . . . . . . . 11  |-  ( ph  ->  2  e.  RR )
1005eldifad 3221 . . . . . . . . . . . 12  |-  ( ph  ->  P  e.  Prime )
101 prmuz2 12824 . . . . . . . . . . . 12  |-  ( P  e.  Prime  ->  P  e.  ( ZZ>= `  2 )
)
102 eluzle 9865 . . . . . . . . . . . 12  |-  ( P  e.  ( ZZ>= `  2
)  ->  2  <_  P )
103100, 101, 1023syl 17 . . . . . . . . . . 11  |-  ( ph  ->  2  <_  P )
10499, 87, 103leltapd 8912 . . . . . . . . . 10  |-  ( ph  ->  ( 2  <  P  <->  P #  2 ) )
10597, 104mpbird 167 . . . . . . . . 9  |-  ( ph  ->  2  <  P )
10691, 105eqbrtrrid 4144 . . . . . . . 8  |-  ( ph  ->  ( 1  +  1 )  <  P )
10784, 84, 87ltaddsubd 8818 . . . . . . . 8  |-  ( ph  ->  ( ( 1  +  1 )  <  P  <->  1  <  ( P  - 
1 ) ) )
108106, 107mpbid 147 . . . . . . 7  |-  ( ph  ->  1  <  ( P  -  1 ) )
10976, 84, 89, 90, 108lelttrd 8397 . . . . . 6  |-  ( ph  ->  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  <  ( P  -  1 ) )
11076, 84, 87ltaddsubd 8818 . . . . . 6  |-  ( ph  ->  ( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  <  P  <->  (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  <  ( P  - 
1 ) ) )
111109, 110mpbird 167 . . . . 5  |-  ( ph  ->  ( ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  +  1 )  <  P )
112 modqid 10710 . . . . 5  |-  ( ( ( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  e.  QQ  /\  P  e.  QQ )  /\  ( 0  <_ 
( ( -u 1 ^ sum_ x  e.  ( 1 ... ( ( P  -  1 )  /  2 ) ) ( |_ `  (
( Q  /  P
)  x.  ( 2  x.  x ) ) ) )  +  1 )  /\  ( (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  +  1 )  < 
P ) )  -> 
( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  mod  P
)  =  ( (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  +  1 ) )
11356, 44, 86, 111, 112syl22anc 1275 . . . 4  |-  ( ph  ->  ( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  mod  P
)  =  ( (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  +  1 ) )
11454, 113eqtrd 2265 . . 3  |-  ( ph  ->  ( ( ( Q ^ ( ( P  -  1 )  / 
2 ) )  +  1 )  mod  P
)  =  ( (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) )  +  1 ) )
115114oveq1d 6064 . 2  |-  ( ph  ->  ( ( ( ( Q ^ ( ( P  -  1 )  /  2 ) )  +  1 )  mod 
P )  -  1 )  =  ( ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  +  1 )  -  1 ) )
11676recnd 8301 . . 3  |-  ( ph  ->  ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  CC )
117 pncan 8478 . . 3  |-  ( ( ( -u 1 ^
sum_ x  e.  (
1 ... ( ( P  -  1 )  / 
2 ) ) ( |_ `  ( ( Q  /  P )  x.  ( 2  x.  x ) ) ) )  e.  CC  /\  1  e.  CC )  ->  ( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  -  1 )  =  ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )
118116, 62, 117sylancl 413 . 2  |-  ( ph  ->  ( ( ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) )  +  1 )  -  1 )  =  ( -u
1 ^ sum_ x  e.  ( 1 ... (
( P  -  1 )  /  2 ) ) ( |_ `  ( ( Q  /  P )  x.  (
2  x.  x ) ) ) ) )
1197, 115, 1183eqtrd 2269 1  |-  ( ph  ->  ( Q  /L
P )  =  (
-u 1 ^ sum_ x  e.  ( 1 ... ( ( P  - 
1 )  /  2
) ) ( |_
`  ( ( Q  /  P )  x.  ( 2  x.  x
) ) ) ) )
Colors of variables: wff set class
Syntax hints:    -> wi 4    /\ wa 104    <-> wb 105    = wceq 1398    e. wcel 2203    =/= wne 2412    \ cdif 3207   {csn 3688   class class class wbr 4108    |-> cmpt 4170   ` cfv 5351  (class class class)co 6049   CCcc 8124   RRcr 8125   0cc0 8126   1c1 8127    + caddc 8129    x. cmul 8131    < clt 8307    <_ cle 8308    - cmin 8443   -ucneg 8444   # cap 8854    / cdiv 8945   NNcn 9236   2c2 9287   ZZcz 9576   ZZ>=cuz 9852   QQcq 9950   ...cfz 10341   |_cfl 10627    mod cmo 10683   ^cexp 10899   abscabs 11678   sum_csu 12034   Primecprime 12800  mulGrpcmgp 14056   ZRHomczrh 14751  ℤ/nczn 14753    /Lclgs 15862
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 619  ax-in2 620  ax-io 717  ax-5 1496  ax-7 1497  ax-gen 1498  ax-ie1 1542  ax-ie2 1543  ax-8 1553  ax-10 1554  ax-11 1555  ax-i12 1556  ax-bndl 1558  ax-4 1559  ax-17 1575  ax-i9 1579  ax-ial 1583  ax-i5r 1584  ax-13 2205  ax-14 2206  ax-ext 2214  ax-coll 4224  ax-sep 4227  ax-nul 4235  ax-pow 4286  ax-pr 4321  ax-un 4553  ax-setind 4658  ax-iinf 4709  ax-cnex 8217  ax-resscn 8218  ax-1cn 8219  ax-1re 8220  ax-icn 8221  ax-addcl 8222  ax-addrcl 8223  ax-mulcl 8224  ax-mulrcl 8225  ax-addcom 8226  ax-mulcom 8227  ax-addass 8228  ax-mulass 8229  ax-distr 8230  ax-i2m1 8231  ax-0lt1 8232  ax-1rid 8233  ax-0id 8234  ax-rnegex 8235  ax-precex 8236  ax-cnre 8237  ax-pre-ltirr 8238  ax-pre-ltwlin 8239  ax-pre-lttrn 8240  ax-pre-apti 8241  ax-pre-ltadd 8242  ax-pre-mulgt0 8243  ax-pre-mulext 8244  ax-arch 8245  ax-caucvg 8246  ax-addf 8248  ax-mulf 8249
This theorem depends on definitions:  df-bi 117  df-stab 839  df-dc 843  df-3or 1006  df-3an 1007  df-tru 1401  df-fal 1404  df-xor 1421  df-nf 1510  df-sb 1812  df-eu 2083  df-mo 2084  df-clab 2219  df-cleq 2225  df-clel 2228  df-nfc 2373  df-ne 2413  df-nel 2508  df-ral 2525  df-rex 2526  df-reu 2527  df-rmo 2528  df-rab 2529  df-v 2814  df-sbc 3042  df-csb 3138  df-dif 3212  df-un 3214  df-in 3216  df-ss 3223  df-nul 3508  df-if 3620  df-pw 3670  df-sn 3694  df-pr 3695  df-tp 3696  df-op 3697  df-uni 3914  df-int 3949  df-iun 3992  df-br 4109  df-opab 4171  df-mpt 4172  df-tr 4208  df-id 4413  df-po 4416  df-iso 4417  df-iord 4486  df-on 4488  df-ilim 4489  df-suc 4491  df-iom 4712  df-xp 4754  df-rel 4755  df-cnv 4756  df-co 4757  df-dm 4758  df-rn 4759  df-res 4760  df-ima 4761  df-iota 5311  df-fun 5353  df-fn 5354  df-f 5355  df-f1 5356  df-fo 5357  df-f1o 5358  df-fv 5359  df-isom 5360  df-riota 6002  df-ov 6052  df-oprab 6053  df-mpo 6054  df-of 6265  df-1st 6333  df-2nd 6334  df-tpos 6475  df-recs 6535  df-irdg 6600  df-frec 6621  df-1o 6646  df-2o 6647  df-oadd 6650  df-er 6766  df-ec 6768  df-qs 6772  df-map 6883  df-en 6975  df-dom 6976  df-fin 6977  df-sup 7274  df-inf 7275  df-pnf 8309  df-mnf 8310  df-xr 8311  df-ltxr 8312  df-le 8313  df-sub 8445  df-neg 8446  df-reap 8848  df-ap 8855  df-div 8946  df-inn 9237  df-2 9295  df-3 9296  df-4 9297  df-5 9298  df-6 9299  df-7 9300  df-8 9301  df-9 9302  df-n0 9496  df-z 9577  df-dec 9709  df-uz 9853  df-q 9951  df-rp 9986  df-fz 10342  df-fzo 10476  df-fl 10629  df-mod 10684  df-seqfrec 10809  df-exp 10900  df-ihash 11137  df-cj 11523  df-re 11524  df-im 11525  df-rsqrt 11679  df-abs 11680  df-clim 11960  df-sumdc 12035  df-proddc 12233  df-dvds 12470  df-gcd 12646  df-prm 12801  df-phi 12904  df-pc 12979  df-struct 13206  df-ndx 13207  df-slot 13208  df-base 13210  df-sets 13211  df-iress 13212  df-plusg 13295  df-mulr 13296  df-starv 13297  df-sca 13298  df-vsca 13299  df-ip 13300  df-tset 13301  df-ple 13302  df-ds 13304  df-unif 13305  df-0g 13463  df-igsum 13464  df-topgen 13465  df-iimas 13507  df-qus 13508  df-mgm 13561  df-sgrp 13607  df-mnd 13622  df-mhm 13664  df-submnd 13665  df-grp 13708  df-minusg 13709  df-sbg 13710  df-mulg 13829  df-subg 13879  df-nsg 13880  df-eqg 13881  df-ghm 13950  df-cmn 13995  df-abl 13996  df-mgp 14057  df-rng 14069  df-ur 14096  df-srg 14100  df-ring 14134  df-cring 14135  df-oppr 14204  df-dvdsr 14225  df-unit 14226  df-invr 14258  df-dvr 14269  df-rhm 14289  df-nzr 14317  df-subrg 14356  df-domn 14396  df-idom 14397  df-lmod 14429  df-lssm 14493  df-lsp 14527  df-sra 14575  df-rgmod 14576  df-lidl 14609  df-rsp 14610  df-2idl 14640  df-bl 14686  df-mopn 14687  df-fg 14689  df-metu 14690  df-cnfld 14697  df-zring 14731  df-zrh 14754  df-zn 14756  df-lgs 15863
This theorem is referenced by:  lgsquadlem2  15943
  Copyright terms: Public domain W3C validator