module Data.Power.Complemented where

Complemented subobjects🔗

A subobject p:P(A)p : \mathbb{P}(A) of a type AA is called complemented if there is a subobject ApA \setminus p such that Ap(Ap)A \sube p \cup (A \setminus p)1, and (p(Ap))(p \cap (A \setminus p)) \sube \emptyset. Because of P(A)\mathbb{P}(A)’s lattice structure, these containments suffice to establish equality.

is-complemented :  {} {A : Type ℓ} (p : ℙ A)  Type _
is-complemented {A = A} p = Σ[ p⁻¹ ∈ ℙ A ]
  ((p ∩ p⁻¹ ⊆ minimal) × (maximal ⊆ p ∪ p⁻¹))

More conventionally, in constructive mathematics, we may say a subobject is decidable if its associated predicate is pointwise a decidable type. It turns out that these conditions are equivalent: a subobject is decidable if, and only if, it is complemented. It’s immediate that decidable subobjects are complemented: given a decision procedure pp, the fibres p(yes(x))p^*(\mathrm{yes}(x)) and p(no(x))p^*(\mathrm{no}(x)) are disjoint and their union is all of AA.

is-decidable :  {} {A : Type ℓ} (p : ℙ A)  Type _
is-decidable p =  a  Dec (a ∈ p)

is-decidable→is-complemented : (p : ℙ A)  is-decidable p  is-complemented p
is-decidable→is-complemented {A = A} p dec = inv , intersection , union where
  inv : ℙ A
  inv x = el (x ∉ p) hlevel!

  intersection : (p ∩ inv) ⊆ minimal
  intersection x (x∈p , x∉p) = x∉p x∈p

  union : maximal ⊆ (p ∪ inv)
  union x wit with dec x
  ... | yes x∈p = inc (inl x∈p)
  ... | no x∉p = inc (inr x∉p)

For the converse, since decidability of a proposition is itself a proposition, it suffices to assume we have an inhabitant of (xp)(xp1)(x \in p) \coprod (x \in p^{-1}). Assuming that xp1x \in p^{-1}, we must show that xpx \notin p: But by the definition of complemented subobject, the intersection (pp1)(p \cap p^{-1}) is empty.

is-complemented→is-decidable : (p : ℙ A)  is-complemented p  is-decidable p
is-complemented→is-decidable p (p⁻¹ , intersection , union) elt =
  ∥-∥-rec!   { (inl x∈p)    yes x∈p
             ; (inr x∈p⁻¹)  no λ x∈p  intersection elt (x∈p , x∈p⁻¹)
             })
    (union elt tt)

Decidable subobject classifiers🔗

In the same way that we have a (large) type Propκ\mathrm{Prop}_\kappa of all propositions of size κ\kappa, the decidable (complemented) subobjects also have a classifying object: Any two-element type with decidable equality! This can be seen as a local instance of excluded middle: the complemented subobjects are precisely those satisfying P¬PP \lor \neg P, and so they are classified by the “classical subobject classifier” 2:={0,1}2 := \{ 0, 1 \}.

decidable-subobject-classifier
  : (A  Bool)(Σ[ p ∈ ℙ A ] (is-decidable p))
decidable-subobject-classifier = eqv where

In much the same way that the subobject represented by a map APropA \to \mathrm{Prop} is the fibre over \top, the subobject represented by a map A2A \to 2 is the fibre over true\mathtt{true}. This is a decidable subobject because 22 has decidable equality.

  to : (A  Bool)  (Σ[ p ∈ ℙ A ] (is-decidable p))
  to map .fst x = el (map x ≡ true) hlevel!
  to map .snd p = Bool-elim  p  Dec (p ≡ true))
    (yes refl) (no  p  true≠false (sym p))) (map p)

Conversely, to each decidable subobject p:P(A)p : \mathbb{P}(A) and element x:Ax : A we associate a boolean bb such that (btrue)(b \equiv \mathtt{true}) if and only if xpx \in p. Projecting the boolean and forgetting the equivalence gives us a map A2A \to 2 associated with pp, as desired; The characterisation of bb serves to smoothen the proof that this process is inverse to taking fibres over true\mathtt{true}.

  from : (pr : Σ[ p ∈ ℙ A ] (is-decidable p)) (x : A)
        (Σ[ b ∈ Bool ] ((b ≡ true)(x ∈ pr .fst)))
  from (p , dec) elt = Dec-elim  _  Σ Bool  b  (b ≡ true)(elt ∈ p)))
     y  true , prop-ext!  _  y)  _  refl))
     x∉p  false , prop-ext!
       p  absurd (true≠false (sym p)))
       x  absurd (x∉p x)))
    (dec elt)

  eqv = Iso→Equiv λ where
    .fst  to
    .snd .is-iso.inv p x  from p x .fst
    .snd .is-iso.rinv pred  Σ-prop-path! $ ℙ-ext
       x w  from pred x .snd .fst w)
       x p  Equiv.from (from pred x .snd) p)
    .snd .is-iso.linv pred  funext λ x 
      Bool-elim  p  from (to λ _  p) x .fst ≡ p) refl refl (pred x)

  1. where AA is regarded as the top element of its own subobject lattice↩︎