summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkrasimir <krasimir@chalmers.se>2010-02-22 14:38:13 +0000
committerkrasimir <krasimir@chalmers.se>2010-02-22 14:38:13 +0000
commitbcf4bc7d23f442155887860a2cfc2ce94b35cf6e (patch)
treee694cf49e026a9501a24c405e2c88350118ce93e
parent59d640088e65002354beaa2b149f6b884731192f (diff)
the oposites of two equal arrows are equal arrows
-rw-r--r--examples/category-theory/Categories.gf12
1 files changed, 10 insertions, 2 deletions
diff --git a/examples/category-theory/Categories.gf b/examples/category-theory/Categories.gf
index e8f4b7955..6cc557d81 100644
--- a/examples/category-theory/Categories.gf
+++ b/examples/category-theory/Categories.gf
@@ -15,7 +15,7 @@ abstract Categories = {
fun comp : ({c} : Category) -> ({x,y,z} : El c) -> Arrow z y -> Arrow x z -> Arrow x y ;
- data eqRefl : ({c} : Category)
+ data eqRefl : ({c} : Category)
-> ({x,y} : El c)
-> (a : Arrow x y)
-> EqAr a a ;
@@ -77,7 +77,15 @@ abstract Categories = {
-> Arrow {Op c} (opEl y) (opEl x) ;
def id {Op c} (opEl {c} x) = opAr (id x) ;
def comp {Op c} {opEl {c} x} {opEl {c} y} {opEl {c} z} (opAr {c} {y} {z} f) (opAr {c} {z} {x} g) = opAr (comp g f) ;
-
+
+ fun eqOp : ({c} : Category)
+ -> ({x,y} : El c)
+ -> ({f} : Arrow x y)
+ -> ({g} : Arrow x y)
+ -> EqAr f g
+ -> EqAr (opAr f) (opAr g) ;
+ def eqOp {c} {x} {y} {f} {f} (eqRefl {c} {x} {y} f) = eqRefl (opAr f) ;
+
data Slash : (c : Category)
-> (x : El c)
-> Category ;