-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathGenericOrd.agda
55 lines (45 loc) · 2.34 KB
/
GenericOrd.agda
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
open import Generics.Prelude hiding (_≟_)
open import Generics.Telescope
open import Generics.Desc
open import Generics.All
open import Generics.HasDesc
open import Agda.Primitive
open import Data.Fin using (_≟_ ; _<_)
open import Relation.Nullary using (yes ; no)
record Ord {ℓ} (A : Set ℓ) : Setω₁ where
field
_<ᵒ_ : A → A → Setω
open Ord ⦃...⦄ public
module _ {P I ℓ} {A : Indexed P I ℓ} (H : HasDesc {P} {I} A) where
open HasDesc H
open import Generics.Helpers P I (λ _ → ⊤) (λ _ → ⊤) (λ _ → ⊤ω) as Helpers
OrdHelpers : ∀ p → Setω
OrdHelpers p = Helpers p D
private module _ {p} (OH : OrdHelpers p) where
variable
V : ExTele P
v : ⟦ V ⟧tel p
i : ⟦ I ⟧tel p
ordIndArg : (C : ConDesc P V I) (x y : ⟦ C ⟧IndArg A′ (p , v)) →
AllIndArgω Acc C x → AllIndArgω Acc C y → Setω
ordCon : (C : ConDesc P V I) (H : ConHelper p C) (x y : ⟦ C ⟧Con A′ (p , v , i)) →
AllConω Acc C x → AllConω Acc C y → Setω
ord-wf : ∀ (x y : A′ (p , i)) → Acc x → Acc y → Setω
ordIndArg (var _) x y accx accy = ord-wf x y accx accy
ordIndArg (π ai S C) x y accx accy =
∀ s → ordIndArg C (app< ai > x s) (app< ai > y s) (accx s) (accy s)
ordIndArg (A ⊗ B) (xa , xb) (ya , yb) (accxa , accxb) (accya , accyb) =
ordIndArg A xa ya accxa accya ×ω ordIndArg B xb yb accxb accyb
ordCon _ var refl refl _ _ = ⊤ω
ordCon _ (pi-irr ⦃ _ ⦄ ⦃ H ⦄) (irrv _ , x) (irrv _ , y) accx accy = ordCon _ H x y accx accy
ordCon _ (pi-rel ⦃ _ ⦄ ⦃ H ⦄) (sx , x) (sy , y) accx accy =
Σω (sx ≡ sy) (λ {refl → ordCon _ H x y accx accy})
ordCon .(A ⊗ B) (prod {A} {B} ⦃ Ha ⦄ ⦃ Hb ⦄) (xa , xb) (ya , yb) (accxa , accxb) (accya , accyb) =
ordIndArg A xa ya accxa accya ×ω ordCon B Hb xb yb accxb accyb
ord-wf x y (acc ax) (acc ay) with split x | split y
ord-wf x y (acc ax) (acc ay) | (kx , x') | (ky , y') with kx ≟ ky
ord-wf x y (acc ax) (acc ay) | (kx , x') | (ky , y') | no _ = Liftω (kx < ky)
ord-wf x y (acc ax) (acc ay) | (k , x') | (k , y') | yes refl =
ordCon (lookupCon D k) (lookupHelper OH k) x' y' ax ay
deriveOrd : ∀ {p} ⦃ OH : OrdHelpers p ⦄ {i} → Ord (A′ (p , i))
deriveOrd ⦃ OH ⦄ ._<ᵒ_ x y = ord-wf OH x y (wf x) (wf y)