{-# OPTIONS --cubical-compatible --safe #-}
module Data.List.Relation.Binary.Prefix.Homogeneous.Properties where
open import Level
open import Function.Base using (_∘′_)
open import Relation.Binary.Core using (Rel; REL; _⇒_)
open import Relation.Binary.Structures
using (IsPreorder; IsPartialOrder; IsDecPartialOrder)
open import Data.List.Relation.Binary.Pointwise as Pointwise using (Pointwise)
open import Data.List.Relation.Binary.Prefix.Heterogeneous
open import Data.List.Relation.Binary.Prefix.Heterogeneous.Properties
private
variable
a b r s : Level
A : Set a
B : Set b
R : REL A B r
S : REL A B s
isPreorder : IsPreorder R S → IsPreorder (Pointwise R) (Prefix S)
isPreorder po = record
{ isEquivalence = Pointwise.isEquivalence PO.isEquivalence
; reflexive = fromPointwise ∘′ Pointwise.map PO.reflexive
; trans = trans PO.trans
} where module PO = IsPreorder po
isPartialOrder : IsPartialOrder R S → IsPartialOrder (Pointwise R) (Prefix S)
isPartialOrder po = record
{ isPreorder = isPreorder PO.isPreorder
; antisym = antisym PO.antisym
} where module PO = IsPartialOrder po
isDecPartialOrder : IsDecPartialOrder R S → IsDecPartialOrder (Pointwise R) (Prefix S)
isDecPartialOrder dpo = record
{ isPartialOrder = isPartialOrder DPO.isPartialOrder
; _≟_ = Pointwise.decidable DPO._≟_
; _≤?_ = prefix? DPO._≤?_
} where module DPO = IsDecPartialOrder dpo