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

Theorem eulerthlema 12243
Description: Lemma for eulerth 12246. (Contributed by Mario Carneiro, 28-Feb-2014.) (Revised by Jim Kingdon, 2-Sep-2024.)
Hypotheses
Ref Expression
eulerth.1  |-  ( ph  ->  ( N  e.  NN  /\  A  e.  ZZ  /\  ( A  gcd  N )  =  1 ) )
eulerth.2  |-  S  =  { y  e.  ( 0..^ N )  |  ( y  gcd  N
)  =  1 }
eulerth.4  |-  ( ph  ->  F : ( 1 ... ( phi `  N ) ) -1-1-onto-> S )
Assertion
Ref Expression
eulerthlema  |-  ( ph  ->  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) )
Distinct variable groups:    x, A    x, F    x, N    y, N    ph, x
Allowed substitution hints:    ph( y)    A( y)    S( x, y)    F( y)

Proof of Theorem eulerthlema
Dummy variables  k  w are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 eulerth.1 . . . . . 6  |-  ( ph  ->  ( N  e.  NN  /\  A  e.  ZZ  /\  ( A  gcd  N )  =  1 ) )
21simp1d 1010 . . . . 5  |-  ( ph  ->  N  e.  NN )
32phicld 12231 . . . 4  |-  ( ph  ->  ( phi `  N
)  e.  NN )
4 elnnuz 9577 . . . 4  |-  ( ( phi `  N )  e.  NN  <->  ( phi `  N )  e.  (
ZZ>= `  1 ) )
53, 4sylib 122 . . 3  |-  ( ph  ->  ( phi `  N
)  e.  ( ZZ>= ` 
1 ) )
6 eluzfz2 10045 . . 3  |-  ( ( phi `  N )  e.  ( ZZ>= `  1
)  ->  ( phi `  N )  e.  ( 1 ... ( phi `  N ) ) )
75, 6syl 14 . 2  |-  ( ph  ->  ( phi `  N
)  e.  ( 1 ... ( phi `  N ) ) )
8 oveq2 5896 . . . . . . 7  |-  ( w  =  1  ->  ( A ^ w )  =  ( A ^ 1 ) )
9 oveq2 5896 . . . . . . . 8  |-  ( w  =  1  ->  (
1 ... w )  =  ( 1 ... 1
) )
109prodeq1d 11585 . . . . . . 7  |-  ( w  =  1  ->  prod_ x  e.  ( 1 ... w ) ( F `
 x )  = 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )
118, 10oveq12d 5906 . . . . . 6  |-  ( w  =  1  ->  (
( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  =  ( ( A ^
1 )  x.  prod_ x  e.  ( 1 ... 1 ) ( F `
 x ) ) )
1211oveq1d 5903 . . . . 5  |-  ( w  =  1  ->  (
( ( A ^
w )  x.  prod_ x  e.  ( 1 ... w ) ( F `
 x ) )  mod  N )  =  ( ( ( A ^ 1 )  x. 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )  mod  N ) )
139prodeq1d 11585 . . . . . 6  |-  ( w  =  1  ->  prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `
 x ) )  mod  N )  = 
prod_ x  e.  (
1 ... 1 ) ( ( A  x.  ( F `  x )
)  mod  N )
)
1413oveq1d 5903 . . . . 5  |-  ( w  =  1  ->  ( prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  =  (
prod_ x  e.  (
1 ... 1 ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )
1512, 14eqeq12d 2202 . . . 4  |-  ( w  =  1  ->  (
( ( ( A ^ w )  x. 
prod_ x  e.  (
1 ... w ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... w
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
)  <->  ( ( ( A ^ 1 )  x.  prod_ x  e.  ( 1 ... 1 ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... 1 ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) ) )
1615imbi2d 230 . . 3  |-  ( w  =  1  ->  (
( ph  ->  ( ( ( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  <->  ( ph  ->  ( ( ( A ^ 1 )  x. 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... 1
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) ) ) )
17 oveq2 5896 . . . . . . 7  |-  ( w  =  k  ->  ( A ^ w )  =  ( A ^ k
) )
18 oveq2 5896 . . . . . . . 8  |-  ( w  =  k  ->  (
1 ... w )  =  ( 1 ... k
) )
1918prodeq1d 11585 . . . . . . 7  |-  ( w  =  k  ->  prod_ x  e.  ( 1 ... w ) ( F `
 x )  = 
prod_ x  e.  (
1 ... k ) ( F `  x ) )
2017, 19oveq12d 5906 . . . . . 6  |-  ( w  =  k  ->  (
( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  =  ( ( A ^
k )  x.  prod_ x  e.  ( 1 ... k ) ( F `
 x ) ) )
2120oveq1d 5903 . . . . 5  |-  ( w  =  k  ->  (
( ( A ^
w )  x.  prod_ x  e.  ( 1 ... w ) ( F `
 x ) )  mod  N )  =  ( ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  mod  N ) )
2218prodeq1d 11585 . . . . . 6  |-  ( w  =  k  ->  prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `
 x ) )  mod  N )  = 
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )
)
2322oveq1d 5903 . . . . 5  |-  ( w  =  k  ->  ( prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  =  (
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )
2421, 23eqeq12d 2202 . . . 4  |-  ( w  =  k  ->  (
( ( ( A ^ w )  x. 
prod_ x  e.  (
1 ... w ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... w
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
)  <->  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) ) )
2524imbi2d 230 . . 3  |-  ( w  =  k  ->  (
( ph  ->  ( ( ( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  <->  ( ph  ->  ( ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) ) ) )
26 oveq2 5896 . . . . . . 7  |-  ( w  =  ( k  +  1 )  ->  ( A ^ w )  =  ( A ^ (
k  +  1 ) ) )
27 oveq2 5896 . . . . . . . 8  |-  ( w  =  ( k  +  1 )  ->  (
1 ... w )  =  ( 1 ... (
k  +  1 ) ) )
2827prodeq1d 11585 . . . . . . 7  |-  ( w  =  ( k  +  1 )  ->  prod_ x  e.  ( 1 ... w ) ( F `
 x )  = 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( F `  x ) )
2926, 28oveq12d 5906 . . . . . 6  |-  ( w  =  ( k  +  1 )  ->  (
( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  =  ( ( A ^
( k  +  1 ) )  x.  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `
 x ) ) )
3029oveq1d 5903 . . . . 5  |-  ( w  =  ( k  +  1 )  ->  (
( ( A ^
w )  x.  prod_ x  e.  ( 1 ... w ) ( F `
 x ) )  mod  N )  =  ( ( ( A ^ ( k  +  1 ) )  x. 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( F `  x ) )  mod  N ) )
3127prodeq1d 11585 . . . . . 6  |-  ( w  =  ( k  +  1 )  ->  prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `
 x ) )  mod  N )  = 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )
)
3231oveq1d 5903 . . . . 5  |-  ( w  =  ( k  +  1 )  ->  ( prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  =  (
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )
3330, 32eqeq12d 2202 . . . 4  |-  ( w  =  ( k  +  1 )  ->  (
( ( ( A ^ w )  x. 
prod_ x  e.  (
1 ... w ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... w
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
)  <->  ( ( ( A ^ ( k  +  1 ) )  x.  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) ) )
3433imbi2d 230 . . 3  |-  ( w  =  ( k  +  1 )  ->  (
( ph  ->  ( ( ( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  <->  ( ph  ->  ( ( ( A ^ ( k  +  1 ) )  x. 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... (
k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) ) ) )
35 oveq2 5896 . . . . . . 7  |-  ( w  =  ( phi `  N )  ->  ( A ^ w )  =  ( A ^ ( phi `  N ) ) )
36 oveq2 5896 . . . . . . . 8  |-  ( w  =  ( phi `  N )  ->  (
1 ... w )  =  ( 1 ... ( phi `  N ) ) )
3736prodeq1d 11585 . . . . . . 7  |-  ( w  =  ( phi `  N )  ->  prod_ x  e.  ( 1 ... w ) ( F `
 x )  = 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )
3835, 37oveq12d 5906 . . . . . 6  |-  ( w  =  ( phi `  N )  ->  (
( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  =  ( ( A ^
( phi `  N
) )  x.  prod_ x  e.  ( 1 ... ( phi `  N
) ) ( F `
 x ) ) )
3938oveq1d 5903 . . . . 5  |-  ( w  =  ( phi `  N )  ->  (
( ( A ^
w )  x.  prod_ x  e.  ( 1 ... w ) ( F `
 x ) )  mod  N )  =  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N ) )
4036prodeq1d 11585 . . . . . 6  |-  ( w  =  ( phi `  N )  ->  prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `
 x ) )  mod  N )  = 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x )
)  mod  N )
)
4140oveq1d 5903 . . . . 5  |-  ( w  =  ( phi `  N )  ->  ( prod_ x  e.  ( 1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  =  (
prod_ x  e.  (
1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )
4239, 41eqeq12d 2202 . . . 4  |-  ( w  =  ( phi `  N )  ->  (
( ( ( A ^ w )  x. 
prod_ x  e.  (
1 ... w ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... w
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
)  <->  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) ) )
4342imbi2d 230 . . 3  |-  ( w  =  ( phi `  N )  ->  (
( ph  ->  ( ( ( A ^ w
)  x.  prod_ x  e.  ( 1 ... w
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... w ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  <->  ( ph  ->  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) ) ) )
441simp2d 1011 . . . . . . . 8  |-  ( ph  ->  A  e.  ZZ )
45 eulerth.2 . . . . . . . . . . . 12  |-  S  =  { y  e.  ( 0..^ N )  |  ( y  gcd  N
)  =  1 }
46 ssrab2 3252 . . . . . . . . . . . 12  |-  { y  e.  ( 0..^ N )  |  ( y  gcd  N )  =  1 }  C_  (
0..^ N )
4745, 46eqsstri 3199 . . . . . . . . . . 11  |-  S  C_  ( 0..^ N )
48 fzo0ssnn0 10228 . . . . . . . . . . 11  |-  ( 0..^ N )  C_  NN0
4947, 48sstri 3176 . . . . . . . . . 10  |-  S  C_  NN0
50 nn0ssz 9284 . . . . . . . . . 10  |-  NN0  C_  ZZ
5149, 50sstri 3176 . . . . . . . . 9  |-  S  C_  ZZ
52 eulerth.4 . . . . . . . . . . 11  |-  ( ph  ->  F : ( 1 ... ( phi `  N ) ) -1-1-onto-> S )
53 f1of 5473 . . . . . . . . . . 11  |-  ( F : ( 1 ... ( phi `  N
) ) -1-1-onto-> S  ->  F :
( 1 ... ( phi `  N ) ) --> S )
5452, 53syl 14 . . . . . . . . . 10  |-  ( ph  ->  F : ( 1 ... ( phi `  N ) ) --> S )
55 1nn 8943 . . . . . . . . . . . 12  |-  1  e.  NN
5655a1i 9 . . . . . . . . . . 11  |-  ( ph  ->  1  e.  NN )
573nnge1d 8975 . . . . . . . . . . 11  |-  ( ph  ->  1  <_  ( phi `  N ) )
58 elfz1b 10103 . . . . . . . . . . 11  |-  ( 1  e.  ( 1 ... ( phi `  N
) )  <->  ( 1  e.  NN  /\  ( phi `  N )  e.  NN  /\  1  <_ 
( phi `  N
) ) )
5956, 3, 57, 58syl3anbrc 1182 . . . . . . . . . 10  |-  ( ph  ->  1  e.  ( 1 ... ( phi `  N ) ) )
6054, 59ffvelcdmd 5665 . . . . . . . . 9  |-  ( ph  ->  ( F `  1
)  e.  S )
6151, 60sselid 3165 . . . . . . . 8  |-  ( ph  ->  ( F `  1
)  e.  ZZ )
6244, 61zmulcld 9394 . . . . . . 7  |-  ( ph  ->  ( A  x.  ( F `  1 )
)  e.  ZZ )
63 zq 9639 . . . . . . 7  |-  ( ( A  x.  ( F `
 1 ) )  e.  ZZ  ->  ( A  x.  ( F `  1 ) )  e.  QQ )
6462, 63syl 14 . . . . . 6  |-  ( ph  ->  ( A  x.  ( F `  1 )
)  e.  QQ )
65 nnq 9646 . . . . . . 7  |-  ( N  e.  NN  ->  N  e.  QQ )
662, 65syl 14 . . . . . 6  |-  ( ph  ->  N  e.  QQ )
672nngt0d 8976 . . . . . 6  |-  ( ph  ->  0  <  N )
68 modqabs2 10371 . . . . . 6  |-  ( ( ( A  x.  ( F `  1 )
)  e.  QQ  /\  N  e.  QQ  /\  0  <  N )  ->  (
( ( A  x.  ( F `  1 ) )  mod  N )  mod  N )  =  ( ( A  x.  ( F `  1 ) )  mod  N ) )
6964, 66, 67, 68syl3anc 1248 . . . . 5  |-  ( ph  ->  ( ( ( A  x.  ( F ` 
1 ) )  mod 
N )  mod  N
)  =  ( ( A  x.  ( F `
 1 ) )  mod  N ) )
70 1z 9292 . . . . . . 7  |-  1  e.  ZZ
7162, 2zmodcld 10358 . . . . . . . 8  |-  ( ph  ->  ( ( A  x.  ( F `  1 ) )  mod  N )  e.  NN0 )
7271nn0cnd 9244 . . . . . . 7  |-  ( ph  ->  ( ( A  x.  ( F `  1 ) )  mod  N )  e.  CC )
73 fveq2 5527 . . . . . . . . . 10  |-  ( x  =  1  ->  ( F `  x )  =  ( F ` 
1 ) )
7473oveq2d 5904 . . . . . . . . 9  |-  ( x  =  1  ->  ( A  x.  ( F `  x ) )  =  ( A  x.  ( F `  1 )
) )
7574oveq1d 5903 . . . . . . . 8  |-  ( x  =  1  ->  (
( A  x.  ( F `  x )
)  mod  N )  =  ( ( A  x.  ( F ` 
1 ) )  mod 
N ) )
7675fprod1 11615 . . . . . . 7  |-  ( ( 1  e.  ZZ  /\  ( ( A  x.  ( F `  1 ) )  mod  N )  e.  CC )  ->  prod_ x  e.  ( 1 ... 1 ) ( ( A  x.  ( F `  x )
)  mod  N )  =  ( ( A  x.  ( F ` 
1 ) )  mod 
N ) )
7770, 72, 76sylancr 414 . . . . . 6  |-  ( ph  ->  prod_ x  e.  ( 1 ... 1 ) ( ( A  x.  ( F `  x ) )  mod  N )  =  ( ( A  x.  ( F ` 
1 ) )  mod 
N ) )
7877oveq1d 5903 . . . . 5  |-  ( ph  ->  ( prod_ x  e.  ( 1 ... 1 ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N )  =  ( ( ( A  x.  ( F ` 
1 ) )  mod 
N )  mod  N
) )
7944zcnd 9389 . . . . . . . 8  |-  ( ph  ->  A  e.  CC )
8079exp1d 10662 . . . . . . 7  |-  ( ph  ->  ( A ^ 1 )  =  A )
81 nn0sscn 9194 . . . . . . . . . 10  |-  NN0  C_  CC
8249, 81sstri 3176 . . . . . . . . 9  |-  S  C_  CC
8382, 60sselid 3165 . . . . . . . 8  |-  ( ph  ->  ( F `  1
)  e.  CC )
8473fprod1 11615 . . . . . . . 8  |-  ( ( 1  e.  ZZ  /\  ( F `  1 )  e.  CC )  ->  prod_ x  e.  ( 1 ... 1 ) ( F `  x )  =  ( F ` 
1 ) )
8570, 83, 84sylancr 414 . . . . . . 7  |-  ( ph  ->  prod_ x  e.  ( 1 ... 1 ) ( F `  x
)  =  ( F `
 1 ) )
8680, 85oveq12d 5906 . . . . . 6  |-  ( ph  ->  ( ( A ^
1 )  x.  prod_ x  e.  ( 1 ... 1 ) ( F `
 x ) )  =  ( A  x.  ( F `  1 ) ) )
8786oveq1d 5903 . . . . 5  |-  ( ph  ->  ( ( ( A ^ 1 )  x. 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )  mod  N )  =  ( ( A  x.  ( F ` 
1 ) )  mod 
N ) )
8869, 78, 873eqtr4rd 2231 . . . 4  |-  ( ph  ->  ( ( ( A ^ 1 )  x. 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... 1
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) )
8988a1i 9 . . 3  |-  ( ( phi `  N )  e.  ( ZZ>= `  1
)  ->  ( ph  ->  ( ( ( A ^ 1 )  x. 
prod_ x  e.  (
1 ... 1 ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... 1
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) ) )
9044adantr 276 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  A  e.  ZZ )
91 elfzo1 10203 . . . . . . . . . . . . . . 15  |-  ( k  e.  ( 1..^ ( phi `  N ) )  <->  ( k  e.  NN  /\  ( phi `  N )  e.  NN  /\  k  <  ( phi `  N ) ) )
9291simp1bi 1013 . . . . . . . . . . . . . 14  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  k  e.  NN )
9392adantl 277 . . . . . . . . . . . . 13  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  k  e.  NN )
9493nnnn0d 9242 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  k  e.  NN0 )
95 zexpcl 10548 . . . . . . . . . . . 12  |-  ( ( A  e.  ZZ  /\  k  e.  NN0 )  -> 
( A ^ k
)  e.  ZZ )
9690, 94, 95syl2anc 411 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A ^
k )  e.  ZZ )
9770a1i 9 . . . . . . . . . . . . 13  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  1  e.  ZZ )
9893nnzd 9387 . . . . . . . . . . . . 13  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  k  e.  ZZ )
9997, 98fzfigd 10444 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( 1 ... k )  e.  Fin )
10054ad2antrr 488 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  F :
( 1 ... ( phi `  N ) ) --> S )
101 elfzelz 10038 . . . . . . . . . . . . . . . . . 18  |-  ( x  e.  ( 1 ... k )  ->  x  e.  ZZ )
102101zred 9388 . . . . . . . . . . . . . . . . 17  |-  ( x  e.  ( 1 ... k )  ->  x  e.  RR )
103102adantl 277 . . . . . . . . . . . . . . . 16  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  x  e.  RR )
1043nnzd 9387 . . . . . . . . . . . . . . . . . 18  |-  ( ph  ->  ( phi `  N
)  e.  ZZ )
105104ad2antrr 488 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( phi `  N )  e.  ZZ )
106105zred 9388 . . . . . . . . . . . . . . . 16  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( phi `  N )  e.  RR )
10793nnred 8945 . . . . . . . . . . . . . . . . . 18  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  k  e.  RR )
108107adantr 276 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  k  e.  RR )
109 elfzle2 10041 . . . . . . . . . . . . . . . . . 18  |-  ( x  e.  ( 1 ... k )  ->  x  <_  k )
110109adantl 277 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  x  <_  k )
111 elfzolt2 10169 . . . . . . . . . . . . . . . . . 18  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  k  <  ( phi `  N ) )
112111ad2antlr 489 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  k  <  ( phi `  N ) )
113103, 108, 106, 110, 112lelttrd 8095 . . . . . . . . . . . . . . . 16  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  x  <  ( phi `  N ) )
114103, 106, 113ltled 8089 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  x  <_  ( phi `  N ) )
115 elfzuz 10034 . . . . . . . . . . . . . . . 16  |-  ( x  e.  ( 1 ... k )  ->  x  e.  ( ZZ>= `  1 )
)
116 elfz5 10030 . . . . . . . . . . . . . . . 16  |-  ( ( x  e.  ( ZZ>= ` 
1 )  /\  ( phi `  N )  e.  ZZ )  ->  (
x  e.  ( 1 ... ( phi `  N ) )  <->  x  <_  ( phi `  N ) ) )
117115, 105, 116syl2an2 594 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( x  e.  ( 1 ... ( phi `  N ) )  <-> 
x  <_  ( phi `  N ) ) )
118114, 117mpbird 167 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  x  e.  ( 1 ... ( phi `  N ) ) )
119100, 118ffvelcdmd 5665 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( F `  x )  e.  S
)
12051, 119sselid 3165 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( F `  x )  e.  ZZ )
12199, 120fprodzcl 11630 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... k ) ( F `  x
)  e.  ZZ )
12296, 121zmulcld 9394 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  e.  ZZ )
123 zq 9639 . . . . . . . . . 10  |-  ( ( ( A ^ k
)  x.  prod_ x  e.  ( 1 ... k
) ( F `  x ) )  e.  ZZ  ->  ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  e.  QQ )
124122, 123syl 14 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  e.  QQ )
125124adantr 276 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( ( A ^
k )  x.  prod_ x  e.  ( 1 ... k ) ( F `
 x ) )  e.  QQ )
12690adantr 276 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  A  e.  ZZ )
127126, 120zmulcld 9394 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( A  x.  ( F `  x
) )  e.  ZZ )
1282ad2antrr 488 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  N  e.  NN )
129127, 128zmodcld 10358 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( ( A  x.  ( F `  x ) )  mod 
N )  e.  NN0 )
130129nn0zd 9386 . . . . . . . . . . 11  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... k ) )  ->  ( ( A  x.  ( F `  x ) )  mod 
N )  e.  ZZ )
13199, 130fprodzcl 11630 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N )  e.  ZZ )
132 zq 9639 . . . . . . . . . 10  |-  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  e.  ZZ  ->  prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  e.  QQ )
133131, 132syl 14 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N )  e.  QQ )
134133adantr 276 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  ->  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  e.  QQ )
13544ad2antrr 488 . . . . . . . . 9  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  ->  A  e.  ZZ )
13654ad2antrr 488 . . . . . . . . . . 11  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  ->  F : ( 1 ... ( phi `  N
) ) --> S )
137 fzofzp1 10240 . . . . . . . . . . . 12  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  ( k  +  1 )  e.  ( 1 ... ( phi `  N ) ) )
138137ad2antlr 489 . . . . . . . . . . 11  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( k  +  1 )  e.  ( 1 ... ( phi `  N ) ) )
139136, 138ffvelcdmd 5665 . . . . . . . . . 10  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( F `  (
k  +  1 ) )  e.  S )
14051, 139sselid 3165 . . . . . . . . 9  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( F `  (
k  +  1 ) )  e.  ZZ )
141135, 140zmulcld 9394 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( A  x.  ( F `  ( k  +  1 ) ) )  e.  ZZ )
14266ad2antrr 488 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  ->  N  e.  QQ )
14367ad2antrr 488 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
0  <  N )
144 simpr 110 . . . . . . . 8  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
) )
145125, 134, 141, 142, 143, 144modqmul1 10390 . . . . . . 7  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N )  =  ( ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N ) )
146145ex 115 . . . . . 6  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( ( A ^ k
)  x.  prod_ x  e.  ( 1 ... k
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  ->  (
( ( ( A ^ k )  x. 
prod_ x  e.  (
1 ... k ) ( F `  x ) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N )  =  ( ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N ) ) )
14796zcnd 9389 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A ^
k )  e.  CC )
148121zcnd 9389 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... k ) ( F `  x
)  e.  CC )
14979adantr 276 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  A  e.  CC )
15054adantr 276 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  F : ( 1 ... ( phi `  N ) ) --> S )
151137adantl 277 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( k  +  1 )  e.  ( 1 ... ( phi `  N ) ) )
152150, 151ffvelcdmd 5665 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( F `  ( k  +  1 ) )  e.  S
)
15382, 152sselid 3165 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( F `  ( k  +  1 ) )  e.  CC )
154147, 148, 149, 153mul4d 8125 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  =  ( ( ( A ^ k )  x.  A )  x.  ( prod_ x  e.  ( 1 ... k ) ( F `  x
)  x.  ( F `
 ( k  +  1 ) ) ) ) )
155149, 94expp1d 10668 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A ^
( k  +  1 ) )  =  ( ( A ^ k
)  x.  A ) )
156 elfzouz 10164 . . . . . . . . . . . 12  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  k  e.  ( ZZ>= `  1 )
)
157156adantl 277 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  k  e.  (
ZZ>= `  1 ) )
158150adantr 276 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  F :
( 1 ... ( phi `  N ) ) --> S )
159 elfzelz 10038 . . . . . . . . . . . . . . . . 17  |-  ( x  e.  ( 1 ... ( k  +  1 ) )  ->  x  e.  ZZ )
160159zred 9388 . . . . . . . . . . . . . . . 16  |-  ( x  e.  ( 1 ... ( k  +  1 ) )  ->  x  e.  RR )
161160adantl 277 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  x  e.  RR )
162 peano2re 8106 . . . . . . . . . . . . . . . . 17  |-  ( k  e.  RR  ->  (
k  +  1 )  e.  RR )
163107, 162syl 14 . . . . . . . . . . . . . . . 16  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( k  +  1 )  e.  RR )
164163adantr 276 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( k  +  1 )  e.  RR )
165104ad2antrr 488 . . . . . . . . . . . . . . . 16  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( phi `  N )  e.  ZZ )
166165zred 9388 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( phi `  N )  e.  RR )
167 elfzle2 10041 . . . . . . . . . . . . . . . 16  |-  ( x  e.  ( 1 ... ( k  +  1 ) )  ->  x  <_  ( k  +  1 ) )
168167adantl 277 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  x  <_  ( k  +  1 ) )
169137ad2antlr 489 . . . . . . . . . . . . . . . 16  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( k  +  1 )  e.  ( 1 ... ( phi `  N ) ) )
170 elfzle2 10041 . . . . . . . . . . . . . . . 16  |-  ( ( k  +  1 )  e.  ( 1 ... ( phi `  N
) )  ->  (
k  +  1 )  <_  ( phi `  N ) )
171169, 170syl 14 . . . . . . . . . . . . . . 15  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( k  +  1 )  <_ 
( phi `  N
) )
172161, 164, 166, 168, 171letrd 8094 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  x  <_  ( phi `  N ) )
173 elfzuz 10034 . . . . . . . . . . . . . . 15  |-  ( x  e.  ( 1 ... ( k  +  1 ) )  ->  x  e.  ( ZZ>= `  1 )
)
174173, 165, 116syl2an2 594 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( x  e.  ( 1 ... ( phi `  N ) )  <-> 
x  <_  ( phi `  N ) ) )
175172, 174mpbird 167 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  x  e.  ( 1 ... ( phi `  N ) ) )
176158, 175ffvelcdmd 5665 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( F `  x )  e.  S
)
17782, 176sselid 3165 . . . . . . . . . . 11  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( F `  x )  e.  CC )
178 fveq2 5527 . . . . . . . . . . 11  |-  ( x  =  ( k  +  1 )  ->  ( F `  x )  =  ( F `  ( k  +  1 ) ) )
179157, 177, 178fprodp1 11621 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `  x
)  =  ( prod_
x  e.  ( 1 ... k ) ( F `  x )  x.  ( F `  ( k  +  1 ) ) ) )
180155, 179oveq12d 5906 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A ^ ( k  +  1 ) )  x. 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( F `  x ) )  =  ( ( ( A ^ k
)  x.  A )  x.  ( prod_ x  e.  ( 1 ... k
) ( F `  x )  x.  ( F `  ( k  +  1 ) ) ) ) )
181154, 180eqtr4d 2223 . . . . . . . 8  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  =  ( ( A ^ ( k  +  1 ) )  x. 
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( F `  x ) ) )
182181oveq1d 5903 . . . . . . 7  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( ( A ^ k
)  x.  prod_ x  e.  ( 1 ... k
) ( F `  x ) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N
)  =  ( ( ( A ^ (
k  +  1 ) )  x.  prod_ x  e.  ( 1 ... (
k  +  1 ) ) ( F `  x ) )  mod 
N ) )
18351, 152sselid 3165 . . . . . . . . . . . . 13  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( F `  ( k  +  1 ) )  e.  ZZ )
18490, 183zmulcld 9394 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A  x.  ( F `  ( k  +  1 ) ) )  e.  ZZ )
1852adantr 276 . . . . . . . . . . . 12  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  N  e.  NN )
186184, 185zmodcld 10358 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod 
N )  e.  NN0 )
187186nn0zd 9386 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod 
N )  e.  ZZ )
188 zq 9639 . . . . . . . . . 10  |-  ( ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N )  e.  ZZ  ->  (
( A  x.  ( F `  ( k  +  1 ) ) )  mod  N )  e.  QQ )
189187, 188syl 14 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod 
N )  e.  QQ )
190 zq 9639 . . . . . . . . . 10  |-  ( ( A  x.  ( F `
 ( k  +  1 ) ) )  e.  ZZ  ->  ( A  x.  ( F `  ( k  +  1 ) ) )  e.  QQ )
191184, 190syl 14 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A  x.  ( F `  ( k  +  1 ) ) )  e.  QQ )
19266adantr 276 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  N  e.  QQ )
19367adantr 276 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  0  <  N
)
194 modqabs2 10371 . . . . . . . . . 10  |-  ( ( ( A  x.  ( F `  ( k  +  1 ) ) )  e.  QQ  /\  N  e.  QQ  /\  0  <  N )  ->  (
( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N )  mod  N )  =  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N ) )
195191, 192, 193, 194syl3anc 1248 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( A  x.  ( F `
 ( k  +  1 ) ) )  mod  N )  mod 
N )  =  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N ) )
196189, 191, 131, 192, 193, 195modqmul1 10390 . . . . . . . 8  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N )  x.  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N ) )  mod  N )  =  ( ( ( A  x.  ( F `
 ( k  +  1 ) ) )  x.  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N ) )  mod  N ) )
19790adantr 276 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  A  e.  ZZ )
19851, 176sselid 3165 . . . . . . . . . . . . . 14  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( F `  x )  e.  ZZ )
199197, 198zmulcld 9394 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( A  x.  ( F `  x
) )  e.  ZZ )
200185adantr 276 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  N  e.  NN )
201199, 200zmodcld 10358 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( ( A  x.  ( F `  x ) )  mod 
N )  e.  NN0 )
202201nn0cnd 9244 . . . . . . . . . . 11  |-  ( ( ( ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  /\  x  e.  ( 1 ... ( k  +  1 ) ) )  ->  ( ( A  x.  ( F `  x ) )  mod 
N )  e.  CC )
203178oveq2d 5904 . . . . . . . . . . . 12  |-  ( x  =  ( k  +  1 )  ->  ( A  x.  ( F `  x ) )  =  ( A  x.  ( F `  ( k  +  1 ) ) ) )
204203oveq1d 5903 . . . . . . . . . . 11  |-  ( x  =  ( k  +  1 )  ->  (
( A  x.  ( F `  x )
)  mod  N )  =  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod 
N ) )
205157, 202, 204fprodp1 11621 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  x.  (
( A  x.  ( F `  ( k  +  1 ) ) )  mod  N ) ) )
206186nn0cnd 9244 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod 
N )  e.  CC )
207131zcnd 9389 . . . . . . . . . . 11  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N )  e.  CC )
208206, 207mulcomd 7992 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( A  x.  ( F `
 ( k  +  1 ) ) )  mod  N )  x. 
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  x.  ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N ) ) )
209205, 208eqtr4d 2223 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod  N )  =  ( ( ( A  x.  ( F `
 ( k  +  1 ) ) )  mod  N )  x. 
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )
) )
210209oveq1d 5903 . . . . . . . 8  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( prod_ x  e.  ( 1 ... (
k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod 
N )  mod  N
)  =  ( ( ( ( A  x.  ( F `  ( k  +  1 ) ) )  mod  N )  x.  prod_ x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x ) )  mod  N ) )  mod  N ) )
211149, 153mulcld 7991 . . . . . . . . . 10  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( A  x.  ( F `  ( k  +  1 ) ) )  e.  CC )
212207, 211mulcomd 7992 . . . . . . . . 9  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  =  ( ( A  x.  ( F `  ( k  +  1 ) ) )  x. 
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )
) )
213212oveq1d 5903 . . . . . . . 8  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N
)  =  ( ( ( A  x.  ( F `  ( k  +  1 ) ) )  x.  prod_ x  e.  ( 1 ... k
) ( ( A  x.  ( F `  x ) )  mod 
N ) )  mod 
N ) )
214196, 210, 2133eqtr4rd 2231 . . . . . . 7  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )
215182, 214eqeq12d 2202 . . . . . 6  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( ( ( A ^
k )  x.  prod_ x  e.  ( 1 ... k ) ( F `
 x ) )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N
)  =  ( (
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  x.  ( A  x.  ( F `  ( k  +  1 ) ) ) )  mod  N
)  <->  ( ( ( A ^ ( k  +  1 ) )  x.  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) ) )
216146, 215sylibd 149 . . . . 5  |-  ( (
ph  /\  k  e.  ( 1..^ ( phi `  N ) ) )  ->  ( ( ( ( A ^ k
)  x.  prod_ x  e.  ( 1 ... k
) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  ->  (
( ( A ^
( k  +  1 ) )  x.  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `
 x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) ) )
217216expcom 116 . . . 4  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  ( ph  ->  ( ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N )  ->  (
( ( A ^
( k  +  1 ) )  x.  prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( F `
 x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) ) ) )
218217a2d 26 . . 3  |-  ( k  e.  ( 1..^ ( phi `  N ) )  ->  ( ( ph  ->  ( ( ( A ^ k )  x.  prod_ x  e.  ( 1 ... k ) ( F `  x
) )  mod  N
)  =  ( prod_
x  e.  ( 1 ... k ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) )  -> 
( ph  ->  ( ( ( A ^ (
k  +  1 ) )  x.  prod_ x  e.  ( 1 ... (
k  +  1 ) ) ( F `  x ) )  mod 
N )  =  (
prod_ x  e.  (
1 ... ( k  +  1 ) ) ( ( A  x.  ( F `  x )
)  mod  N )  mod  N ) ) ) )
21916, 25, 34, 43, 89, 218fzind2 10252 . 2  |-  ( ( phi `  N )  e.  ( 1 ... ( phi `  N
) )  ->  ( ph  ->  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) ) )
2207, 219mpcom 36 1  |-  ( ph  ->  ( ( ( A ^ ( phi `  N ) )  x. 
prod_ x  e.  (
1 ... ( phi `  N ) ) ( F `  x ) )  mod  N )  =  ( prod_ x  e.  ( 1 ... ( phi `  N ) ) ( ( A  x.  ( F `  x ) )  mod  N )  mod  N ) )
Colors of variables: wff set class
Syntax hints:    -> wi 4    /\ wa 104    <-> wb 105    /\ w3a 979    = wceq 1363    e. wcel 2158   {crab 2469   class class class wbr 4015   -->wf 5224   -1-1-onto->wf1o 5227   ` cfv 5228  (class class class)co 5888   CCcc 7822   RRcr 7823   0cc0 7824   1c1 7825    + caddc 7827    x. cmul 7829    < clt 8005    <_ cle 8006   NNcn 8932   NN0cn0 9189   ZZcz 9266   ZZ>=cuz 9541   QQcq 9632   ...cfz 10021  ..^cfzo 10155    mod cmo 10335   ^cexp 10532   prod_cprod 11571    gcd cgcd 11956   phicphi 12222
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 1457  ax-7 1458  ax-gen 1459  ax-ie1 1503  ax-ie2 1504  ax-8 1514  ax-10 1515  ax-11 1516  ax-i12 1517  ax-bndl 1519  ax-4 1520  ax-17 1536  ax-i9 1540  ax-ial 1544  ax-i5r 1545  ax-13 2160  ax-14 2161  ax-ext 2169  ax-coll 4130  ax-sep 4133  ax-nul 4141  ax-pow 4186  ax-pr 4221  ax-un 4445  ax-setind 4548  ax-iinf 4599  ax-cnex 7915  ax-resscn 7916  ax-1cn 7917  ax-1re 7918  ax-icn 7919  ax-addcl 7920  ax-addrcl 7921  ax-mulcl 7922  ax-mulrcl 7923  ax-addcom 7924  ax-mulcom 7925  ax-addass 7926  ax-mulass 7927  ax-distr 7928  ax-i2m1 7929  ax-0lt1 7930  ax-1rid 7931  ax-0id 7932  ax-rnegex 7933  ax-precex 7934  ax-cnre 7935  ax-pre-ltirr 7936  ax-pre-ltwlin 7937  ax-pre-lttrn 7938  ax-pre-apti 7939  ax-pre-ltadd 7940  ax-pre-mulgt0 7941  ax-pre-mulext 7942  ax-arch 7943  ax-caucvg 7944
This theorem depends on definitions:  df-bi 117  df-dc 836  df-3or 980  df-3an 981  df-tru 1366  df-fal 1369  df-nf 1471  df-sb 1773  df-eu 2039  df-mo 2040  df-clab 2174  df-cleq 2180  df-clel 2183  df-nfc 2318  df-ne 2358  df-nel 2453  df-ral 2470  df-rex 2471  df-reu 2472  df-rmo 2473  df-rab 2474  df-v 2751  df-sbc 2975  df-csb 3070  df-dif 3143  df-un 3145  df-in 3147  df-ss 3154  df-nul 3435  df-if 3547  df-pw 3589  df-sn 3610  df-pr 3611  df-op 3613  df-uni 3822  df-int 3857  df-iun 3900  df-br 4016  df-opab 4077  df-mpt 4078  df-tr 4114  df-id 4305  df-po 4308  df-iso 4309  df-iord 4378  df-on 4380  df-ilim 4381  df-suc 4383  df-iom 4602  df-xp 4644  df-rel 4645  df-cnv 4646  df-co 4647  df-dm 4648  df-rn 4649  df-res 4650  df-ima 4651  df-iota 5190  df-fun 5230  df-fn 5231  df-f 5232  df-f1 5233  df-fo 5234  df-f1o 5235  df-fv 5236  df-isom 5237  df-riota 5844  df-ov 5891  df-oprab 5892  df-mpo 5893  df-1st 6154  df-2nd 6155  df-recs 6319  df-irdg 6384  df-frec 6405  df-1o 6430  df-oadd 6434  df-er 6548  df-en 6754  df-dom 6755  df-fin 6756  df-sup 6996  df-pnf 8007  df-mnf 8008  df-xr 8009  df-ltxr 8010  df-le 8011  df-sub 8143  df-neg 8144  df-reap 8545  df-ap 8552  df-div 8643  df-inn 8933  df-2 8991  df-3 8992  df-4 8993  df-n0 9190  df-z 9267  df-uz 9542  df-q 9633  df-rp 9667  df-fz 10022  df-fzo 10156  df-fl 10283  df-mod 10336  df-seqfrec 10459  df-exp 10533  df-ihash 10769  df-cj 10864  df-re 10865  df-im 10866  df-rsqrt 11020  df-abs 11021  df-clim 11300  df-proddc 11572  df-dvds 11808  df-gcd 11957  df-phi 12224
This theorem is referenced by:  eulerthlemth  12245
  Copyright terms: Public domain W3C validator