------------------------------------------------------------------------
-- "Equational" reasoning combinator setup
------------------------------------------------------------------------

{-# OPTIONS --without-K --safe #-}

open import Labelled-transition-system

module Bisimilarity.Weak.Alternative.Equational-reasoning-instances
         {} {lts : LTS } where

open import Prelude

open import Bisimilarity lts
import Bisimilarity.Equational-reasoning-instances
open import Bisimilarity.Weak.Alternative lts
open import Equational-reasoning

instance

  trans∼≈ :  {i}  Transitive _∼_ [ i ]_≈_
  trans∼≈ = is-transitive (transitive {a = }  ∼⇒≈)

  trans∼′≈ :  {i}  Transitive _∼′_ [ i ]_≈_
  trans∼′≈ = is-transitive (transitive {a = }  ∼⇒≈″)

  trans∼′≈′ :  {i}  Transitive _∼′_ [ i ]_≈′_
  trans∼′≈′ = is-transitive (transitive {a = }  ∼⇒≈″)

  trans∼≈′ :  {i}  Transitive _∼_ [ i ]_≈′_
  trans∼≈′ {i} = is-transitive (transitive {a = }  ∼⇒≈ {i})

  convert∼≈ : Convertible _∼_ _≈_
  convert∼≈ = is-convertible ∼⇒≈

  convert∼′≈ : Convertible _∼′_ _≈_
  convert∼′≈ = is-convertible (convert {a = }  ∼⇒≈″)

  convert∼≈′ : Convertible _∼_ _≈′_
  convert∼≈′ = is-convertible ∼⇒≈′

  convert∼′≈′ : Convertible _∼′_ _≈′_
  convert∼′≈′ = is-convertible ∼⇒≈″

open Bisimilarity.Equational-reasoning-instances
       {lts = weak lts} public