This commit is contained in:
Leon Vatthauer 2024-01-16 10:07:01 +01:00
parent 02c6307e17
commit 577b095325
Signed by: leonv
SSH key fingerprint: SHA256:G4+ddwoZmhLPRB1agvXzZMXIzkVJ36dUYZXf5NxT+u8

View file

@ -210,19 +210,16 @@ module Monad.Instance.Setoids.K { : Level} where
outer : A ⟶ A ×ₛ -setoid {} outer : A ⟶ A ×ₛ -setoid {}
outer = record { _⟨$⟩_ = λ z → z , zero ; cong = λ {x} {y} x≡y → x≡y , ≣-refl } outer = record { _⟨$⟩_ = λ z → z , zero ; cong = λ {x} {y} x≡y → x≡y , ≣-refl }
zero-helper : Delayₛ A ⟶ Delayₛ (A ×ₛ -setoid {}) ι-cancel : ∀ {x} → [ A ][ (ι {A} ∘′ (λ z → z , zero)) x now x ]
zero-helper = liftFₛ outer
ι-cancel : ∀ {x} → [ A ][ (ι ∘′ (λ z → z , zero)) x now x ]
ι-cancel = -refl A ι-cancel = -refl A
helper₁' : Delay ( A × {}) → ⟦ B ⟧ ⊎ Delay ( A × {}) helper₁' : Delay ( A × {}) → ⟦ B ⟧ ⊎ Delay ( A × {})
helper₁' (now (x , zero)) = inj₁ (< f > x) helper₁' (now (x , zero)) = inj₁ (< f > x)
helper₁' (now (x , suc n)) = inj₂ (< zero-helper > (ι {A} (x , n))) helper₁' (now (x , suc n)) = inj₂ (< liftFₛ outer > (ι {A} (x , n)))
helper₁' (later y) = inj₂ (force y) helper₁' (later y) = inj₂ (force y)
helper₁-cong' : {x y : Delay ( A × {})} → (xy : [ A ×ₛ -setoid ][ x y ]) → [ ⟦ B ⟧ ⊎ₛ Delayₛ (A ×ₛ -setoid) ][ helper₁' x ≡ helper₁' y ] helper₁-cong' : {x y : Delay ( A × {})} → (xy : [ A ×ₛ -setoid ][ x y ]) → [ ⟦ B ⟧ ⊎ₛ Delayₛ (A ×ₛ -setoid) ][ helper₁' x ≡ helper₁' y ]
helper₁-cong' {now (x , zero)} (now (x≡y , ≣-refl)) = inj₁ (cong f x≡y) helper₁-cong' {now (x , zero)} (now (x≡y , ≣-refl)) = inj₁ (cong f x≡y)
helper₁-cong' {now (x , suc n)} {now (y , suc _)} (now (x≡y , ≣-refl)) = inj₂ (cong zero-helper (cong ιₛ' (x≡y , ≣-refl))) helper₁-cong' {now (x , suc n)} {now (y , suc _)} (now (x≡y , ≣-refl)) = inj₂ (cong (liftFₛ outer) (cong ιₛ' (x≡y , ≣-refl)))
helper₁-cong' (later xy) = inj₂ (force xy) helper₁-cong' (later xy) = inj₂ (force xy)
helper' : Delayₛ (A ×ₛ -setoid) ⟶ ⟦ B ⟧ ⊎ₛ Delayₛ (A ×ₛ -setoid) helper' : Delayₛ (A ×ₛ -setoid) ⟶ ⟦ B ⟧ ⊎ₛ Delayₛ (A ×ₛ -setoid)
@ -257,13 +254,14 @@ module Monad.Instance.Setoids.K { : Level} where
-- Should follow by compositionality + fixpoint -- Should follow by compositionality + fixpoint
eq₁ : ∀ {z} → [ ⟦ B ⟧ ][ helper' # ⟨$⟩ z ≡ helper # ⟨$⟩ liftF proj₁ z ] eq₁ : ∀ {z} → [ ⟦ B ⟧ ][ helper' # ⟨$⟩ z ≡ helper # ⟨$⟩ liftF proj₁ z ]
eq₁ {x} = {! !} eq₁ {z} = {! !}
where where
step₁ : [ ⟦ B ⟧ ][ helper' # ⟨$⟩ z ≡ (< ([ inj₁ₛ , inj₂ₛ ∘ out ]ₛ ∘ helper' ∘ out⁻¹) # > ∘′ out) z ] step₁ : [ ⟦ B ⟧ ][ helper' # ⟨$⟩ z ≡ (< ([ inj₁ₛ , inj₂ₛ ∘ out ]ₛ ∘ helper' ∘ out⁻¹) # > ∘′ out) z ]
step₁ = {! !} -- should follow by uniformity step₁ = {! !} -- should follow by uniformity
step₂ : [ ⟦ B ⟧ ][ (< ([ inj₁ₛ , inj₂ₛ ∘ out ]ₛ ∘ helper' ∘ out⁻¹) # > ∘′ out) z ≡ helper # ⟨$⟩ liftF proj₁ z ] step₂ : ∀ {x} → [ ⟦ B ⟧ ][ (< ([ inj₁ₛ , inj₂ₛ ∘ out ]ₛ ∘ helper' ∘ out⁻¹) # > ∘′ out) x ≡ helper # ⟨$⟩ liftF proj₁ x ]
step₂ = {! !} -- ? step₂ {now x} = {! !}
step₂ {later x} = {! !} -- ?
eq : ∀ {x y} → [ A ×ₛ -setoid ][ x y ] → [ ⟦ B ⟧ ⊎ₛ Delayₛ A ][ [ inj₁ , inj₂ ∘′ μ ∘′ (liftF ι) ] (helper₁' x) ≡ (helper₁ ∘′ μ ∘′ (liftF ι)) y ] eq : ∀ {x y} → [ A ×ₛ -setoid ][ x y ] → [ ⟦ B ⟧ ⊎ₛ Delayₛ A ][ [ inj₁ , inj₂ ∘′ μ ∘′ (liftF ι) ] (helper₁' x) ≡ (helper₁ ∘′ μ ∘′ (liftF ι)) y ]
eq {now (x , n)} {now (y , .n)} (now (xy , ≣-refl)) = eq' eq {now (x , n)} {now (y , .n)} (now (xy , ≣-refl)) = eq'