Subtype.hascasl revision 6b7d53eb1a93b9a9d7e3ce48964128fcd142fe53
vars a: Type; b: Type
type i a b, Inj a b < a -> b
vars a: Type; b < a
op twice: (a ->? b) -> (a ->? b)
vars f: a ->? b; x: a
. twice f x = f (f x)
vars a: Type; b: Type
type Inj a b = {f: a -> b . forall x, y: a . f x = f y => x = y}
vars a, b: Type; a < b
op down: b ->? a
var y: b; x: a
. down y = x
op up: a -> b
. down (up x : b) = x
. def (down (y : b) : a) => up (down y : a) = y
vars c: Type; b < c
var x: a
. up (up x : b) = up x : c
. up (x: a) = x: b
vars c, d, e, f; c < e; d < f
forall f: e -> f . up : e ->? f = \ x : e . f x
forall f: e ->? d . up f : c ->? f = \ x : c . up (f (up x))
forall x: c; y: d . up (x, y) : e * f = (up x, up y)