Merge pull request #905 from alebahn/master

Add public export to types/functions in Data.Fin.Order
This commit is contained in:
André Videla 2021-01-07 13:46:23 +00:00 committed by GitHub
commit 3478297557
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -10,23 +10,29 @@ import Decidable.Decidable
import Decidable.Order import Decidable.Order
using (k : Nat) using (k : Nat)
public export
data FinLTE : Fin k -> Fin k -> Type where data FinLTE : Fin k -> Fin k -> Type where
FromNatPrf : {m, n : Fin k} -> LTE (finToNat m) (finToNat n) -> FinLTE m n FromNatPrf : {m, n : Fin k} -> LTE (finToNat m) (finToNat n) -> FinLTE m n
public export
implementation Preorder (Fin k) FinLTE where implementation Preorder (Fin k) FinLTE where
transitive m n o (FromNatPrf p1) (FromNatPrf p2) = transitive m n o (FromNatPrf p1) (FromNatPrf p2) =
FromNatPrf (LTEIsTransitive (finToNat m) (finToNat n) (finToNat o) p1 p2) FromNatPrf (LTEIsTransitive (finToNat m) (finToNat n) (finToNat o) p1 p2)
reflexive n = FromNatPrf (LTEIsReflexive (finToNat n)) reflexive n = FromNatPrf (LTEIsReflexive (finToNat n))
public export
implementation Poset (Fin k) FinLTE where implementation Poset (Fin k) FinLTE where
antisymmetric m n (FromNatPrf p1) (FromNatPrf p2) = antisymmetric m n (FromNatPrf p1) (FromNatPrf p2) =
finToNatInjective m n (LTEIsAntisymmetric (finToNat m) (finToNat n) p1 p2) finToNatInjective m n (LTEIsAntisymmetric (finToNat m) (finToNat n) p1 p2)
public export
implementation Decidable 2 [Fin k, Fin k] FinLTE where implementation Decidable 2 [Fin k, Fin k] FinLTE where
decide m n with (decideLTE (finToNat m) (finToNat n)) decide m n with (decideLTE (finToNat m) (finToNat n))
decide m n | Yes prf = Yes (FromNatPrf prf) decide m n | Yes prf = Yes (FromNatPrf prf)
decide m n | No disprf = No (\ (FromNatPrf prf) => disprf prf) decide m n | No disprf = No (\ (FromNatPrf prf) => disprf prf)
public export
implementation Ordered (Fin k) FinLTE where implementation Ordered (Fin k) FinLTE where
order m n = order m n =
either (Left . FromNatPrf) either (Left . FromNatPrf)