{-# OPTIONS --safe --cubical-compatible --guardedness #-}
module Codata.Musical.Conat.Base where
open import Codata.Musical.Notation using (♭; ∞; ♯_)
open import Data.Nat.Base using (ℕ; zero; suc)
open import Function.Base using (_∋_)
data Coℕ : Set where
zero : Coℕ
suc : (n : ∞ Coℕ) → Coℕ
∞ℕ : Coℕ
∞ℕ = suc (♯ ∞ℕ)
pred : Coℕ → Coℕ
pred zero = zero
pred (suc n) = ♭ n
fromℕ : ℕ → Coℕ
fromℕ zero = zero
fromℕ (suc n) = suc (♯ fromℕ n)
infixl 6 _+_
_+_ : Coℕ → Coℕ → Coℕ
zero + n = n
suc m + n = suc (♯ (♭ m + n))