:: RINGCAT1  semantic presentation
:: deftheorem   RINGCAT1:def 1 : 
canceled; 
:: deftheorem Def2   defines linear RINGCAT1:def 2 : 
theorem :: RINGCAT1:1
canceled; 
theorem :: RINGCAT1:2
canceled; 
theorem Th3: :: RINGCAT1:3
:: deftheorem    defines dom RINGCAT1:def 3 : 
:: deftheorem    defines cod RINGCAT1:def 4 : 
:: deftheorem    defines fun RINGCAT1:def 5 : 
Lm1: 
for G being non empty  doubleLoopStr  holds   id G is linear
 
:: deftheorem Def6   defines RingMorphism-like RINGCAT1:def 6 : 
:: deftheorem    defines ID RINGCAT1:def 7 : 
:: deftheorem Def8   defines <= RINGCAT1:def 8 : 
Lm2: 
for F being  RingMorphism holds   RingMorphismStr(# the Dom of F,the Cod of F,the Fun of F #) is RingMorphism-like
 
:: deftheorem Def9   defines Morphism RINGCAT1:def 9 : 
Lm3: 
for F being  RingMorphism holds  the Fun of F is linear
 
Lm4: 
for G, H being  Ring
 for f being strict  RingMorphismStr   st  dom f = G &  cod f = H &  fun f is linear holds 
f is    Morphism of G,H
 
Lm5: 
for G, H being  Ring
 for f being  Function of G,H  st f is linear holds 
 RingMorphismStr(# G,H,f #) is    Morphism of G,H
 
Lm6: 
for F being  RingMorphism  ex G, H being  Ring st 
( G <= H &  dom F = G &  cod F = H &  RingMorphismStr(# the Dom of F,the Cod of F,the Fun of F #) is    Morphism of G,H )
 
theorem :: RINGCAT1:4
canceled; 
theorem Th5: :: RINGCAT1:5
theorem Th6: :: RINGCAT1:6
Lm7: 
for G, H being  Ring
 for F being   Morphism of G,H  st G <= H holds 
 ex f being  Function of G,H st 
( F =  RingMorphismStr(# G,H,f #) & f is linear )
 
Lm8: 
for G, H being  Ring
 for F being   Morphism of G,H  st G <= H holds 
 ex f being  Function of G,H st F =  RingMorphismStr(# G,H,f #)
 
theorem :: RINGCAT1:7
definition
let G, 
F be   
RingMorphism;
assume A1: 
 
dom G =  cod F
 ;
func G * F ->  strict RingMorphism means :
Def10: 
:: RINGCAT1:def 10
for 
G1, 
G2, 
G3 being  
Ring for 
g being  
Function of 
G2,
G3 for 
f being  
Function of 
G1,
G2  st  
RingMorphismStr(# the 
Dom of 
G,the 
Cod of 
G,the 
Fun of 
G #) 
=  RingMorphismStr(# 
G2,
G3,
g #) &  
RingMorphismStr(# the 
Dom of 
F,the 
Cod of 
F,the 
Fun of 
F #) 
=  RingMorphismStr(# 
G1,
G2,
f #) holds 
it =  RingMorphismStr(# 
G1,
G3,
(g * f) #);
existence 
 ex b1 being strict RingMorphism st 
for G1, G2, G3 being  Ring
 for g being  Function of G2,G3
 for f being  Function of G1,G2  st  RingMorphismStr(# the Dom of G,the Cod of G,the Fun of G #) =  RingMorphismStr(# G2,G3,g #) &  RingMorphismStr(# the Dom of F,the Cod of F,the Fun of F #) =  RingMorphismStr(# G1,G2,f #) holds 
b1 =  RingMorphismStr(# G1,G3,(g * f) #)
 
uniqueness 
for b1, b2 being strict RingMorphism  st ( for G1, G2, G3 being  Ring
 for g being  Function of G2,G3
 for f being  Function of G1,G2  st  RingMorphismStr(# the Dom of G,the Cod of G,the Fun of G #) =  RingMorphismStr(# G2,G3,g #) &  RingMorphismStr(# the Dom of F,the Cod of F,the Fun of F #) =  RingMorphismStr(# G1,G2,f #) holds 
b1 =  RingMorphismStr(# G1,G3,(g * f) #) ) & ( for G1, G2, G3 being  Ring
 for g being  Function of G2,G3
 for f being  Function of G1,G2  st  RingMorphismStr(# the Dom of G,the Cod of G,the Fun of G #) =  RingMorphismStr(# G2,G3,g #) &  RingMorphismStr(# the Dom of F,the Cod of F,the Fun of F #) =  RingMorphismStr(# G1,G2,f #) holds 
b2 =  RingMorphismStr(# G1,G3,(g * f) #) ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def10   defines * RINGCAT1:def 10 : 
for 
G, 
F being  
RingMorphism  st  
dom G =  cod F holds 
for 
b3 being 
strict RingMorphism holds 
 ( 
b3 = G * F iff for 
G1, 
G2, 
G3 being  
Ring for 
g being  
Function of 
G2,
G3 for 
f being  
Function of 
G1,
G2  st  
RingMorphismStr(# the 
Dom of 
G,the 
Cod of 
G,the 
Fun of 
G #) 
=  RingMorphismStr(# 
G2,
G3,
g #) &  
RingMorphismStr(# the 
Dom of 
F,the 
Cod of 
F,the 
Fun of 
F #) 
=  RingMorphismStr(# 
G1,
G2,
f #) holds 
b3 =  RingMorphismStr(# 
G1,
G3,
(g * f) #) );
theorem Th8: :: RINGCAT1:8
for 
G1, 
G2, 
G3 being  
Ring  st 
G1 <= G2 & 
G2 <= G3 holds 
G1 <= G3
theorem Th9: :: RINGCAT1:9
:: deftheorem Def11   defines *' RINGCAT1:def 11 : 
theorem Th10: :: RINGCAT1:10
for 
f, 
g being 
strict RingMorphism  st  
dom g =  cod f holds 
 ex 
G1, 
G2, 
G3 being  
Ring ex 
f0 being  
Function of 
G1,
G2 ex 
g0 being  
Function of 
G2,
G3 st 
( 
f =  RingMorphismStr(# 
G1,
G2,
f0 #) & 
g =  RingMorphismStr(# 
G2,
G3,
g0 #) & 
g * f =  RingMorphismStr(# 
G1,
G3,
(g0 * f0) #) )
theorem Th11: :: RINGCAT1:11
theorem Th12: :: RINGCAT1:12
theorem Th13: :: RINGCAT1:13
theorem Th14: :: RINGCAT1:14
:: deftheorem Def12   defines Ring_DOMAIN-like RINGCAT1:def 12 : 
:: deftheorem Def13   defines RingMorphism_DOMAIN-like RINGCAT1:def 13 : 
theorem :: RINGCAT1:15
canceled; 
theorem :: RINGCAT1:16
canceled; 
theorem Th17: :: RINGCAT1:17
:: deftheorem Def14   defines RingMorphism_DOMAIN RINGCAT1:def 14 : 
theorem Th18: :: RINGCAT1:18
theorem :: RINGCAT1:19
definition
let G, 
H be   
Ring;
assume A1: 
G <= H
 ;
func  Morphs G,
H ->    RingMorphism_DOMAIN of 
G,
H means :
Def15: 
:: RINGCAT1:def 15
for 
x being   
set  holds 
 ( 
x in it iff 
x is    
Morphism of 
G,
H );
existence 
 ex b1 being   RingMorphism_DOMAIN of G,H st 
for x being   set  holds 
 ( x in b1 iff x is    Morphism of G,H )
 
uniqueness 
for b1, b2 being   RingMorphism_DOMAIN of G,H  st ( for x being   set  holds 
 ( x in b1 iff x is    Morphism of G,H ) ) & ( for x being   set  holds 
 ( x in b2 iff x is    Morphism of G,H ) ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def15   defines Morphs RINGCAT1:def 15 : 
definition
let x, 
y be    
set ;
pred  GO x,
y means :
Def16: 
:: RINGCAT1:def 16
 ex 
x1, 
x2, 
x3, 
x4, 
x5, 
x6 being   
set  st 
( 
x = [[x1,x2,x3,x4],x5,x6] &  ex 
G being 
strict Ring st 
( 
y = G & 
x1 = the 
carrier of 
G & 
x2 = the 
addF of 
G & 
x3 =  comp G & 
x4 =  0. G & 
x5 = the 
multF of 
G & 
x6 =  1. G ) );
 
end;
 
:: deftheorem Def16   defines GO RINGCAT1:def 16 : 
for 
x, 
y being   
set  holds 
 (  
GO x,
y iff  ex 
x1, 
x2, 
x3, 
x4, 
x5, 
x6 being   
set  st 
( 
x = [[x1,x2,x3,x4],x5,x6] &  ex 
G being 
strict Ring st 
( 
y = G & 
x1 = the 
carrier of 
G & 
x2 = the 
addF of 
G & 
x3 =  comp G & 
x4 =  0. G & 
x5 = the 
multF of 
G & 
x6 =  1. G ) ) );
theorem Th20: :: RINGCAT1:20
for 
x, 
y1, 
y2 being   
set   st  
GO x,
y1 &  
GO x,
y2 holds 
y1 = y2
theorem Th21: :: RINGCAT1:21
:: deftheorem Def17   defines RingObjects RINGCAT1:def 17 : 
theorem Th22: :: RINGCAT1:22
theorem Th23: :: RINGCAT1:23
:: deftheorem Def18   defines Morphs RINGCAT1:def 18 : 
:: deftheorem    defines ID RINGCAT1:def 19 : 
definition
let V be   
Ring_DOMAIN;
func  dom V ->   Function of  
Morphs V,
V means :
Def20: 
:: RINGCAT1:def 20
for 
f being   
Element of  
Morphs V holds  
it . f =  dom f;
existence 
 ex b1 being  Function of  Morphs V,V st 
for f being   Element of  Morphs V holds  b1 . f =  dom f
 
uniqueness 
for b1, b2 being  Function of  Morphs V,V  st ( for f being   Element of  Morphs V holds  b1 . f =  dom f ) & ( for f being   Element of  Morphs V holds  b2 . f =  dom f ) holds 
b1 = b2
 
func  cod V ->   Function of  
Morphs V,
V means :
Def21: 
:: RINGCAT1:def 21
for 
f being   
Element of  
Morphs V holds  
it . f =  cod f;
existence 
 ex b1 being  Function of  Morphs V,V st 
for f being   Element of  Morphs V holds  b1 . f =  cod f
 
uniqueness 
for b1, b2 being  Function of  Morphs V,V  st ( for f being   Element of  Morphs V holds  b1 . f =  cod f ) & ( for f being   Element of  Morphs V holds  b2 . f =  cod f ) holds 
b1 = b2
 
func  ID V ->   Function of 
V, 
Morphs V means :
Def22: 
:: RINGCAT1:def 22
for 
G being   
Element of 
V holds  
it . G =  ID G;
existence 
 ex b1 being  Function of V, Morphs V st 
for G being   Element of V holds  b1 . G =  ID G
 
uniqueness 
for b1, b2 being  Function of V, Morphs V  st ( for G being   Element of V holds  b1 . G =  ID G ) & ( for G being   Element of V holds  b2 . G =  ID G ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def20   defines dom RINGCAT1:def 20 : 
:: deftheorem Def21   defines cod RINGCAT1:def 21 : 
:: deftheorem Def22   defines ID RINGCAT1:def 22 : 
theorem Th24: :: RINGCAT1:24
theorem Th25: :: RINGCAT1:25
definition
let V be   
Ring_DOMAIN;
func  comp V ->   PartFunc of 
[:(Morphs V),(Morphs V):], 
Morphs V means :
Def23: 
:: RINGCAT1:def 23
( ( for 
g, 
f being   
Element of  
Morphs V holds 
 ( 
[g,f] in  dom it iff  
dom g =  cod f ) ) & ( for 
g, 
f being   
Element of  
Morphs V  st 
[g,f] in  dom it holds 
it . g,
f = g * f ) );
existence 
 ex b1 being  PartFunc of [:(Morphs V),(Morphs V):], Morphs V st 
( ( for g, f being   Element of  Morphs V holds 
 ( [g,f] in  dom b1 iff  dom g =  cod f ) ) & ( for g, f being   Element of  Morphs V  st [g,f] in  dom b1 holds 
b1 . g,f = g * f ) )
 
uniqueness 
for b1, b2 being  PartFunc of [:(Morphs V),(Morphs V):], Morphs V  st ( for g, f being   Element of  Morphs V holds 
 ( [g,f] in  dom b1 iff  dom g =  cod f ) ) & ( for g, f being   Element of  Morphs V  st [g,f] in  dom b1 holds 
b1 . g,f = g * f ) & ( for g, f being   Element of  Morphs V holds 
 ( [g,f] in  dom b2 iff  dom g =  cod f ) ) & ( for g, f being   Element of  Morphs V  st [g,f] in  dom b2 holds 
b2 . g,f = g * f ) holds 
b1 = b2
 
 
end;
 
:: deftheorem Def23   defines comp RINGCAT1:def 23 : 
definition
let UN be   
Universe;
func  RingCat UN ->    CatStr  equals :: RINGCAT1:def 24
 CatStr(# 
(RingObjects UN),
(Morphs (RingObjects UN)),
(dom (RingObjects UN)),
(cod (RingObjects UN)),
(comp (RingObjects UN)),
(ID (RingObjects UN)) #);
coherence 
 CatStr(# (RingObjects UN),(Morphs (RingObjects UN)),(dom (RingObjects UN)),(cod (RingObjects UN)),(comp (RingObjects UN)),(ID (RingObjects UN)) #) is    CatStr 
 ;
 
end;
 
:: deftheorem    defines RingCat RINGCAT1:def 24 : 
theorem Th26: :: RINGCAT1:26
theorem Th27: :: RINGCAT1:27
theorem Th28: :: RINGCAT1:28
theorem Th29: :: RINGCAT1:29
theorem Th30: :: RINGCAT1:30
Lm9: 
for UN being  Universe
 for f, g being  Morphism of (RingCat UN)  st  dom g =  cod f holds 
(  dom (g * f) =  dom f &  cod (g * f) =  cod g )
 
Lm10: 
for UN being  Universe
 for f, g, h being  Morphism of (RingCat UN)  st  dom h =  cod g &  dom g =  cod f holds 
h * (g * f) = (h * g) * f
 
Lm11: 
for UN being  Universe
 for b being  Object of (RingCat UN) holds 
 (  dom (id b) = b &  cod (id b) = b & ( for f being  Morphism of (RingCat UN)  st  cod f = b holds 
(id b) * f = f ) & ( for g being  Morphism of (RingCat UN)  st  dom g = b holds 
g * (id b) = g ) )