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

Theorem modfzo0difsn 9397
Description: For a number within a half-open range of nonnegative integers with one excluded integer there is a positive integer so that the number is equal to the sum of the positive integer and the excluded integer modulo the upper bound of the range. (Contributed by AV, 19-Mar-2021.)
Assertion
Ref Expression
modfzo0difsn  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  ->  E. i  e.  (
1..^ N ) K  =  ( ( i  +  J )  mod 
N ) )
Distinct variable groups:    i, J    i, K    i, N

Proof of Theorem modfzo0difsn
StepHypRef Expression
1 eldifi 3094 . . . 4  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  K  e.  ( 0..^ N ) )
2 elfzoelz 9157 . . . 4  |-  ( K  e.  ( 0..^ N )  ->  K  e.  ZZ )
31, 2syl 14 . . 3  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  K  e.  ZZ )
4 elfzoelz 9157 . . 3  |-  ( J  e.  ( 0..^ N )  ->  J  e.  ZZ )
5 zdcle 8424 . . . 4  |-  ( ( K  e.  ZZ  /\  J  e.  ZZ )  -> DECID  K  <_  J )
6 exmiddc 777 . . . 4  |-  (DECID  K  <_  J  ->  ( K  <_  J  \/  -.  K  <_  J ) )
75, 6syl 14 . . 3  |-  ( ( K  e.  ZZ  /\  J  e.  ZZ )  ->  ( K  <_  J  \/  -.  K  <_  J
) )
83, 4, 7syl2anr 284 . 2  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  <_  J  \/  -.  K  <_  J
) )
9 zleloe 8398 . . . . . 6  |-  ( ( K  e.  ZZ  /\  J  e.  ZZ )  ->  ( K  <_  J  <->  ( K  <  J  \/  K  =  J )
) )
103, 4, 9syl2anr 284 . . . . 5  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  <_  J  <->  ( K  <  J  \/  K  =  J )
) )
11 elfzo0 9191 . . . . . . . . . . . . 13  |-  ( K  e.  ( 0..^ N )  <->  ( K  e. 
NN0  /\  N  e.  NN  /\  K  <  N
) )
12 elfzo0 9191 . . . . . . . . . . . . . . . 16  |-  ( J  e.  ( 0..^ N )  <->  ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
) )
13 nn0cn 8298 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( K  e.  NN0  ->  K  e.  CC )
1413adantr 270 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( K  e.  NN0  /\  K  <  N )  ->  K  e.  CC )
1514adantl 271 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  K  e.  CC )
16 nn0cn 8298 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( J  e.  NN0  ->  J  e.  CC )
17163ad2ant1 959 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  J  e.  CC )
1817adantr 270 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  J  e.  CC )
19 nncn 8047 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( N  e.  NN  ->  N  e.  CC )
20193ad2ant2 960 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  N  e.  CC )
2120adantr 270 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  N  e.  CC )
2215, 18, 21subadd23d 7441 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( ( K  -  J )  +  N )  =  ( K  +  ( N  -  J ) ) )
23 simpl 107 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  NN0  /\  K  <  N )  ->  K  e.  NN0 )
24 nn0z 8371 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( J  e.  NN0  ->  J  e.  ZZ )
25 nnz 8370 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( N  e.  NN  ->  N  e.  ZZ )
26 znnsub 8402 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  ZZ  /\  N  e.  ZZ )  ->  ( J  <  N  <->  ( N  -  J )  e.  NN ) )
2724, 25, 26syl2an 283 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN )  ->  ( J  <  N  <->  ( N  -  J )  e.  NN ) )
2827biimp3a 1276 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  ( N  -  J )  e.  NN )
29 nn0nnaddcl 8319 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  NN0  /\  ( N  -  J
)  e.  NN )  ->  ( K  +  ( N  -  J
) )  e.  NN )
3023, 28, 29syl2anr 284 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( K  +  ( N  -  J ) )  e.  NN )
3122, 30eqeltrd 2155 . . . . . . . . . . . . . . . . . . 19  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( ( K  -  J )  +  N )  e.  NN )
3231adantr 270 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( ( K  -  J )  +  N
)  e.  NN )
33 simp2 939 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  N  e.  NN )
3433adantr 270 . . . . . . . . . . . . . . . . . . 19  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  N  e.  NN )
3534adantr 270 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  ->  N  e.  NN )
36 nn0re 8297 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( K  e.  NN0  ->  K  e.  RR )
3736adantr 270 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( K  e.  NN0  /\  K  <  N )  ->  K  e.  RR )
3837adantl 271 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  K  e.  RR )
39 nn0re 8297 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( J  e.  NN0  ->  J  e.  RR )
40393ad2ant1 959 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  J  e.  RR )
4140adantr 270 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  J  e.  RR )
4238, 41sublt0d 7670 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( ( K  -  J )  <  0  <->  K  <  J ) )
4342bicomd 139 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( K  <  J  <->  ( K  -  J )  <  0
) )
4443biimpa 290 . . . . . . . . . . . . . . . . . . 19  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( K  -  J
)  <  0 )
45 resubcl 7372 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( K  e.  RR  /\  J  e.  RR )  ->  ( K  -  J
)  e.  RR )
4637, 40, 45syl2anr 284 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( K  -  J )  e.  RR )
47 nnre 8046 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( N  e.  NN  ->  N  e.  RR )
48473ad2ant2 960 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  N  e.  RR )
4948adantr 270 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  N  e.  RR )
5046, 49jca 300 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  /\  ( K  e.  NN0  /\  K  <  N ) )  ->  ( ( K  -  J )  e.  RR  /\  N  e.  RR ) )
5150adantr 270 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( ( K  -  J )  e.  RR  /\  N  e.  RR ) )
52 ltaddnegr 7529 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( ( K  -  J
)  e.  RR  /\  N  e.  RR )  ->  ( ( K  -  J )  <  0  <->  ( ( K  -  J
)  +  N )  <  N ) )
5351, 52syl 14 . . . . . . . . . . . . . . . . . . 19  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( ( K  -  J )  <  0  <->  ( ( K  -  J
)  +  N )  <  N ) )
5444, 53mpbid 145 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( ( K  -  J )  +  N
)  <  N )
55 elfzo1 9199 . . . . . . . . . . . . . . . . . 18  |-  ( ( ( K  -  J
)  +  N )  e.  ( 1..^ N )  <->  ( ( ( K  -  J )  +  N )  e.  NN  /\  N  e.  NN  /\  ( ( K  -  J )  +  N )  < 
N ) )
5632, 35, 54, 55syl3anbrc 1122 . . . . . . . . . . . . . . . . 17  |-  ( ( ( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  /\  ( K  e.  NN0  /\  K  < 
N ) )  /\  K  <  J )  -> 
( ( K  -  J )  +  N
)  e.  ( 1..^ N ) )
5756exp31 356 . . . . . . . . . . . . . . . 16  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  (
( K  e.  NN0  /\  K  <  N )  ->  ( K  < 
J  ->  ( ( K  -  J )  +  N )  e.  ( 1..^ N ) ) ) )
5812, 57sylbi 119 . . . . . . . . . . . . . . 15  |-  ( J  e.  ( 0..^ N )  ->  ( ( K  e.  NN0  /\  K  <  N )  ->  ( K  <  J  ->  (
( K  -  J
)  +  N )  e.  ( 1..^ N ) ) ) )
5958com12 30 . . . . . . . . . . . . . 14  |-  ( ( K  e.  NN0  /\  K  <  N )  -> 
( J  e.  ( 0..^ N )  -> 
( K  <  J  ->  ( ( K  -  J )  +  N
)  e.  ( 1..^ N ) ) ) )
60593adant2 957 . . . . . . . . . . . . 13  |-  ( ( K  e.  NN0  /\  N  e.  NN  /\  K  <  N )  ->  ( J  e.  ( 0..^ N )  ->  ( K  <  J  ->  (
( K  -  J
)  +  N )  e.  ( 1..^ N ) ) ) )
6111, 60sylbi 119 . . . . . . . . . . . 12  |-  ( K  e.  ( 0..^ N )  ->  ( J  e.  ( 0..^ N )  ->  ( K  < 
J  ->  ( ( K  -  J )  +  N )  e.  ( 1..^ N ) ) ) )
621, 61syl 14 . . . . . . . . . . 11  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( J  e.  ( 0..^ N )  ->  ( K  <  J  ->  (
( K  -  J
)  +  N )  e.  ( 1..^ N ) ) ) )
6362impcom 123 . . . . . . . . . 10  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  <  J  ->  ( ( K  -  J )  +  N
)  e.  ( 1..^ N ) ) )
6463impcom 123 . . . . . . . . 9  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( ( K  -  J )  +  N )  e.  ( 1..^ N ) )
65 oveq1 5539 . . . . . . . . . . . 12  |-  ( i  =  ( ( K  -  J )  +  N )  ->  (
i  +  J )  =  ( ( ( K  -  J )  +  N )  +  J ) )
662zcnd 8470 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( K  e.  ( 0..^ N )  ->  K  e.  CC )
6766adantr 270 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  ( 0..^ N )  /\  ( J  e.  NN0  /\  N  e.  NN ) )  ->  K  e.  CC )
6816adantr 270 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN )  ->  J  e.  CC )
6968adantl 271 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  ( 0..^ N )  /\  ( J  e.  NN0  /\  N  e.  NN ) )  ->  J  e.  CC )
7019adantl 271 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN )  ->  N  e.  CC )
7170adantl 271 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  ( 0..^ N )  /\  ( J  e.  NN0  /\  N  e.  NN ) )  ->  N  e.  CC )
7267, 69, 713jca 1118 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( K  e.  ( 0..^ N )  /\  ( J  e.  NN0  /\  N  e.  NN ) )  -> 
( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC )
)
7372ex 113 . . . . . . . . . . . . . . . . . . 19  |-  ( K  e.  ( 0..^ N )  ->  ( ( J  e.  NN0  /\  N  e.  NN )  ->  ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC ) ) )
741, 73syl 14 . . . . . . . . . . . . . . . . . 18  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  (
( J  e.  NN0  /\  N  e.  NN )  ->  ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC ) ) )
7574com12 30 . . . . . . . . . . . . . . . . 17  |-  ( ( J  e.  NN0  /\  N  e.  NN )  ->  ( K  e.  ( ( 0..^ N ) 
\  { J }
)  ->  ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC ) ) )
76753adant3 958 . . . . . . . . . . . . . . . 16  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  ( K  e.  ( (
0..^ N )  \  { J } )  -> 
( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC )
) )
7712, 76sylbi 119 . . . . . . . . . . . . . . 15  |-  ( J  e.  ( 0..^ N )  ->  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC ) ) )
7877imp 122 . . . . . . . . . . . . . 14  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC )
)
7978adantl 271 . . . . . . . . . . . . 13  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC ) )
80 nppcan 7330 . . . . . . . . . . . . 13  |-  ( ( K  e.  CC  /\  J  e.  CC  /\  N  e.  CC )  ->  (
( ( K  -  J )  +  N
)  +  J )  =  ( K  +  N ) )
8179, 80syl 14 . . . . . . . . . . . 12  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( (
( K  -  J
)  +  N )  +  J )  =  ( K  +  N
) )
8265, 81sylan9eqr 2135 . . . . . . . . . . 11  |-  ( ( ( K  <  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  /\  i  =  ( ( K  -  J )  +  N
) )  ->  (
i  +  J )  =  ( K  +  N ) )
8382oveq1d 5547 . . . . . . . . . 10  |-  ( ( ( K  <  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  /\  i  =  ( ( K  -  J )  +  N
) )  ->  (
( i  +  J
)  mod  N )  =  ( ( K  +  N )  mod 
N ) )
8483eqeq2d 2092 . . . . . . . . 9  |-  ( ( ( K  <  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  /\  i  =  ( ( K  -  J )  +  N
) )  ->  ( K  =  ( (
i  +  J )  mod  N )  <->  K  =  ( ( K  +  N )  mod  N
) ) )
8511biimpi 118 . . . . . . . . . . . . . 14  |-  ( K  e.  ( 0..^ N )  ->  ( K  e.  NN0  /\  N  e.  NN  /\  K  < 
N ) )
8685a1d 22 . . . . . . . . . . . . 13  |-  ( K  e.  ( 0..^ N )  ->  ( J  e.  ( 0..^ N )  ->  ( K  e. 
NN0  /\  N  e.  NN  /\  K  <  N
) ) )
871, 86syl 14 . . . . . . . . . . . 12  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( J  e.  ( 0..^ N )  ->  ( K  e.  NN0  /\  N  e.  NN  /\  K  < 
N ) ) )
8887impcom 123 . . . . . . . . . . 11  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  e.  NN0  /\  N  e.  NN  /\  K  <  N ) )
8988adantl 271 . . . . . . . . . 10  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( K  e.  NN0  /\  N  e.  NN  /\  K  < 
N ) )
90 addmodidr 9375 . . . . . . . . . . 11  |-  ( ( K  e.  NN0  /\  N  e.  NN  /\  K  <  N )  ->  (
( K  +  N
)  mod  N )  =  K )
9190eqcomd 2086 . . . . . . . . . 10  |-  ( ( K  e.  NN0  /\  N  e.  NN  /\  K  <  N )  ->  K  =  ( ( K  +  N )  mod 
N ) )
9289, 91syl 14 . . . . . . . . 9  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  K  =  ( ( K  +  N )  mod  N
) )
9364, 84, 92rspcedvd 2708 . . . . . . . 8  |-  ( ( K  <  J  /\  ( J  e.  (
0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N ) )
9493ex 113 . . . . . . 7  |-  ( K  <  J  ->  (
( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
95 eldifsn 3517 . . . . . . . . . 10  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  <->  ( K  e.  ( 0..^ N )  /\  K  =/=  J
) )
96 eqneqall 2255 . . . . . . . . . . . 12  |-  ( K  =  J  ->  ( K  =/=  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N ) ) )
9796com12 30 . . . . . . . . . . 11  |-  ( K  =/=  J  ->  ( K  =  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N
) ) )
9897adantl 271 . . . . . . . . . 10  |-  ( ( K  e.  ( 0..^ N )  /\  K  =/=  J )  ->  ( K  =  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N
) ) )
9995, 98sylbi 119 . . . . . . . . 9  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( K  =  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N
) ) )
10099adantl 271 . . . . . . . 8  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  =  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
101100com12 30 . . . . . . 7  |-  ( K  =  J  ->  (
( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
10294, 101jaoi 668 . . . . . 6  |-  ( ( K  <  J  \/  K  =  J )  ->  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N ) 
\  { J }
) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N ) ) )
103102com12 30 . . . . 5  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( ( K  < 
J  \/  K  =  J )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N ) ) )
10410, 103sylbid 148 . . . 4  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  <_  J  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
105104com12 30 . . 3  |-  ( K  <_  J  ->  (
( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
106 zltnle 8397 . . . . . . . . . 10  |-  ( ( J  e.  ZZ  /\  K  e.  ZZ )  ->  ( J  <  K  <->  -.  K  <_  J )
)
1074, 3, 106syl2an 283 . . . . . . . . 9  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( J  <  K  <->  -.  K  <_  J )
)
108107bicomd 139 . . . . . . . 8  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( -.  K  <_  J 
<->  J  <  K ) )
109243ad2ant1 959 . . . . . . . . . . . . . . . . . 18  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  J  e.  ZZ )
110 nn0z 8371 . . . . . . . . . . . . . . . . . . 19  |-  ( K  e.  NN0  ->  K  e.  ZZ )
111110adantr 270 . . . . . . . . . . . . . . . . . 18  |-  ( ( K  e.  NN0  /\  K  <  N )  ->  K  e.  ZZ )
112 znnsub 8402 . . . . . . . . . . . . . . . . . 18  |-  ( ( J  e.  ZZ  /\  K  e.  ZZ )  ->  ( J  <  K  <->  ( K  -  J )  e.  NN ) )
113109, 111, 112syl2anr 284 . . . . . . . . . . . . . . . . 17  |-  ( ( ( K  e.  NN0  /\  K  <  N )  /\  ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
) )  ->  ( J  <  K  <->  ( K  -  J )  e.  NN ) )
114113biimpa 290 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( K  e. 
NN0  /\  K  <  N )  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  < 
N ) )  /\  J  <  K )  -> 
( K  -  J
)  e.  NN )
11533adantl 271 . . . . . . . . . . . . . . . . 17  |-  ( ( ( K  e.  NN0  /\  K  <  N )  /\  ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
) )  ->  N  e.  NN )
116115adantr 270 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( K  e. 
NN0  /\  K  <  N )  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  < 
N ) )  /\  J  <  K )  ->  N  e.  NN )
117 nn0ge0 8313 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( J  e.  NN0  ->  0  <_  J )
1181173ad2ant1 959 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  0  <_  J )
119118adantl 271 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  0  <_  J
)
120 subge02 7582 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( K  e.  RR  /\  J  e.  RR )  ->  ( 0  <_  J  <->  ( K  -  J )  <_  K ) )
12136, 40, 120syl2an 283 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( 0  <_  J 
<->  ( K  -  J
)  <_  K )
)
122119, 121mpbid 145 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( K  -  J )  <_  K
)
12340adantl 271 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  J  e.  RR )
12436adantr 270 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  K  e.  RR )
12548adantl 271 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  N  e.  RR )
126123, 124, 1253jca 1118 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( J  e.  RR  /\  K  e.  RR  /\  N  e.  RR ) )
12745ancoms 264 . . . . . . . . . . . . . . . . . . . . . . . 24  |-  ( ( J  e.  RR  /\  K  e.  RR )  ->  ( K  -  J
)  e.  RR )
1281273adant3 958 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  RR  /\  K  e.  RR  /\  N  e.  RR )  ->  ( K  -  J )  e.  RR )
129 simp2 939 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  RR  /\  K  e.  RR  /\  N  e.  RR )  ->  K  e.  RR )
130 simp3 940 . . . . . . . . . . . . . . . . . . . . . . 23  |-  ( ( J  e.  RR  /\  K  e.  RR  /\  N  e.  RR )  ->  N  e.  RR )
131128, 129, 1303jca 1118 . . . . . . . . . . . . . . . . . . . . . 22  |-  ( ( J  e.  RR  /\  K  e.  RR  /\  N  e.  RR )  ->  (
( K  -  J
)  e.  RR  /\  K  e.  RR  /\  N  e.  RR ) )
132126, 131syl 14 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( ( K  -  J )  e.  RR  /\  K  e.  RR  /\  N  e.  RR ) )
133 lelttr 7199 . . . . . . . . . . . . . . . . . . . . 21  |-  ( ( ( K  -  J
)  e.  RR  /\  K  e.  RR  /\  N  e.  RR )  ->  (
( ( K  -  J )  <_  K  /\  K  <  N )  ->  ( K  -  J )  <  N
) )
134132, 133syl 14 . . . . . . . . . . . . . . . . . . . 20  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( ( ( K  -  J )  <_  K  /\  K  <  N )  ->  ( K  -  J )  <  N ) )
135122, 134mpand 419 . . . . . . . . . . . . . . . . . . 19  |-  ( ( K  e.  NN0  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N ) )  ->  ( K  < 
N  ->  ( K  -  J )  <  N
) )
136135impancom 256 . . . . . . . . . . . . . . . . . 18  |-  ( ( K  e.  NN0  /\  K  <  N )  -> 
( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  ->  ( K  -  J )  <  N
) )
137136imp 122 . . . . . . . . . . . . . . . . 17  |-  ( ( ( K  e.  NN0  /\  K  <  N )  /\  ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
) )  ->  ( K  -  J )  <  N )
138137adantr 270 . . . . . . . . . . . . . . . 16  |-  ( ( ( ( K  e. 
NN0  /\  K  <  N )  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  < 
N ) )  /\  J  <  K )  -> 
( K  -  J
)  <  N )
139114, 116, 1383jca 1118 . . . . . . . . . . . . . . 15  |-  ( ( ( ( K  e. 
NN0  /\  K  <  N )  /\  ( J  e.  NN0  /\  N  e.  NN  /\  J  < 
N ) )  /\  J  <  K )  -> 
( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J
)  <  N )
)
140139exp31 356 . . . . . . . . . . . . . 14  |-  ( ( K  e.  NN0  /\  K  <  N )  -> 
( ( J  e. 
NN0  /\  N  e.  NN  /\  J  <  N
)  ->  ( J  <  K  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  < 
N ) ) ) )
1411403adant2 957 . . . . . . . . . . . . 13  |-  ( ( K  e.  NN0  /\  N  e.  NN  /\  K  <  N )  ->  (
( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  -> 
( J  <  K  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J
)  <  N )
) ) )
14211, 141sylbi 119 . . . . . . . . . . . 12  |-  ( K  e.  ( 0..^ N )  ->  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  < 
N )  ->  ( J  <  K  ->  (
( K  -  J
)  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  <  N ) ) ) )
1431, 142syl 14 . . . . . . . . . . 11  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  (
( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  -> 
( J  <  K  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J
)  <  N )
) ) )
144143com12 30 . . . . . . . . . 10  |-  ( ( J  e.  NN0  /\  N  e.  NN  /\  J  <  N )  ->  ( K  e.  ( (
0..^ N )  \  { J } )  -> 
( J  <  K  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J
)  <  N )
) ) )
14512, 144sylbi 119 . . . . . . . . 9  |-  ( J  e.  ( 0..^ N )  ->  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( J  <  K  ->  (
( K  -  J
)  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  <  N ) ) ) )
146145imp 122 . . . . . . . 8  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( J  <  K  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J
)  <  N )
) )
147108, 146sylbid 148 . . . . . . 7  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( -.  K  <_  J  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  < 
N ) ) )
148147impcom 123 . . . . . 6  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  < 
N ) )
149 elfzo1 9199 . . . . . 6  |-  ( ( K  -  J )  e.  ( 1..^ N )  <->  ( ( K  -  J )  e.  NN  /\  N  e.  NN  /\  ( K  -  J )  < 
N ) )
150148, 149sylibr 132 . . . . 5  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( K  -  J )  e.  ( 1..^ N ) )
151 oveq1 5539 . . . . . . . 8  |-  ( i  =  ( K  -  J )  ->  (
i  +  J )  =  ( ( K  -  J )  +  J ) )
1521, 66syl 14 . . . . . . . . . 10  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  K  e.  CC )
1534zcnd 8470 . . . . . . . . . 10  |-  ( J  e.  ( 0..^ N )  ->  J  e.  CC )
154 npcan 7317 . . . . . . . . . 10  |-  ( ( K  e.  CC  /\  J  e.  CC )  ->  ( ( K  -  J )  +  J
)  =  K )
155152, 153, 154syl2anr 284 . . . . . . . . 9  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( ( K  -  J )  +  J
)  =  K )
156155adantl 271 . . . . . . . 8  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( ( K  -  J )  +  J )  =  K )
157151, 156sylan9eqr 2135 . . . . . . 7  |-  ( ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N ) 
\  { J }
) ) )  /\  i  =  ( K  -  J ) )  -> 
( i  +  J
)  =  K )
158157oveq1d 5547 . . . . . 6  |-  ( ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N ) 
\  { J }
) ) )  /\  i  =  ( K  -  J ) )  -> 
( ( i  +  J )  mod  N
)  =  ( K  mod  N ) )
159158eqeq2d 2092 . . . . 5  |-  ( ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N ) 
\  { J }
) ) )  /\  i  =  ( K  -  J ) )  -> 
( K  =  ( ( i  +  J
)  mod  N )  <->  K  =  ( K  mod  N ) ) )
160 zmodidfzoimp 9356 . . . . . . . . 9  |-  ( K  e.  ( 0..^ N )  ->  ( K  mod  N )  =  K )
1611, 160syl 14 . . . . . . . 8  |-  ( K  e.  ( ( 0..^ N )  \  { J } )  ->  ( K  mod  N )  =  K )
162161adantl 271 . . . . . . 7  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  -> 
( K  mod  N
)  =  K )
163162adantl 271 . . . . . 6  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  ( K  mod  N )  =  K )
164163eqcomd 2086 . . . . 5  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  K  =  ( K  mod  N ) )
165150, 159, 164rspcedvd 2708 . . . 4  |-  ( ( -.  K  <_  J  /\  ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod  N ) )
166165ex 113 . . 3  |-  ( -.  K  <_  J  ->  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( (
0..^ N )  \  { J } ) )  ->  E. i  e.  ( 1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
167105, 166jaoi 668 . 2  |-  ( ( K  <_  J  \/  -.  K  <_  J )  ->  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  ->  E. i  e.  (
1..^ N ) K  =  ( ( i  +  J )  mod 
N ) ) )
1688, 167mpcom 36 1  |-  ( ( J  e.  ( 0..^ N )  /\  K  e.  ( ( 0..^ N )  \  { J } ) )  ->  E. i  e.  (
1..^ N ) K  =  ( ( i  +  J )  mod 
N ) )
Colors of variables: wff set class
Syntax hints:   -. wn 3    -> wi 4    /\ wa 102    <-> wb 103    \/ wo 661  DECID wdc 775    /\ w3a 919    = wceq 1284    e. wcel 1433    =/= wne 2245   E.wrex 2349    \ cdif 2970   {csn 3398   class class class wbr 3785  (class class class)co 5532   CCcc 6979   RRcr 6980   0cc0 6981   1c1 6982    + caddc 6984    < clt 7153    <_ cle 7154    - cmin 7279   NNcn 8039   NN0cn0 8288   ZZcz 8351  ..^cfzo 9152    mod cmo 9324
This theorem was proved from axioms:  ax-1 5  ax-2 6  ax-mp 7  ax-ia1 104  ax-ia2 105  ax-ia3 106  ax-in1 576  ax-in2 577  ax-io 662  ax-5 1376  ax-7 1377  ax-gen 1378  ax-ie1 1422  ax-ie2 1423  ax-8 1435  ax-10 1436  ax-11 1437  ax-i12 1438  ax-bndl 1439  ax-4 1440  ax-13 1444  ax-14 1445  ax-17 1459  ax-i9 1463  ax-ial 1467  ax-i5r 1468  ax-ext 2063  ax-sep 3896  ax-pow 3948  ax-pr 3964  ax-un 4188  ax-setind 4280  ax-cnex 7067  ax-resscn 7068  ax-1cn 7069  ax-1re 7070  ax-icn 7071  ax-addcl 7072  ax-addrcl 7073  ax-mulcl 7074  ax-mulrcl 7075  ax-addcom 7076  ax-mulcom 7077  ax-addass 7078  ax-mulass 7079  ax-distr 7080  ax-i2m1 7081  ax-0lt1 7082  ax-1rid 7083  ax-0id 7084  ax-rnegex 7085  ax-precex 7086  ax-cnre 7087  ax-pre-ltirr 7088  ax-pre-ltwlin 7089  ax-pre-lttrn 7090  ax-pre-apti 7091  ax-pre-ltadd 7092  ax-pre-mulgt0 7093  ax-pre-mulext 7094  ax-arch 7095
This theorem depends on definitions:  df-bi 115  df-dc 776  df-3or 920  df-3an 921  df-tru 1287  df-fal 1290  df-nf 1390  df-sb 1686  df-eu 1944  df-mo 1945  df-clab 2068  df-cleq 2074  df-clel 2077  df-nfc 2208  df-ne 2246  df-nel 2340  df-ral 2353  df-rex 2354  df-reu 2355  df-rmo 2356  df-rab 2357  df-v 2603  df-sbc 2816  df-csb 2909  df-dif 2975  df-un 2977  df-in 2979  df-ss 2986  df-pw 3384  df-sn 3404  df-pr 3405  df-op 3407  df-uni 3602  df-int 3637  df-iun 3680  df-br 3786  df-opab 3840  df-mpt 3841  df-id 4048  df-po 4051  df-iso 4052  df-xp 4369  df-rel 4370  df-cnv 4371  df-co 4372  df-dm 4373  df-rn 4374  df-res 4375  df-ima 4376  df-iota 4887  df-fun 4924  df-fn 4925  df-f 4926  df-fv 4930  df-riota 5488  df-ov 5535  df-oprab 5536  df-mpt2 5537  df-1st 5787  df-2nd 5788  df-pnf 7155  df-mnf 7156  df-xr 7157  df-ltxr 7158  df-le 7159  df-sub 7281  df-neg 7282  df-reap 7675  df-ap 7682  df-div 7761  df-inn 8040  df-n0 8289  df-z 8352  df-uz 8620  df-q 8705  df-rp 8735  df-ico 8917  df-fz 9030  df-fzo 9153  df-fl 9274  df-mod 9325
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator