module ExamplePrograms.Simulation.FunCast1 where
open import Data.List using ([])
open import Data.Unit
open import Data.Bool renaming (Bool to 𝔹)
open import Relation.Binary.PropositionalEquality using (_≡_; refl)
open import Common.Types
open import Common.BlameLabels
open import Surface.SurfaceLang
M =
`let ƛ⟦ high ⟧ ` Bool of ⋆ ˙ ` 0 of low `in
`let (` 0) ∶ ⟦ ⋆ ⟧ (` Bool of ⋆) ⇒ (` Bool of ⋆) of ⋆ at pos 0 `in
(((` 0) ∶ ⟦ l low ⟧ (` Bool of l low) ⇒ (` Bool of l high) of ⋆ at pos 2) · $ false of low at pos 1)
M′ =
`let ƛ⟦ high ⟧ ` Bool of l high ˙ ` 0 of low `in
`let (` 0) ∶ ⟦ l low ⟧ (` Bool of l low) ⇒ (` Bool of l high) of ⋆ at pos 0 `in
(((` 0) ∶ ⟦ l low ⟧ (` Bool of l low) ⇒ (` Bool of l high) of l low at pos 2) · $ false of low at pos 1)
⊢M : [] ; l low ⊢ᴳ M ⦂ ` Bool of ⋆
⊢M = ⊢let (⊢lam (⊢var refl))
(⊢let (⊢ann (⊢var refl) (≲-ty ≾-⋆r (≲-fun ≾-⋆l ≲-refl (≲-ty ≾-⋆l ≲-ι))))
(⊢app (⊢ann (⊢var refl) (≲-ty ≾-refl (≲-fun ≾-⋆r (≲-ty ≾-⋆r ≲-ι) (≲-ty ≾-⋆l ≲-ι))))
⊢const (≲-ty ≾-refl ≲-ι) ≾-⋆l ≾-refl))
⊢M′ : [] ; l low ⊢ᴳ M′ ⦂ ` Bool of l high
⊢M′ = ⊢let (⊢lam (⊢var refl))
(⊢let (⊢ann (⊢var refl) (≲-ty ≾-⋆r (≲-fun (≾-l l≼h) (≲-ty (≾-l l≼h) ≲-ι) ≲-refl)))
(⊢app (⊢ann (⊢var refl) (≲-ty ≾-⋆l ≲ᵣ-refl)) ⊢const (≲-ty ≾-refl ≲-ι) ≾-refl ≾-refl))