Source code on Github{-# OPTIONS --cubical-compatible #-}
module Class.Decidable.Instances where
open import Class.Prelude
open import Class.Decidable.Core
open import Class.DecEq.Core
instance
DecEq⇒Dec : ⦃ DecEq A ⦄ → _≡_ {A = A} ⁇²
DecEq⇒Dec = ⁇² _≟_
Dec-⊥ : ⊥ ⁇
Dec-⊥ .dec = no λ()
Dec-⊤ : ⊤ ⁇
Dec-⊤ .dec = yes tt
open import Relation.Nullary.Decidable as D
Dec-→ : ⦃ A ⁇ ⦄ → ⦃ B ⁇ ⦄ → (A → B) ⁇
Dec-→ .dec = dec D.→-dec dec
Dec-× : ⦃ A ⁇ ⦄ → ⦃ B ⁇ ⦄ → (A × B) ⁇
Dec-× .dec = dec D.×-dec dec
Dec-⊎ : ⦃ A ⁇ ⦄ → ⦃ B ⁇ ⦄ → (A ⊎ B) ⁇
Dec-⊎ .dec = dec D.⊎-dec dec
Dec-T : T ⁇¹
Dec-T = ⁇¹ 𝔹.T?
import Data.List.Relation.Unary.All as L
import Data.List.Relation.Unary.Any as L
Dec-All : ⦃ P ⁇¹ ⦄ → L.All P ⁇¹
Dec-All = ⁇¹ L.all? dec¹
Dec-Any : ⦃ P ⁇¹ ⦄ → L.Any P ⁇¹
Dec-Any = ⁇¹ L.any? dec¹
import Data.List.Relation.Unary.AllPairs as AP
Dec-AllPairs : ⦃ R ⁇² ⦄ → AP.AllPairs R ⁇¹
Dec-AllPairs = ⁇¹ AP.allPairs? dec²
open import Data.Vec.Relation.Unary.All as V
open import Data.Vec.Relation.Unary.Any as V
Dec-VAll : ⦃ P ⁇¹ ⦄ → V.All P {n} ⁇¹
Dec-VAll = ⁇¹ V.all? dec¹
Dec-VAny : ⦃ P ⁇¹ ⦄ → V.Any P {n} ⁇¹
Dec-VAny = ⁇¹ V.any? dec¹
import Data.Maybe.Relation.Unary.All as Mb renaming (dec to all?)
import Data.Maybe.Relation.Unary.Any as Mb renaming (dec to any?)
Dec-MAll : ⦃ P ⁇¹ ⦄ → Mb.All P ⁇¹
Dec-MAll = ⁇¹ Mb.all? dec¹
Dec-MAny : ⦃ P ⁇¹ ⦄ → Mb.Any P ⁇¹
Dec-MAny = ⁇¹ Mb.any? dec¹
ℕ-Dec-≤ = ⁇² Nat._≤?_
ℕ-Dec-< = ⁇² Nat._<?_
import Data.Integer.Properties as ℤ
ℤ-Dec-≤ = ⁇² ℤ._≤?_
ℤ-Dec-< = ⁇² ℤ._<?_
import Data.Rational.Properties as Rat
ℚ-Dec-≤ = ⁇² Rat._≤?_
ℚ-Dec-< = ⁇² Rat._<?_