:: The Chinese Remainder Theorem
:: by Andrzej Kondracki
:: 
:: Received December 30, 1997
:: Copyright (c) 1997 Association of Mizar Users
theorem :: WSIERP_1:1
canceled; 
theorem Th2: :: WSIERP_1:2
theorem Th3: :: WSIERP_1:3
theorem :: WSIERP_1:4
canceled; 
theorem Th5: :: WSIERP_1:5
Lm1: 
for x, y being  real   number  holds 
 ( ( x >=  0  implies x + y >= y ) & ( x + y >= y implies x >=  0  ) & ( x >  0  implies x + y > y ) & ( x + y > y implies x >  0  ) & ( x >=  0  implies y >= y - x ) & ( y >= y - x implies x >=  0  ) & ( x >  0  implies y > y - x ) & ( y > y - x implies x >  0  ) )
 
Lm2: 
for x, y, z being  real   number   st x >=  0  & y >= z holds 
( x + y >= z & y >= z - x )
 
Lm3: 
for x, y, z being  real   number   st ( ( x >=  0  & y > z ) or ( x >  0  & y >= z ) ) holds 
( x + y > z & y > z - x )
 
Lm4: 
for a being  Nat  ex b being  Nat st 
( a = 2 * b or a = (2 * b) + 1 )
 
theorem :: WSIERP_1:6
canceled; 
theorem :: WSIERP_1:7
canceled; 
theorem :: WSIERP_1:8
canceled; 
theorem Th9: :: WSIERP_1:9
theorem Th10: :: WSIERP_1:10
theorem Th11: :: WSIERP_1:11
theorem :: WSIERP_1:12
theorem Th13: :: WSIERP_1:13
theorem Th14: :: WSIERP_1:14
theorem Th15: :: WSIERP_1:15
theorem Th16: :: WSIERP_1:16
theorem Th17: :: WSIERP_1:17
theorem :: WSIERP_1:18
theorem Th19: :: WSIERP_1:19
theorem Th20: :: WSIERP_1:20
theorem :: WSIERP_1:21
Lm5: 
for a, b being  Nat  st a <>  0  holds 
( a divides b iff b / a is    Element of  NAT  )
 
theorem Th22: :: WSIERP_1:22
Lm6: 
for b, a being  Nat
 for k being  Integer  st b <>  0  & a * k = b holds 
k is    Element of  NAT 
 
Lm7: 
for a, b, c being  Nat  st a + b <= c holds 
( a <= c & b <= c )
 
theorem :: WSIERP_1:23
for 
a, 
b, 
c being  
Nat  st 
a <= b - c holds 
( 
a <= b & 
c <= b )
Lm8: 
for k, m being  Integer holds 
 ( k < m iff k <= m - 1 )
 
Lm9: 
for k, m being  Integer holds 
 ( k < m + 1 iff k <= m )
 
Lm12: 
for a being  Nat
 for fs being  FinSequence  st a in  dom fs holds 
 ex fs1, fs2 being  FinSequence st 
( fs = (fs1 ^ <*(fs . a)*>) ^ fs2 &  len fs1 = a - 1 &  len fs2 = (len fs) - a )
 
:: deftheorem Def1   defines Del WSIERP_1:def 1 : 
for 
a being  
Nat for 
fs being  
FinSequence for 
b3 being   
set  holds 
 ( ( not 
a in  dom fs implies ( 
b3 =  Del fs,
a iff 
b3 = fs ) ) & ( 
a in  dom fs implies ( 
b3 =  Del fs,
a iff ( 
(len b3) + 1 
=  len fs & ( for 
b being  
Nat holds 
 ( ( 
b < a implies 
b3 . b = fs . b ) & ( 
b >= a implies 
b3 . b = fs . (b + 1) ) ) ) ) ) ) );
Lm13: 
for a being  Nat
 for fs, fs1, fs2 being  FinSequence
 for v being   set   st a in  dom fs & fs = (fs1 ^ <*v*>) ^ fs2 &  len fs1 = a - 1 holds 
 Del fs,a = fs1 ^ fs2
 
Lm14: 
for a being  Nat
 for fs being  FinSequence holds   dom (Del fs,a) c=  dom fs
 
Lm15: 
for a being  Nat
 for fs1, fs2 being  FinSequence holds 
 ( ( a <=  len fs1 implies  Del (fs1 ^ fs2),a = (Del fs1,a) ^ fs2 ) & ( a >= 1 implies  Del (fs1 ^ fs2),((len fs1) + a) = fs1 ^ (Del fs2,a) ) )
 
Lm16: 
for fs being  FinSequence
 for v being   set  holds 
 (  Del (<*v*> ^ fs),1 = fs &  Del (fs ^ <*v*>),((len fs) + 1) = fs )
 
theorem :: WSIERP_1:24
canceled; 
theorem :: WSIERP_1:25
canceled; 
theorem :: WSIERP_1:26
for 
v1, 
v2, 
v3 being   
set  holds 
 (  
Del <*v1*>,1 
=  {}  &  
Del <*v1,v2*>,1 
= <*v2*> &  
Del <*v1,v2*>,2 
= <*v1*> &  
Del <*v1,v2,v3*>,1 
= <*v2,v3*> &  
Del <*v1,v2,v3*>,2 
= <*v1,v3*> &  
Del <*v1,v2,v3*>,3 
= <*v1,v2*> )
Lm17: 
for fs being  FinSequence  st 1 <=  len fs holds 
( fs = <*(fs . 1)*> ^ (Del fs,1) & fs = (Del fs,(len fs)) ^ <*(fs . (len fs))*> )
 
Lm18: 
for a being  Nat
 for ft being   FinSequence of  REAL   st a in  dom ft holds 
(Product (Del ft,a)) * (ft . a) =  Product ft
 
theorem :: WSIERP_1:27
theorem :: WSIERP_1:28
theorem Th29: :: WSIERP_1:29
theorem :: WSIERP_1:30
theorem Th31: :: WSIERP_1:31
theorem Th32: :: WSIERP_1:32
theorem :: WSIERP_1:33
theorem Th34: :: WSIERP_1:34
theorem Th35: :: WSIERP_1:35
theorem Th36: :: WSIERP_1:36
theorem :: WSIERP_1:37
theorem Th38: :: WSIERP_1:38
theorem :: WSIERP_1:39
for 
f, 
g, 
a, 
b being  
Nat  st 
f >  0  & 
g >  0  & 
f gcd g = 1 & 
a |^ f = b |^ g holds 
 ex 
e being  
Nat st 
( 
a = e |^ g & 
b = e |^ f )
theorem Th40: :: WSIERP_1:40
theorem :: WSIERP_1:41
theorem :: WSIERP_1:42
for 
a, 
b, 
c, 
d being  
Nat  st 
a gcd b = 1 & 
a * b = c |^ d holds 
 ex 
e, 
f being  
Nat st 
( 
a = e |^ d & 
b = f |^ d )
theorem Th43: :: WSIERP_1:43
theorem :: WSIERP_1:44
Lm20: 
for k, m being  Integer holds 
 ( k divides m iff k divides  abs m )
 
Lm21: 
for m, n being  Integer holds  (m * n) mod n =  0 
 
Lm22: 
for k, n, m being  Integer  st k mod n = m mod n holds 
(k - m) mod n =  0 
 
Lm23: 
for n, m being  Integer  st n <>  0  & m mod n =  0  holds 
n divides m
 
Lm24: 
for x being  Integer holds 
 ( ( 1 < x implies ( 1 <  sqrt x &  sqrt x < x ) ) & (  0  < x & x < 1 implies (  0  <  sqrt x &  sqrt x < 1 & x <  sqrt x ) ) )
 
theorem :: WSIERP_1:45
canceled; 
theorem :: WSIERP_1:46
theorem :: WSIERP_1:47
theorem :: WSIERP_1:48
theorem :: WSIERP_1:49
theorem :: WSIERP_1:50