mirror of
https://git8.cs.fau.de/theses/bsc-leon-vatthauer.git
synced 2024-05-31 07:28:34 +02:00
36 lines
No EOL
1 KiB
Agda
36 lines
No EOL
1 KiB
Agda
{-# OPTIONS --guardedness #-}
|
||
open import Codata.Musical.Notation
|
||
open import Data.Nat
|
||
|
||
module reverse where
|
||
data Delay (A : Set) : Set where
|
||
now : A → Delay A
|
||
later : ∞ (Delay A) → Delay A
|
||
|
||
run_for_steps : ∀ {A : Set} → Delay A → ℕ → Delay A
|
||
run now x for n steps = now x
|
||
run later x for zero steps = later x
|
||
run later x for suc n steps = run ♭ x for n steps
|
||
|
||
never : ∀ {A : Set} → Delay A
|
||
never = later (♯ never)
|
||
|
||
data Colist (A : Set) : Set where
|
||
[] : Colist A
|
||
_∷_ : A → ∞ (Colist A) → Colist A
|
||
|
||
reverse : ∀ {A : Set} → Colist A → Delay (Colist A)
|
||
reverse {A} l = reverseAcc l []
|
||
where
|
||
reverseAcc : Colist A → Colist A → Delay (Colist A)
|
||
reverseAcc [] a = now a
|
||
reverseAcc (x ∷ xs) a = later (♯ reverseAcc (♭ xs) (x ∷ (♯ a)))
|
||
|
||
fin-colist : Colist ℕ
|
||
fin-colist = 1 ∷ ♯ (2 ∷ ♯ (3 ∷ ♯ []))
|
||
|
||
ones : Colist ℕ
|
||
ones = 1 ∷ ♯ ones
|
||
|
||
-- run reverse fin-colist for 5 steps
|
||
-- run reverse ones for 1000 steps |