Skip to content

Commit

Permalink
Remove Reflects type from Haskell.Law.Equality in favor of the one in…
Browse files Browse the repository at this point in the history
… Haskell.Extra.Dec
  • Loading branch information
jespercockx committed Dec 19, 2023
1 parent 578390d commit 7d64796
Show file tree
Hide file tree
Showing 7 changed files with 54 additions and 51 deletions.
24 changes: 23 additions & 1 deletion lib/Haskell/Extra/Dec.agda
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,32 @@ open import Haskell.Prelude
open import Haskell.Extra.Refinement
open import Agda.Primitive

@0 Reflects : {ℓ} Set Bool Set
private variable
: Level
P : Set

@0 Reflects : Set Bool Set
Reflects P True = P
Reflects P False = P

of : {b : Bool} if b then P else (P ⊥) Reflects P b
of {b = False} np = np
of {b = True} p = p

invert : {b} Reflects P b if b then P else (P ⊥)
invert {b = False} np = np
invert {b = True} p = p

extractTrue : { b } ⦃ true : b ≡ True ⦄ Reflects P b P
extractTrue {b = True} p = p

extractFalse : { b } ⦃ true : b ≡ False ⦄ Reflects P b (P ⊥)
extractFalse {b = False} np = np

mapReflects : {cond} (a b) (b a)
Reflects a cond Reflects b cond
mapReflects {cond = False} f g x = x ∘ g
mapReflects {cond = True} f g x = f x

Dec : {ℓ} @0 Set Set
Dec P = ∃ Bool (Reflects P)
Expand Down
10 changes: 10 additions & 0 deletions lib/Haskell/Law.agda
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,13 @@ module Haskell.Law where
open import Haskell.Prim
open import Haskell.Prim.Bool

open import Haskell.Law.Applicative public
open import Haskell.Law.Bool public
open import Haskell.Law.Eq public
open import Haskell.Law.Equality public
open import Haskell.Law.Functor public
open import Haskell.Law.List public
open import Haskell.Law.Maybe public
open import Haskell.Law.Monad public
open import Haskell.Law.Monoid public
open import Haskell.Law.Ord public
8 changes: 4 additions & 4 deletions lib/Haskell/Law/Eq/Bool.agda
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ open import Haskell.Law.Equality

instance
iLawfulEqBool : IsLawfulEq Bool
iLawfulEqBool .isEquality False False = ofY refl
iLawfulEqBool .isEquality False True = ofN λ()
iLawfulEqBool .isEquality True False = ofN λ()
iLawfulEqBool .isEquality True True = ofY refl
iLawfulEqBool .isEquality False False = refl
iLawfulEqBool .isEquality False True = λ()
iLawfulEqBool .isEquality True False = λ()
iLawfulEqBool .isEquality True True = refl

2 changes: 2 additions & 0 deletions lib/Haskell/Law/Eq/Def.agda
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ open import Haskell.Prim.Either

open import Haskell.Prim.Eq

open import Haskell.Extra.Dec

open import Haskell.Law.Bool
open import Haskell.Law.Equality

Expand Down
17 changes: 6 additions & 11 deletions lib/Haskell/Law/Eq/Maybe.agda
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,16 @@ open import Haskell.Prim
open import Haskell.Prim.Eq
open import Haskell.Prim.Maybe

open import Haskell.Extra.Dec

open import Haskell.Law.Eq.Def
open import Haskell.Law.Equality
open import Haskell.Law.Maybe

private
reflectsJust : ⦃ iEqA : Eq a ⦄ ⦃ IsLawfulEq a ⦄
(x y : a) Reflects (Just x ≡ Just y) ((Just x) == (Just y))
reflectsJust x y with (x == y) in h
... | True = ofY (cong Just (equality x y h))
... | False = ofN (λ eq (nequality x y h) (injective eq))

instance
iLawfulEqMaybe : ⦃ iEqA : Eq a ⦄ ⦃ IsLawfulEq a ⦄ IsLawfulEq (Maybe a)
iLawfulEqMaybe .isEquality Nothing Nothing = ofY refl
iLawfulEqMaybe .isEquality Nothing (Just _) = ofN λ()
iLawfulEqMaybe .isEquality (Just _) Nothing = ofN λ()
iLawfulEqMaybe .isEquality (Just x) (Just y) = reflectsJust x y
iLawfulEqMaybe .isEquality Nothing Nothing = refl
iLawfulEqMaybe .isEquality Nothing (Just _) = λ()
iLawfulEqMaybe .isEquality (Just _) Nothing = λ()
iLawfulEqMaybe .isEquality (Just x) (Just y) = mapReflects (cong Just) injective (isEquality x y)

18 changes: 9 additions & 9 deletions lib/Haskell/Law/Eq/Ordering.agda
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@ open import Haskell.Law.Equality
instance
iLawfulEqOrdering : IsLawfulEq Ordering

iLawfulEqOrdering .isEquality LT LT = ofY refl
iLawfulEqOrdering .isEquality LT EQ = ofN λ()
iLawfulEqOrdering .isEquality LT GT = ofN λ()
iLawfulEqOrdering .isEquality EQ LT = ofN λ()
iLawfulEqOrdering .isEquality EQ EQ = ofY refl
iLawfulEqOrdering .isEquality EQ GT = ofN λ()
iLawfulEqOrdering .isEquality GT LT = ofN λ()
iLawfulEqOrdering .isEquality GT EQ = ofN λ()
iLawfulEqOrdering .isEquality GT GT = ofY refl
iLawfulEqOrdering .isEquality LT LT = refl
iLawfulEqOrdering .isEquality LT EQ = λ()
iLawfulEqOrdering .isEquality LT GT = λ()
iLawfulEqOrdering .isEquality EQ LT = λ()
iLawfulEqOrdering .isEquality EQ EQ = refl
iLawfulEqOrdering .isEquality EQ GT = λ()
iLawfulEqOrdering .isEquality GT LT = λ()
iLawfulEqOrdering .isEquality GT EQ = λ()
iLawfulEqOrdering .isEquality GT GT = refl

26 changes: 0 additions & 26 deletions lib/Haskell/Law/Equality.agda
Original file line number Diff line number Diff line change
Expand Up @@ -54,29 +54,3 @@ _∎ _ = refl

syntax step-≡ x y≡z x≡y = x ≡⟨ x≡y ⟩ y≡z
syntax step-≡˘ x y≡z y≡x = x ≡˘⟨ y≡x ⟩ y≡z

--------------------------------------------------
-- Reflects idiom

data Reflects {p} (P : Set p) : Bool Set p where
ofY : ( p : P ) Reflects P True
ofN : ( np : (P ⊥) ) Reflects P False

private
variable
p : Level
P : Set p

of : {b} if b then P else (P ⊥) Reflects P b
of {b = False} np = ofN np
of {b = True } p = ofY p

invert : {b} Reflects P b if b then P else (P ⊥)
invert (ofY p) = p
invert (ofN np) = np

extractTrue : { b } ⦃ true : b ≡ True ⦄ Reflects P b P
extractTrue (ofY p) = p

extractFalse : { b } ⦃ true : b ≡ False ⦄ Reflects P b (P ⊥)
extractFalse (ofN np) = np

0 comments on commit 7d64796

Please sign in to comment.