2
module Logic.Leibniz where
4
_≡_ : {A : Set} -> A -> A -> Set1
5
x ≡ y = (P : _ -> Set) -> P x -> P y
7
≡-refl : {A : Set}(x : A) -> x ≡ x
10
≡-sym : {A : Set}(x y : A) -> x ≡ y -> y ≡ x
11
≡-sym x y xy P py = xy (\z -> P z -> P x) (\px -> px) py
13
≡-trans : {A : Set}(x y z : A) -> x ≡ y -> y ≡ z -> x ≡ z
14
≡-trans x y z xy yz P px = yz P (xy P px)
16
≡-subst : {A : Set}(P : A -> Set)(x y : A) -> x ≡ y -> P x -> P y
17
≡-subst P _ _ xy = xy P