Martin Escardo, 20th December 2021

Some thoughts about Dedekind reals.

A Dedekind real in constructive type theory is defined as a triple
(L , U , p) where L and U are data, namely given sets of rational
numbers, and p is property of (L , U).

But actually, given a lower Dedekind section L, there is at most one
pair (U , p) such that (L , U , p) is a Dedekind real. Hence the
Dedekind data (U , p) is property of the lower real L rather than
data. A more precise statement of this phenomenon is given below.

We generalize the rationals to any type with a proposition-valued,
irreflexive relation _<_, simply to avoid having to define the
rational numbers. But also it is interesting than nothing other than
a proposition-valued irreflexive relation is needed for the above
discussion.

We also discuss a version of the Dedekind reals proposed by Troelstra.
To show that it agrees with the usual one, we further assume that _<_
is dense, upper open, and satisfies p ≠ q → p ≮ q → p < q (which the
type of rationals does).

We also discuss what happens when we assume the principle of
excluded middle.

Here we adopt HoTT/UF as our type-theoretic foundation, which, in
particular, is well-suited to discuss the distinction between data and
property. The univalence axiom is not used anywhere here, but we
mention it in some discussions.

See also the discussion at https://twitter.com/EscardoMartin/status/1473393261012295681

\begin{code}

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

open import MLTT.Spartan
open import Naturals.Order hiding (<-≤-trans)
open import Notation.CanonicalMap
open import Notation.Order
open import TypeTopology.CompactTypes
open import UF.Base
open import UF.Embeddings
open import UF.Equiv
open import UF.FunExt
open import UF.Powerset
open import UF.PropTrunc
open import UF.Sets
open import UF.Sets-Properties
open import UF.Size
open import UF.SubtypeClassifier
open import UF.Subsingletons
open import UF.Subsingletons-FunExt

module Various.Dedekind
        (pt  : propositional-truncations-exist)
        (fe  : Fun-Ext)
        (pe  : Prop-Ext)
        {𝓤  : Universe}
        (   : 𝓤 ̇ )
        (_<-ℚ-ℚ_              :     𝓤 ̇ )
        (<-ℚ-ℚ-is-prop-valued : (p q : )  is-prop (p <-ℚ-ℚ q))
        (<-ℚ-ℚ-irrefl         : (q : )  ¬ (q <-ℚ-ℚ q))
       where

open PropositionalTruncation pt
open inhabited-subsets pt

instance
 strict-order-ℚ : Strict-Order  
 _<_ {{strict-order-ℚ}} = _<-ℚ-ℚ_

𝓤⁺ = 𝓤 

\end{code}

Lower-real conditions:

\begin{code}

is-lower : 𝓟   𝓤 ̇
is-lower L = (q : )  q  L  (p : )  p < q  p  L

is-upper-open : 𝓟   𝓤 ̇
is-upper-open L = (p : )  p  L   p'   , ((p < p') × p'  L)

is-lower-real : 𝓟   𝓤 ̇
is-lower-real L = is-inhabited L × is-lower L × is-upper-open L

\end{code}

Upper-real conditions:

\begin{code}

is-upper : 𝓟   𝓤 ̇
is-upper U = (p : )  p  U  (q : )  p < q  q  U

is-lower-open : 𝓟   𝓤 ̇
is-lower-open U = (q : )  q  U   q'   , ((q' < q) × q'  U)

is-upper-real : 𝓟   𝓤 ̇
is-upper-real U = is-inhabited U × is-upper U × is-lower-open U

\end{code}

The conditions are property:

\begin{code}

being-lower-is-prop : (L : 𝓟 )  is-prop (is-lower L)
being-lower-is-prop L = Π₄-is-prop fe  _ _ _ _  ∈-is-prop L _)

being-upper-open-is-prop : (L : 𝓟 )  is-prop (is-upper-open L)
being-upper-open-is-prop L = Π₂-is-prop fe  _ _  ∃-is-prop)

being-lower-real-is-prop : (L : 𝓟 )  is-prop (is-lower-real L)
being-lower-real-is-prop L = ×₃-is-prop
                              (being-inhabited-is-prop L)
                              (being-lower-is-prop L)
                              (being-upper-open-is-prop L)

being-upper-is-prop : (L : 𝓟 )  is-prop (is-upper L)
being-upper-is-prop L = Π₄-is-prop fe  _ _ _ _  ∈-is-prop L _)

being-lower-open-is-prop : (L : 𝓟 )  is-prop (is-lower-open L)
being-lower-open-is-prop L = Π₂-is-prop fe  _ _  ∃-is-prop)

being-upper-real-is-prop : (L : 𝓟 )  is-prop (is-upper-real L)
being-upper-real-is-prop L = ×₃-is-prop
                              (being-inhabited-is-prop L)
                              (being-upper-is-prop L)
                              (being-lower-open-is-prop L)
\end{code}

The sets of lower and upper reals:

\begin{code}

ℝᴸ : 𝓤⁺ ̇
ℝᴸ = Σ L  𝓟  , is-lower-real L

ℝᵁ : 𝓤⁺ ̇
ℝᵁ = Σ U  𝓟  , is-upper-real U

ℝᴸ-is-set : is-set ℝᴸ
ℝᴸ-is-set = subsets-of-sets-are-sets (𝓟 )
             is-lower-real
             (powersets-are-sets'' fe fe pe)
              {l}  being-lower-real-is-prop l)

ℝᵁ-is-set : is-set ℝᵁ
ℝᵁ-is-set = subsets-of-sets-are-sets (𝓟 )
             is-upper-real
             (powersets-are-sets'' fe fe pe)
              {l}  being-upper-real-is-prop l)

ℝᴸ-to-𝓟ℚ : ℝᴸ  𝓟 
ℝᴸ-to-𝓟ℚ = pr₁

ℝᵁ-to-𝓟ℚ : ℝᵁ  𝓟 
ℝᵁ-to-𝓟ℚ = pr₁

instance
 canonical-map-ℝᴸ-to-𝓟ℚ : Canonical-Map ℝᴸ (𝓟 )
 ι {{canonical-map-ℝᴸ-to-𝓟ℚ}} = ℝᴸ-to-𝓟ℚ

 canonical-map-ℝᵁ-to-𝓟ℚ : Canonical-Map ℝᵁ (𝓟 )
 ι {{canonical-map-ℝᵁ-to-𝓟ℚ}} = ℝᵁ-to-𝓟ℚ

ℝᴸ-to-𝓟ℚ-is-embedding : is-embedding (canonical-map ℝᴸ (𝓟 ))
ℝᴸ-to-𝓟ℚ-is-embedding = pr₁-is-embedding being-lower-real-is-prop

ℝᵁ-to-𝓟ℚ-is-embedding : is-embedding (canonical-map ℝᵁ (𝓟 ))
ℝᵁ-to-𝓟ℚ-is-embedding = pr₁-is-embedding being-upper-real-is-prop

\end{code}

Next we define the set of Dedekind reals as a subset of the lower
reals, after some preparation.

\begin{code}

are-ordered : 𝓟   𝓟   𝓤  ̇
are-ordered L U = (p q : )  p  L  q  U  p < q

are-located : 𝓟   𝓟   𝓤  ̇
are-located L U = (p q : )  p < q  p  L  q  U

being-ordered-is-prop : (L U : 𝓟 )  is-prop (are-ordered L U)
being-ordered-is-prop _ _ = Π₄-is-prop fe  _ _ _ _  <-ℚ-ℚ-is-prop-valued _ _)

being-located-is-prop : (L U : 𝓟 )  is-prop (are-located L U)
being-located-is-prop _ _ = Π₃-is-prop fe  _ _ _  ∨-is-prop)

order-lemma : (L U L' U' : 𝓟 )
             is-lower-open U'
             are-located L  U
             are-ordered L' U'
             L   L'
             U'  U
order-lemma L U L' U'
            U'-lower-open
            LU-located
            LU'-ordered
            L-contained-in-L'
            q
            q-in-U'             = γ
 where
  I :  q'   , (q' < q) × q'  U'
  I = U'-lower-open q q-in-U'

  II : (Σ q'   , (q' < q) × q'  U')  q  U
  II (q' , l , i) = VI
   where
    III : q'  L  q  U
    III = LU-located q' q l

    IV : q'  L
    IV j = <-ℚ-ℚ-irrefl q' b
     where
      a : q'  L'
      a = L-contained-in-L' q' j

      b : q' < q'
      b = LU'-ordered q' q' a i

    V : (q'  L) + (q  U)  q  U
    V (inl j) = 𝟘-elim (IV j)
    V (inr k) = k

    VI : q  U
    VI = ∥∥-rec (∈-is-prop U q) V III

  γ : q  U
  γ = ∥∥-rec (∈-is-prop U q) II I


order-lemma-converse : (L U L' U' : 𝓟 )
                      is-upper-open L
                      are-located L' U'
                      are-ordered L  U
                      U'  U
                      L   L'
order-lemma-converse L U L' U'
                     L-upper-open
                     LU'-located
                     LU-ordered
                     U'-contained-in-U
                     q
                     q-in-L             = γ
 where
  I :  q'   , (q < q') × q'  L
  I = L-upper-open q q-in-L

  II : (Σ q'   , (q < q') × q'  L)  q  L'
  II (q' , l , i) = VI
   where
    III : q  L'  q'  U'
    III = LU'-located q q' l

    IV : q'  U'
    IV j = <-ℚ-ℚ-irrefl q' b
     where
      a : q'  U
      a = U'-contained-in-U q' j

      b : q' < q'
      b = LU-ordered q' q' i a

    V : (q  L') + (q'  U')  q  L'
    V (inl j) = j
    V (inr k) = 𝟘-elim (IV k)

    VI : q  L'
    VI = ∥∥-rec (∈-is-prop L' q) V III

  γ : q  L'
  γ = ∥∥-rec (∈-is-prop L' q) II I

\end{code}

The following definition is of an auxiliary character:

\begin{code}

_is-an-upper-section-of_ : 𝓟   𝓟   𝓤 ̇
U is-an-upper-section-of L = is-lower-open U × are-ordered L U × are-located L U

any-two-upper-sections-are-equal : (L U U' : 𝓟 )
                                  U  is-an-upper-section-of L
                                  U' is-an-upper-section-of L
                                  U  U'
any-two-upper-sections-are-equal L U U' (a , b , c) (u , v , w) = γ
 where
  i : U  U'
  i = order-lemma L U' L U  a w b (⊆-refl' L)

  j : U  U'
  j = order-lemma L U  L U' u c v (⊆-refl' L)

  γ : U  U'
  γ = subset-extensionality'' pe fe fe i j

\end{code}

The following is the version of the definition we are interested in:

\begin{code}

_is-upper-section-of_ : ℝᵁ  ℝᴸ  𝓤 ̇
(U , _) is-upper-section-of  (L , _) = are-ordered L U × are-located L U

being-upper-section-is-prop : (x : ℝᴸ) (y : ℝᵁ)
                             is-prop (y is-upper-section-of x)
being-upper-section-is-prop (L , _) (U , _) = ×-is-prop
                                               (being-ordered-is-prop L U)
                                               (being-located-is-prop L U)
\end{code}

We use the above auxiliary definition and lemma to establish the following:

\begin{code}

at-most-one-upper-section : (l : ℝᴸ) (u₀ u₁ : ℝᵁ)
                           u₀ is-upper-section-of l
                           u₁ is-upper-section-of l
                           u₀  u₁
at-most-one-upper-section (L , _)
                          u₀@(U₀ , _ , _ , U₀-is-lower-open)
                          u₁@(U₁ , _ , _ , U₁-is-lower-open)
                          (lu₀-ordered , lu₀-located)
                          (lu₁-ordered , lu₁-located)      = γ
 where
  γ : u₀  u₁
  γ = to-subtype-=
        being-upper-real-is-prop
        (any-two-upper-sections-are-equal L U₀ U₁
            (U₀-is-lower-open , lu₀-ordered , lu₀-located)
            (U₁-is-lower-open , lu₁-ordered , lu₁-located))
\end{code}

The Dedekind condition for a lower real:

\begin{code}

is-dedekind : ℝᴸ  𝓤⁺ ̇
is-dedekind l = Σ u  ℝᵁ , (u is-upper-section-of l)

being-dedekind-is-prop : (l : ℝᴸ)  is-prop (is-dedekind l)
being-dedekind-is-prop l (u₀ , p₀) (u₁ , p₁) =
 to-subtype-=
  (being-upper-section-is-prop l)
  (at-most-one-upper-section l u₀ u₁ p₀ p₁)

\end{code}

We define the Dedekind reals as a subset of the lower reals:

\begin{code}

 : 𝓤⁺ ̇
 = Σ l  ℝᴸ , is-dedekind l

\end{code}

The forgetful map of the reals into the lower reals is an embedding
and hence ℝ is a set:

\begin{code}

ℝ-to-ℝᴸ :   ℝᴸ
ℝ-to-ℝᴸ = pr₁

ℝ-to-ℝᴸ-is-embedding : is-embedding ℝ-to-ℝᴸ
ℝ-to-ℝᴸ-is-embedding = pr₁-is-embedding being-dedekind-is-prop

ℝ-is-set : is-set 
ℝ-is-set = subsets-of-sets-are-sets ℝᴸ
            is-dedekind
            ℝᴸ-is-set
             {l}  being-dedekind-is-prop l)

instance
 canonical-map-ℝ-to-ℝᴸ : Canonical-Map  ℝᴸ
 ι {{canonical-map-ℝ-to-ℝᴸ}} = ℝ-to-ℝᴸ

\end{code}

NB. This won't be a *topological* embedding in topological
models. Because ℝ and ℝᴸ are sets, in the sense of HoTT/UF, the
embedding condition merely says that the map is left-cancellable.

We unpack and reorder the definition to emphasize that it amounts to
the usual one:

\begin{code}

is-dedekind-section : 𝓟  × 𝓟   𝓤 ̇
is-dedekind-section (L , U) = is-inhabited L × is-lower L × is-upper-open L
                            × is-inhabited U × is-upper U × is-lower-open U
                            × are-ordered L U × are-located L U


NB₁ :   (Σ (L , R)  𝓟  × 𝓟  , is-dedekind-section (L , R))

NB₁ = qinveq
        ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l)
          ((L , U) , Li , Ll , Lo , Ui , Uu , Uo , o , l))

       ((λ ((L , U) , Li , Ll , Lo , Ui , Uu , Uo , o , l)
          ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l)) ,

         _  refl) ,

         _  refl))

\end{code}

The following shows that there is some redundancy in the definition of
Dedekind real:

\begin{code}

ordered-located-gives-lower : (L U : 𝓟 )
                             are-ordered L U
                             are-located L U
                             is-lower L
ordered-located-gives-lower L U LU-ordered LU-located = γ
 where
  γ : is-lower L
  γ q l p m = ∥∥-rec (∈-is-prop L p) b a
   where
    a : p  L  q  U
    a = LU-located p q m

    b : (p  L) + (q  U)  p  L
    b (inl u) = u
    b (inr v) = 𝟘-elim (<-ℚ-ℚ-irrefl q (LU-ordered q q l v))

ordered-located-gives-upper : (L U : 𝓟 )
                             are-ordered L U
                             are-located L U
                             is-upper U
ordered-located-gives-upper L U LU-ordered LU-located = γ
 where
  γ : is-upper U
  γ q l p m = ∥∥-rec (∈-is-prop U p) b a
   where
    a : q  L  p  U
    a = LU-located q p m

    b : (q  L) + (p  U)  p  U
    b (inl u) = 𝟘-elim (<-ℚ-ℚ-irrefl q (LU-ordered q q u l))
    b (inr v) = v


NB₂ :   (Σ (L , U)  𝓟  × 𝓟 
                , is-inhabited L × is-upper-open L
                × is-inhabited U × is-lower-open U
                × are-ordered L U × are-located L U)

NB₂ = qinveq
        ((L , Li , _ , Lo) , (U , Ui , _ , Uo) , o , l)
          ((L , U) , Li , Lo , Ui , Uo , o , l))

       ((λ ((L , U) , Li , Lo , Ui , Uo , o , l)
          ((L , Li , ordered-located-gives-lower L U o l , Lo) ,
            (U , Ui , ordered-located-gives-upper L U o l , Uo) ,
            o , l)) ,

         ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l)
           to-subtype-= being-dedekind-is-prop
             (to-subtype-= being-lower-real-is-prop refl)) ,

         ((L , U) , Li , Lo , Ui , Uo , o , l)
          to-subtype-=  (L , U)  ×₆-is-prop
                                      (being-inhabited-is-prop L)
                                      (being-upper-open-is-prop L)
                                      (being-inhabited-is-prop U)
                                      (being-lower-open-is-prop U)
                                      (being-ordered-is-prop L U)
                                      (being-located-is-prop L U))
             refl))
\end{code}

Sometimes a disjointness condition rather than the order condition is
used in the definition of Dedekind reals.

\begin{code}

disjoint-criterion : (L U : 𝓟 )
                    are-ordered L U
                    are-disjoint L U
disjoint-criterion L U o p (p-in-L , p-in-U) = <-ℚ-ℚ-irrefl p (o p p p-in-L p-in-U)

\end{code}

From now on we assume the properties of ℚ and its order alluded above,
and a few more:

\begin{code}

module _ (ℚ-density         : (p r : )  p < r  Σ q   , (p < q) × (q < r))
         (ℚ-transitivity    : (p q r : )  p < q  q < r  p < r)
         (ℚ-order-criterion : (p q : )  q  p  p  q  p < q)
         (ℚ-cotransitivity  : (p q r : )  p < r  (p < q)  (q < r))
         (ℚ-tightness       : (p q : )  q  p  p  q  p  q)
         (ℚ-is-lower-open   : (q : )   p   , (p < q))
         (ℚ-is-upper-open   : (p : )   q   , (p < q))
         (𝟎 ½ 𝟏             : )
         (𝟎-is-less-than-½  : 𝟎 < ½)
         (½-is-less-than-𝟏  : ½ < 𝟏)
       where

 𝟎-is-less-than-𝟏 : 𝟎 < 𝟏
 𝟎-is-less-than-𝟏 = ℚ-transitivity 𝟎 ½ 𝟏 𝟎-is-less-than-½ ½-is-less-than-𝟏

 instance
  order-ℚ-ℚ : Order  
  _≤_ {{order-ℚ-ℚ}} p q = (r : )  r < p  r < q

 ℚ-≤-antisym : (p q : )  p  q  q  p  p  q
 ℚ-≤-antisym p q i j = ℚ-tightness p q    <-ℚ-ℚ-irrefl q (i q ))
                                          <-ℚ-ℚ-irrefl p (j p ))

 <-or-=-gives-≤-on-ℚ : (p q : )  (p < q) + (p  q)  p  q
 <-or-=-gives-≤-on-ℚ p q (inl )    r m = ℚ-transitivity r p q m 
 <-or-=-gives-≤-on-ℚ p q (inr refl) r  = 

 ℚ-trichotomy = (p q : )  (p < q) + (p  q) + (p > q)

 ≤-on-ℚ-gives-=-or-< : ℚ-trichotomy
                      (p q : )  p  q  (p < q) + (p  q)
 ≤-on-ℚ-gives-=-or-< τ p q  = γ (τ p q)
  where
   I : q  p
   I m = <-ℚ-ℚ-irrefl q ( q m)

   γ : (p < q) + (p  q) + (p > q)  (p < q) + (p  q)
   γ (inl i)       = inl i
   γ (inr (inl e)) = inr e
   γ (inr (inr j)) = 𝟘-elim (I j)

 ordered-criterion : (L U : 𝓟 )
                    is-lower L
                    are-disjoint L U
                    are-ordered L U
 ordered-criterion L U L-lower LU-disjoint p q p-in-L q-in-U = γ
  where
   I : p  U
   I p-in-U = LU-disjoint p (p-in-L , p-in-U)

   II : p  q
   II refl = I q-in-U

   III : q  p
   III  = LU-disjoint q (L-lower p p-in-L q  , q-in-U)

   γ : p < q
   γ = ℚ-order-criterion p q III II

\end{code}

The following alternative definition of the Dedekind reals is often
found in the literature:

\begin{code}

 NB₃ :   (Σ (L , U)  𝓟  × 𝓟 
                 , is-inhabited L × is-lower L × is-upper-open L
                 × is-inhabited U × is-upper U × is-lower-open U
                 × are-disjoint L U × are-located L U)

 NB₃ = qinveq
         ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l)
           ((L , U) , Li , Ll , Lo , Ui , Uu , Uo , disjoint-criterion L U o , l))

        ((λ ((L , U) , Li , Ll , Lo , Ui , Uu , Uo , d , l)
           ((L , Li , Ll , Lo) ,
             (U , Ui , Uu , Uo) ,
             ordered-criterion L U Ll d , l)) ,

          ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l)
           to-subtype-= being-dedekind-is-prop
             (to-subtype-= being-lower-real-is-prop
               refl)) ,

          ((L , U) , Li , Lo , Ui , Uo , o , l)
           to-subtype-=  (L , U)  ×₈-is-prop
                                       (being-inhabited-is-prop L)
                                       (being-lower-is-prop L)
                                       (being-upper-open-is-prop L)
                                       (being-inhabited-is-prop U)
                                       (being-upper-is-prop U)
                                       (being-lower-open-is-prop U)
                                       (being-disjoint-is-prop fe L U)
                                       (being-located-is-prop L U))
            refl))

\end{code}

We now consider an alternative definition of the Dedekind reals
offered by Troelstra.

\begin{code}

 is-bounded-above : 𝓟   𝓤 ̇
 is-bounded-above L =  s   , s  L

 is-located : 𝓟   𝓤 ̇
 is-located L = ((r s : )  r < s  r  L  s  L)

 is-troelstra : ℝᴸ  𝓤 ̇
 is-troelstra (L , _) = is-bounded-above L × is-located L

 being-bounded-above-is-prop : (L : 𝓟 )  is-prop (is-bounded-above L)
 being-bounded-above-is-prop L = ∃-is-prop

 being-troelstra-located-is-prop : (L : 𝓟 )  is-prop (is-located L)
 being-troelstra-located-is-prop L = Π₃-is-prop fe  _ _ _  ∨-is-prop)

 being-troelstra-is-prop : (l : ℝᴸ)  is-prop (is-troelstra l)
 being-troelstra-is-prop (L , _) = ×-is-prop
                                    (being-bounded-above-is-prop L)
                                    (being-troelstra-located-is-prop L)
\end{code}

The Dedekind and Troelstra conditions are equivalent:

\begin{code}

 dedekind-gives-troelstra : (l : ℝᴸ)  is-dedekind l  is-troelstra l
 dedekind-gives-troelstra l@(L , _ , _ , _)
                           ((U , U-inhabited , _ , _) , LU-ordered , LU-located) = γ
  where
   bounded : ( s   , s  L)
   bounded = ∥∥-functor f U-inhabited
    where
     f : (Σ q   , q  U)  Σ q   , q  L
     f (q , q-in-U) = q ,  q-in-L  <-ℚ-ℚ-irrefl q (c q-in-L))
      where
       c : q  L  q < q
       c q-in-L = LU-ordered q q q-in-L q-in-U

   located : (r s : )  r < s  r  L  s  L
   located r s  = ∥∥-functor f (LU-located r s )
    where
     f : (r  L) + (s  U)  (r  L) + (s  L)
     f (inl r-in-L) = inl r-in-L
     f (inr r-in-L) = inr  s-in-L  <-ℚ-ℚ-irrefl s (d s-in-L))
      where
       d : s  L  s < s
       d s-in-L = LU-ordered s s s-in-L r-in-L

   γ : is-troelstra l
   γ = bounded , located

\end{code}

A lower Dedekind real may or may not have an upper section. If it
does, it is given by the following candidate.

\begin{code}

 candidate-upper-section : 𝓟   𝓟 
 candidate-upper-section L = λ q  ( p   , (p < q) × (p  L)) , ∃-is-prop

 candidate-upper-section-is-lower-open : (L : 𝓟 )
                                        is-lower-open (candidate-upper-section L)
 candidate-upper-section-is-lower-open L q q-in-U = γ
  where
   f : (Σ p   , (p < q) × (p  L))   p'   , (p' < q) × ( p   , (p < p') × (p  L))
   f (p , i , p-not-in-L) = g (ℚ-density p q i)
    where
     g : (Σ p'   , (p < p') × (p' < q))
          p'   , (p' < q) × ( p   , (p < p') × (p  L))
     g (p' , j , k) =  p' , k ,  p , j , p-not-in-L  

   γ :  q'   , ((q' < q) × (q'  candidate-upper-section L))
   γ = ∥∥-rec ∃-is-prop f q-in-U

 candidate-upper-section-is-ordered : (L : 𝓟 )
                                     is-lower L
                                     is-located L
                                     are-ordered L (candidate-upper-section L)
 candidate-upper-section-is-ordered L L-lower located p q p-in-L q-in-U = γ
    where
     f : (Σ r   , (r < q) × (r  L))  p < q
     f (r , i , r-not-in-L) = ∥∥-rec (<-ℚ-ℚ-is-prop-valued p q) g (located r q i)
      where
       g : (r  L) + (q  L)  p < q
       g (inl r-in-L)     = 𝟘-elim (r-not-in-L r-in-L)
       g (inr q-not-in-L) = ℚ-order-criterion p q II I
        where
         I : p  q
         I refl = q-not-in-L p-in-L

         II : q  p
         II  = q-not-in-L (L-lower p p-in-L q )

     γ : p < q
     γ = ∥∥-rec (<-ℚ-ℚ-is-prop-valued p q) f q-in-U

 candidate-upper-section-is-located : (L : 𝓟 )
                                     is-located L
                                     are-located L (candidate-upper-section L)
 candidate-upper-section-is-located L located p q  = ∥∥-rec ∨-is-prop II I
    where
     I :  p'   , (p < p') × (p' < q)
     I =  ℚ-density p q  

     II : (Σ p'   , (p < p') × (p' < q))  p  L  q  candidate-upper-section L
     II (p' , i , j) = ∥∥-rec ∨-is-prop IV III
      where
       III : p  L  p'  L
       III = located p p' i

       IV : (p  L) + (p'  L)  p  L  q  candidate-upper-section L
       IV (inl p-in-L)      =  inl p-in-L 
       IV (inr p'-not-in-L) =  inr  (p' , j , p'-not-in-L)  

 candidate-upper-section-is-inhabited : (L : 𝓟 )
                                       is-bounded-above L
                                       is-inhabited (candidate-upper-section L)
 candidate-upper-section-is-inhabited L bounded =  γ
    where
     f : (Σ s   , s  L)  is-inhabited (candidate-upper-section L)
     f (s , ν) = ∥∥-functor g (ℚ-is-upper-open s)
      where
       g : (Σ p   , s < p)  Σ p   , p  candidate-upper-section L
       g (p , i) = p ,  s , i , ν 

     γ : is-inhabited (candidate-upper-section L)
     γ = ∥∥-rec (being-inhabited-is-prop (candidate-upper-section L)) f bounded

 candidate-upper-section-is-upper : (L : 𝓟 )
                                   is-lower L
                                   is-located L
                                   is-upper (candidate-upper-section L)
 candidate-upper-section-is-upper L lower located p p-in-U q  = γ
  where
   γ :  q'   , (q' < q) × (q'  L)
   γ =  p ,
         ,
         p-in-L  <-ℚ-ℚ-irrefl p
                     (candidate-upper-section-is-ordered
                       L lower located p p p-in-L p-in-U)) 
\end{code}

The candidate upper section is the unique candidate in the following
sense:

\begin{code}

 unique-candidate : (L U : 𝓟 )
                   is-dedekind-section (L , U)
                   U  candidate-upper-section L
 unique-candidate L U (Li , Ll , Lo , Ui , Uu , Uo , ordered , located) = γ
  where
   l : ℝᴸ
   l = (L , Li , Ll , Lo)

   u : ℝᵁ
   u = (U , Ui , Uu , Uo)

   I : is-dedekind l
   I = u , ordered , located

   II : is-located L
   II = pr₂ (dedekind-gives-troelstra l I)

   III : (candidate-upper-section L) is-an-upper-section-of L
   III = candidate-upper-section-is-lower-open L ,
         candidate-upper-section-is-ordered L Ll II ,
         candidate-upper-section-is-located L II

   γ : U  candidate-upper-section L
   γ = any-two-upper-sections-are-equal L U
        (candidate-upper-section L)
        (Uo , ordered , located)
        III

\end{code}

And, as promised, the Troelstra condition implies the Dedekind condition:

\begin{code}

 troelstra-gives-dedekind : (l : ℝᴸ)  is-troelstra l  is-dedekind l
 troelstra-gives-dedekind l@(L , L-inhabited , L-lower , L-upper-open)
                            (bounded , located) = γ
  where
   γ : is-dedekind l
   γ = ((candidate-upper-section L ,
         (candidate-upper-section-is-inhabited L bounded ,
          candidate-upper-section-is-upper L L-lower located ,
          candidate-upper-section-is-lower-open L)) ,
        candidate-upper-section-is-ordered L L-lower located ,
        candidate-upper-section-is-located L located)

\end{code}

The set of Troelstra reals, again as a subset of the lower reals:

\begin{code}

 ℝᵀ : 𝓤⁺ ̇
 ℝᵀ = Σ l  ℝᴸ , is-troelstra l

\end{code}

Question. Can we prove that ℝ = ℝᵀ with propositional and functional
extensionality, without univalence? The problem is that the Dedekind
condition and the troelstra condition have different universe levels,
and hence propositional extensionality is not applicable to show that
they are equal, as their equality doesn't even type check. Would
universe lifting help? I haven't thought about this.

\begin{code}

 dedekind-agrees-with-troelstra :   ℝᵀ
 dedekind-agrees-with-troelstra = γ
  where
   f :   ℝᵀ
   f (l , h) = l , dedekind-gives-troelstra l h

   g : ℝᵀ  
   g (l , k) = l , troelstra-gives-dedekind l k

   γ :   ℝᵀ
   γ = qinveq f (g ,
                 (l , h)  to-subtype-= being-dedekind-is-prop refl) ,
                 (l , k)  to-subtype-= being-troelstra-is-prop refl))
\end{code}

We now consider consequences of excluded middle. Notice that if A is a
proposition, then so is A + ¬ A, and thus A + ¬ A is equivalent to A ∨ ¬ A.

\begin{code}

 LEM = (A : 𝓤 ̇ )  is-prop A  A + ¬ A

 LEM-gives-locatedness : LEM  ((L , _) : ℝᴸ)  is-located L
 LEM-gives-locatedness
   lem l@(L , L-inhabited , L-lower , L-upper-open) r s  = γ δ
  where
   δ : (s  L) + (s  L)
   δ = lem (s  L) (∈-is-prop L s)

   γ : type-of δ  (r  L)  (s  L)
   γ (inl s-in-L)     =  inl (L-lower s s-in-L r ) 
   γ (inr s-not-in-L) =  inr s-not-in-L 

\end{code}

The bounded lower reals:

\begin{code}

 ℝᴮᴸ : 𝓤⁺ ̇
 ℝᴮᴸ = Σ (L , _)  ℝᴸ , is-bounded-above L

\end{code}

The boundedness condition only excludes a point at infinity in the
lower reals:

\begin{code}

 infty : 𝓟 
 infty = λ q  

 infty-is-lower-real : is-lower-real infty
 infty-is-lower-real =  𝟎 ,   ,
                    _ _ _ _  ) ,
                    p   ∥∥-rec
                              ∃-is-prop
                               (q , i)   q , i ,  )
                              (ℚ-is-upper-open p))

 infty-is-not-bounded-above : ¬ is-bounded-above infty
 infty-is-not-bounded-above bounded = ∥∥-rec
                                        𝟘-is-prop
                                         (q , q-not-in-infty)  q-not-in-infty )
                                        bounded
\end{code}

In connection with a discussion above, notice that we don't need
univalence for the following, which says that the Troelstra reals
agree with the bounded lower reals if we assume excluded middle:

\begin{code}

 ℝᵀ-and-ℝᴮᴸ-agree-under-LEM : LEM  ℝᵀ  ℝᴮᴸ
 ℝᵀ-and-ℝᴮᴸ-agree-under-LEM lem = ap Σ γ
  where
   δ : is-troelstra  λ (L , _)  is-bounded-above L
   δ l@(L , _) = pe (being-troelstra-is-prop l)
                    (being-bounded-above-is-prop L)
                    pr₁
                     β  β , LEM-gives-locatedness lem l)

   γ : is-troelstra   (L , _)  is-bounded-above L)
   γ = dfunext fe δ

\end{code}

Therefore, under excluded middle, the Dedekind reals agree with the
bounded lower reals:

\begin{code}

 ℝ-and-ℝᴮᴸ-agree-under-LEM : LEM    ℝᴮᴸ
 ℝ-and-ℝᴮᴸ-agree-under-LEM lem = transport ( ≃_)
                                  (ℝᵀ-and-ℝᴮᴸ-agree-under-LEM lem)
                                  (dedekind-agrees-with-troelstra)
\end{code}

It follows that bounded lower reals are Dedekind under excluded middle.

\begin{code}

 LEM-gives-all-bounded-lower-reals-are-dedekind : LEM
                                                 ((l , _) : ℝᴮᴸ)  is-dedekind l
 LEM-gives-all-bounded-lower-reals-are-dedekind lem (l , bounded) = γ
  where
   γ : is-dedekind l
   γ = troelstra-gives-dedekind l (bounded , LEM-gives-locatedness lem l)

\end{code}

And the converse also holds. We use a method of proof suggested
independently by Steve Vickers and Toby Bartels.

\begin{code}

 all-bounded-lower-reals-are-dedekind-gives-LEM : (((l , _) : ℝᴮᴸ)  is-dedekind l)
                                                 LEM
 all-bounded-lower-reals-are-dedekind-gives-LEM α A A-is-prop = γ
  where
   L : 𝓟 
   L p = ((p < 𝟎)  (A × (p < 𝟏))) , ∨-is-prop

   L-inhabited : is-inhabited L
   L-inhabited = ∥∥-functor h (ℚ-is-lower-open 𝟎)
    where
     h : (Σ p   , p < 𝟎)  Σ p   , p  L
     h (p , ) = p ,  inl  

   L-lower : is-lower L
   L-lower p p-in-L p' j = ∥∥-functor h p-in-L
    where
     h : (p < 𝟎) + (A × (p < 𝟏))  (p' < 𝟎) + (A × (p' < 𝟏))
     h (inl )       = inl (ℚ-transitivity p' p 𝟎 j )
     h (inr (a , )) = inr (a , ℚ-transitivity p' p 𝟏 j )

   L-upper-open : is-upper-open L
   L-upper-open p p-in-L = ∥∥-rec ∃-is-prop h p-in-L
    where
     h : (p < 𝟎) + (A × (p < 𝟏))   p'   , (p < p') × (p'  L)
     h (inl ) = k (ℚ-density p 𝟎 )
      where
       k : (Σ p'   , (p < p') × (p' < 𝟎))   p'   , (p < p') × (p'  L)
       k (p' , i , j) =  p' , i ,  inl j  
     h (inr (a , )) = k (ℚ-density p 𝟏 )
      where
       k : (Σ p'   , (p < p') × (p' < 𝟏))   p'   , (p < p') × p'  L
       k (p' , i , j) =  p' , i ,  inr (a , j)  

   l : ℝᴸ
   l = (L , L-inhabited , L-lower , L-upper-open)

   l-dedekind-gives-A-decidable : is-dedekind l  A + ¬ A
   l-dedekind-gives-A-decidable ((U , _ , _) , LU-ordered , LU-located) = δ
    where
     δ : A + ¬ A
     δ = ∥∥-rec
           (decidability-of-prop-is-prop fe A-is-prop)
           h
           (LU-located 𝟎 ½ 𝟎-is-less-than-½)
      where
       h : (𝟎  L) + (½  U)  A + ¬ A
       h (inl 𝟘-in-L) = inl (∥∥-rec A-is-prop k 𝟘-in-L)
        where
         k : (𝟎 < 𝟎) + (A × (𝟎 < 𝟏))  A
         k (inl )       = 𝟘-elim (<-ℚ-ℚ-irrefl 𝟎 )
         k (inr (a , _)) = a
       h (inr ½-in-U) = inr ν
        where
         ν : ¬ A
         ν a = disjoint-criterion L U LU-ordered ½ (½-in-L , ½-in-U)
          where
           ½-in-L : ½  L
           ½-in-L =  inr (a , ½-is-less-than-𝟏) 

   L-bounded-above : is-bounded-above L
   L-bounded-above =  𝟏 ,  𝟏-in-L  ∥∥-rec 𝟘-is-prop h 𝟏-in-L) 
    where
     h : ¬((𝟏 < 𝟎) + (A × (𝟏 < 𝟏)))
     h (inl )       = <-ℚ-ℚ-irrefl 𝟎 (ℚ-transitivity 𝟎 𝟏 𝟎 𝟎-is-less-than-𝟏 )
     h (inr (_ , )) = <-ℚ-ℚ-irrefl 𝟏 

   b : ℝᴮᴸ
   b = (l , L-bounded-above)

   γ : A + ¬ A
   γ = l-dedekind-gives-A-decidable (α b)

\end{code}

The canonical embedding of the rationals into the reals:

\begin{code}

 ℚ-to-ℝᴸ :   ℝᴸ
 ℚ-to-ℝᴸ q =  p  (p < q) , <-ℚ-ℚ-is-prop-valued p q) ,
             ℚ-is-lower-open q ,
              p i r j  ℚ-transitivity r p q j i) ,
              p i   ℚ-density p q i )

 ℚ-to-ℝᵁ :   ℝᵁ
 ℚ-to-ℝᵁ q =  p  (q < p) , <-ℚ-ℚ-is-prop-valued q p) ,
             ℚ-is-upper-open q ,
              p i r j  ℚ-transitivity q p r i j) ,
              p i   (r , j , k)  r , k , j) (ℚ-density q p i))

 ℚ-to-ℝᵁ-is-upper-section-of-ℚ-to-ℝᴸ : (q : )  (ℚ-to-ℝᵁ q) is-upper-section-of (ℚ-to-ℝᴸ q)
 ℚ-to-ℝᵁ-is-upper-section-of-ℚ-to-ℝᴸ q =  p  ℚ-transitivity p q) ,
                                          p  ℚ-cotransitivity p q)

 ℚ-to-ℝᴸ-is-dedekind : (q : )  is-dedekind (ℚ-to-ℝᴸ q)
 ℚ-to-ℝᴸ-is-dedekind q = ℚ-to-ℝᵁ q , ℚ-to-ℝᵁ-is-upper-section-of-ℚ-to-ℝᴸ q

 ℚ-to-ℝ :   
 ℚ-to-ℝ q = ℚ-to-ℝᴸ q , ℚ-to-ℝᴸ-is-dedekind q

 ℚ-to-ℝᴸ-is-embedding : is-embedding ℚ-to-ℝᴸ
 ℚ-to-ℝᴸ-is-embedding l (p , a) (q , b) = γ
  where
   I = ℚ-to-ℝᴸ p =⟨ a 
       l         =⟨ b ⁻¹ 
       ℚ-to-ℝᴸ q 

   II :  r  (r < p) , _)   r  (r < q) , _)
   II = ap pr₁ I

   III :  r  r < p)   r  r < q)
   III = ap  f r  pr₁ (f r)) II

   A : (r : )  r < p  r < q
   A r = idtofun (r < p) (r < q) (happly III r)

   B : (r : )  r < q  r < p
   B r = idtofun (r < q) (r < p) (happly (III ⁻¹) r)

   V : p  q
   V =  ℚ-≤-antisym p q A B

   γ : (p , a)  (q , b)
   γ = to-subtype-=  _  ℝᴸ-is-set) V

 instance
  canonical-map-ℚ-to-ℝ : Canonical-Map  
  ι {{canonical-map-ℚ-to-ℝ}} = ℚ-to-ℝ

 ℚ-to-ℝ-is-embedding : is-embedding (canonical-map  )
 ℚ-to-ℝ-is-embedding = factor-is-embedding
                        ℚ-to-ℝ
                        ℝ-to-ℝᴸ
                        ℚ-to-ℝᴸ-is-embedding
                        ℝ-to-ℝᴸ-is-embedding
  where
   notice-that : ℝ-to-ℝᴸ  ℚ-to-ℝ  ℚ-to-ℝᴸ
   notice-that = refl

 is-rational :   𝓤⁺ ̇
 is-rational x = Σ q   , ι q  x

 being-rational-is-prop : (x : )  is-prop (is-rational x)
 being-rational-is-prop = ℚ-to-ℝ-is-embedding

\end{code}

We could also define

 instance
  canonical-map-ℚ-to-ℝᴸ : Canonical-Map ℚ ℝᴸ
  ι {{canonical-map-ℚ-to-ℝᴸ}} = ℚ-to-ℝᴸ

  canonical-map-ℚ-to-ℝᵁ : Canonical-Map ℚ ℝᵁ
  ι {{canonical-map-ℚ-to-ℝᵁ}} = ℚ-to-ℝᵁ

but this would give us trouble with unsolved constraints.

We now consider order and apartness on real numbers.

\begin{code}

 lowercut :   𝓟 
 lowercut ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = L

 uppercut :   𝓟 
 uppercut ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = U

 instance
  strict-order-ℚ-ℝ : Strict-Order  
  _<_ {{strict-order-ℚ-ℝ}} p x = p  lowercut x

  strict-order-ℝ-ℚ : Strict-Order  
  _<_ {{strict-order-ℝ-ℚ}} x q = q  uppercut x

  strict-order-ℝ-ℝ : Strict-Order  
  _<_ {{strict-order-ℝ-ℝ}} x y =  q   , (x < q) × (q < y)

 <-ℚ-ℝ-is-prop-valued : (p : ) (x : )  is-prop (p < x)
 <-ℚ-ℝ-is-prop-valued p x = ∈-is-prop (lowercut x) p

 <-ℝ-ℚ-is-prop-valued : (x : ) (q : )  is-prop (x < q)
 <-ℝ-ℚ-is-prop-valued x q = ∈-is-prop (uppercut x) q

 <-ℝ-ℝ-is-prop-valued : (x y : )  is-prop (x < y)
 <-ℝ-ℝ-is-prop-valued x y = ∃-is-prop

\end{code}

We now name all the remaining projections out of ℝ. We first give
their types and then define them, for the sake of clarity.

\begin{code}

 lowercut-is-inhabited  : (x : )   p   , p < x
 uppercut-is-inhabited  : (x : )   q   , x < q
 lowercut-is-lower      : (x : ) (q : )  q < x  (p : )  p < q  p < x
 uppercut-is-upper      : (x : ) (p : )  x < p  (q : )  p < q  x < q
 lowercut-is-upper-open : (x : ) (p : )  p < x   q   , (p < q) × (q < x)
 uppercut-is-lower-open : (x : ) (q : )  x < q   p   , (p < q) × (x < p)
 cuts-are-ordered       : (x : ) (p q : )  p < x  x < q  p < q
 cuts-are-located       : (x : ) (p q : )  p < q  (p < x)  (x < q)
 cuts-are-disjoint      : (x : ) (p : )  p < x  x  p
 lowercut-is-bounded    : (x : )   p   , p  x
 lowercut-is-located    : (x : ) (p q : )  p < q  (p < x)  (q  x)

 lowercut-is-inhabited  ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Li
 uppercut-is-inhabited  ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Ui
 lowercut-is-lower      ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Ll
 uppercut-is-upper      ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Uu
 lowercut-is-upper-open ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Lo
 uppercut-is-lower-open ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = Uo
 cuts-are-ordered       ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = o
 cuts-are-located       ((L , Li , Ll , Lo) , (U , Ui , Uu , Uo) , o , l) = l

 cuts-are-disjoint x p l m = disjoint-criterion
                              (lowercut x) (uppercut x)
                              (cuts-are-ordered x)
                              p
                              (l , m)

 lowercut-is-bounded (l , δ) = pr₁ (dedekind-gives-troelstra l δ)
 lowercut-is-located (l , δ) = pr₂ (dedekind-gives-troelstra l δ)

\end{code}

The lower and upper cut projections are left-cancellable (and hence
embeddings, as the types under consideration are all sets).

\begin{code}

 lowercut-lc : (x y : )  lowercut x  lowercut y  x  y
 lowercut-lc x y e = to-subtype-= being-dedekind-is-prop
                       (to-subtype-= being-lower-real-is-prop e)

 uppercut-lc : (x y : )  uppercut x  uppercut y  x  y
 uppercut-lc x y p = lowercut-lc x y III
  where
   I : lowercut x  lowercut y
   I = order-lemma-converse (lowercut x) (uppercut x) (lowercut y) (uppercut y)
        (lowercut-is-upper-open x) (cuts-are-located y) (cuts-are-ordered x)
        (transport (_⊆ uppercut x) p (⊆-refl (uppercut x)))

   II : lowercut x  lowercut y
   II = order-lemma-converse (lowercut y) (uppercut y) (lowercut x) (uppercut x)
         (lowercut-is-upper-open y) (cuts-are-located x) (cuts-are-ordered y)
         (transport (uppercut x ⊆_) p (⊆-refl (uppercut x)))

   III : lowercut x  lowercut y
   III = subset-extensionality'' pe fe fe I II

\end{code}

We now develop the basic properties of the _<_ order.

\begin{code}

 <-irrefl : (x : )  x  x
 <-irrefl x  = γ
  where
   δ : ¬ (Σ q   , ((x < q) × (q < x)))
   δ (q , a , b) = cuts-are-disjoint x q b a

   γ : 𝟘
   γ = ∥∥-rec 𝟘-is-prop δ 

 <-ℝ-ℝ-trans : (x y z : )  x < y  y < z  x < z
 <-ℝ-ℝ-trans x y z i j = ∥∥-functor₂ f i j
  where
   f : (Σ p   , (x < p) × (p < y))
      (Σ q   , (y < q) × (q < z))
       Σ r   , (x < r) × (r < z)
   f (p , i , j) (q , k , l) = p , i , v
    where
     u : p < q
     u = cuts-are-ordered y p q j k

     v : p < z
     v = lowercut-is-lower z q l p u

 <-cotrans-ℚ : (p q : )  p < q  (z : )  (p < z)  (z < q)
 <-cotrans-ℚ p q  z = cuts-are-located z p q 

 <-cotrans : (x y : )  x < y  (z : )  (x < z)  (z < y)
 <-cotrans x y  z = V
  where
   I : (Σ q   , ((x < q) × (q < y)))  (x < z)  (z < y)
   I (q , a , b) = ∥∥-rec ∨-is-prop III II
    where
     II :  p   , (p < q) × (x < p)
     II = uppercut-is-lower-open x q a

     III : (Σ p   , (p < q) × (x < p))  (x < z)  (z < y)
     III (p , c , d) = ∥∥-functor IV (<-cotrans-ℚ p q c z)
       where
        IV : (p < z) + (z < q)  (x < z) + (z < y)
        IV (inl ) = inl  p , d ,  
        IV (inr ) = inr  q ,  , b 

   V : (x < z)  (z < y)
   V = ∥∥-rec ∨-is-prop I 

\end{code}

There are a number of equivalent ways to define the _≤_ order on ℝ. We
give four for now, and three more later.

\begin{code}

 _≤₀_ _≤₁_ _≤₂_ _≤₃_ :     𝓤 ̇
 x ≤₀ y  = (p : )  p < x  p < y
 x ≤₁ y  = (q : )  y < q  x < q
 x ≤₂ y  = y  x
 x ≤₃ y  = (p q : )  p < x  y < q  p < q

\end{code}

Definition (3) has the advantage that it is applicable when x is a
lower real and y is an upper real. See the interval domain below. But
we adopted the first definition for reals before we realized that. It
doesn't matter much, because we can switch between all the definitions
in the case of the reals.

\begin{code}

 ≤₀-is-prop-valued : (x y : )  is-prop (x ≤₀ y)
 ≤₁-is-prop-valued : (x y : )  is-prop (x ≤₁ y)
 ≤₂-is-prop-valued : (x y : )  is-prop (x ≤₂ y)
 ≤₃-is-prop-valued : (x y : )  is-prop (x ≤₃ y)

 ≤₀-is-prop-valued x y = Π₂-is-prop fe  _ _  <-ℚ-ℝ-is-prop-valued _ y)
 ≤₁-is-prop-valued x y = Π₂-is-prop fe  _ _  <-ℝ-ℚ-is-prop-valued x _)
 ≤₂-is-prop-valued x y = negations-are-props fe
 ≤₃-is-prop-valued x y = Π₄-is-prop fe  _ _ _ _  <-ℚ-ℚ-is-prop-valued _ _)

 instance
  order-ℝ-ℝ : Order  
  _≤_ {{order-ℝ-ℝ}} = _≤₀_

 ≤-gives-≤₁ : (x y : )  x  y  x ≤₁ y
 ≤-gives-≤₁ x y  = order-lemma
                     (lowercut x) (uppercut x)
                     (lowercut y) (uppercut y)
                     (uppercut-is-lower-open y)
                     (cuts-are-located x)
                     (cuts-are-ordered y)
                     

 ≤₁-gives-≤ : (x y : )  x ≤₁ y  x  y
 ≤₁-gives-≤ x y  = order-lemma-converse
                     (lowercut x) (uppercut x)
                     (lowercut y) (uppercut y)
                     (lowercut-is-upper-open x)
                     (cuts-are-located y)
                     (cuts-are-ordered x)
                     

 ≤₂-gives-≤ : (x y : )  x ≤₂ y  x  y
 ≤₂-gives-≤ x y ν q  = VI
  where
   I : (p : )  p < x  y  p
   I p m l = ν  p , l , m 

   II :  p   , (q < p) × (p < x)
   II = lowercut-is-upper-open x q 

   III : (Σ p   , (q < p) × (p < x))  q < y
   III (p , i , j) = ∥∥-rec (<-ℚ-ℝ-is-prop-valued q y) V IV
    where
     IV : (q < y)  (y < p)
     IV = <-cotrans-ℚ q p i y

     V : (q < y) + (y < p)  q < y
     V (inl k) = k
     V (inr l) = 𝟘-elim (I p j l)

   VI : q < y
   VI = ∥∥-rec (<-ℚ-ℝ-is-prop-valued q y) III II

 ≤-gives-≤₂ : (x y : )  x  y  x ≤₂ y
 ≤-gives-≤₂ x y  i = II
  where
   I : ¬ (Σ p   , (y < p) × (p < x))
   I (p , j , k) = cuts-are-disjoint y p ( p k) j

   II : 𝟘
   II = ∥∥-rec 𝟘-is-prop I i

 ≤₃-gives-≤ : (x y : )  x ≤₃ y  x  y
 ≤₃-gives-≤ x y l = III
  where
   I : ¬ (Σ p   , (y < p) × (p < x))
   I (p , i , j) = <-ℚ-ℚ-irrefl p (l p p j i)

   II : y  x
   II m = ∥∥-rec 𝟘-is-prop I m

   III : x  y
   III = ≤₂-gives-≤ x y II

 ≤-gives-≤₃ : (x y : )  x  y  x ≤₃ y
 ≤-gives-≤₃ x y l p q i j = II
  where
   I : p < y
   I = l p i

   II : p < q
   II = cuts-are-ordered y p q I j

 ≤-ℝ-refl : (x : )  x  x
 ≤-ℝ-refl x q  = 

 ≤-ℝ-ℝ-trans : (x y z : )  x  y  y  z  x  z
 ≤-ℝ-ℝ-trans x y z l m p i = m p (l p i)

 ≤-ℝ-ℝ-antisym : (x y : )  x  y  y  x  x  y
 ≤-ℝ-ℝ-antisym x y l m = lowercut-lc x y γ
  where
   γ : lowercut x  lowercut y
   γ = subset-extensionality'' pe fe fe l m

\end{code}

The type ℝ is large, in the sense that it lives in 𝓤⁺ rather than 𝓤,
but it is locally small, in the sense that each identity type x = y
with x,y:ℝ, which also lives in 𝓤⁺, has copy in the universe 𝓤, namely
the type (x ≤ y) × (y ≤ x).

\begin{code}

 ℝ-is-locally-small : is-locally-small 
 ℝ-is-locally-small x y = γ
  where
   f : (x  y) × (y  x)  x  y
   f = uncurry (≤-ℝ-ℝ-antisym x y)

   g : x  y  (x  y) × (y  x)
   g refl = ≤-ℝ-refl x , ≤-ℝ-refl x

   e : ((x  y) × (y  x))  (x  y)
   e = qinveq
        f
        (g ,
          a  ×-is-prop (≤₀-is-prop-valued x y) (≤₀-is-prop-valued y x) (g (f a)) a) ,
          b  ℝ-is-set (f (g b)) b))

   γ : (x  y) is 𝓤 small
   γ = ((x  y) × (y  x)) , e

\end{code}

Relationship between the orders of ℚ and ℝ:

\begin{code}

 ℚ-to-ℝ-preserves-< : (p q : )  p < q  ι p < ι q
 ℚ-to-ℝ-preserves-< p q l =  ℚ-density p q l 

 ℚ-to-ℝ-reflects-< : (p q : )  ι p < ι q  p < q
 ℚ-to-ℝ-reflects-< p q = ∥∥-rec
                           (<-ℚ-ℚ-is-prop-valued p q)
                            (r , i , j)  ℚ-transitivity p r q i j)

 ≤-on-ℚ-agrees-with-≤-on-ℝ : (p q : )  (p  q)  (ι p  ι q)
 ≤-on-ℚ-agrees-with-≤-on-ℝ p q = refl

 ≤-on-ℚ-is-prop-valued : (p q : )  is-prop (ι p  ι q)
 ≤-on-ℚ-is-prop-valued p q = ≤₀-is-prop-valued (ι p) (ι q)

 ℚ-to-ℝ-preserves-≤ : (p q : )  p  q  ι p  ι q
 ℚ-to-ℝ-preserves-≤ p q = id

 ℚ-to-ℝ-reflects-≤ : (p q : )  ι p  ι q  p  q
 ℚ-to-ℝ-reflects-≤ p q = id

 ℚ-to-ℝ-left : (p : ) (x : )  p < x  ι p < x
 ℚ-to-ℝ-left p x = lowercut-is-upper-open x p

 ℚ-to-ℝ-left-converse : (p : ) (x : )  ι p < x  p < x
 ℚ-to-ℝ-left-converse p x = ∥∥-rec
                              (<-ℚ-ℝ-is-prop-valued p x)
                               (q , m , o)  lowercut-is-lower x q o p m)

 ℚ-to-ℝ-right : (x : ) (q : )  x < q  x < ι q
 ℚ-to-ℝ-right x q l = ∥∥-functor
                        (p , m , o)  p , o , m)
                       (uppercut-is-lower-open x q l)

 ℚ-to-ℝ-right-converse : (x : ) (q : )  x < ι q  x < q
 ℚ-to-ℝ-right-converse x q = ∥∥-rec
                               (<-ℝ-ℚ-is-prop-valued x q)
                                (p , m , o)  uppercut-is-upper x p m q o)
\end{code}

The promised three more ways to define _≤_ on ℝ:

\begin{code}

 _≤₀ₐ_ _≤₁ₐ_ _≤₃ₐ_ :     𝓤⁺ ̇
 x ≤₀ₐ y = (z : )  z < x  z < y
 x ≤₁ₐ y = (z : )  y < z  x < z
 x ≤₃ₐ y = (z t : )  z < x  y < t  z < t

 ≤₀ₐ-is-prop-valued : (x y : )  is-prop (x ≤₀ₐ y)
 ≤₁ₐ-is-prop-valued : (x y : )  is-prop (x ≤₁ₐ y)
 ≤₃ₐ-is-prop-valued : (x y : )  is-prop (x ≤₃ₐ y)

 ≤₀ₐ-is-prop-valued x y = Π₂-is-prop fe  z _  <-ℝ-ℝ-is-prop-valued z y)
 ≤₁ₐ-is-prop-valued x y = Π₂-is-prop fe  z _  <-ℝ-ℝ-is-prop-valued x z)
 ≤₃ₐ-is-prop-valued x y = Π₄-is-prop fe  z t _ _  <-ℝ-ℝ-is-prop-valued z t)

 ≤₀-gives-≤₀ₐ : (x y : )  x ≤₀ y  x ≤₀ₐ y
 ≤₀-gives-≤₀ₐ x y l z = ∥∥-functor f
  where
   f : (Σ p   , (z < p) × (p < x))
      (Σ p   , (z < p) × (p < y))
   f (p , u , v) = p , u , l p v

 ≤₀ₐ-gives-≤₀ : (x y : )  x ≤₀ₐ y  x ≤₀ y
 ≤₀ₐ-gives-≤₀ x y l p m = II
  where
   I : ι p < y
   I = l (ι p) (ℚ-to-ℝ-left p x m)

   II : p < y
   II = ℚ-to-ℝ-left-converse p y I

 ≤₁-gives-≤₁ₐ : (x y : )  x ≤₁ y  x ≤₁ₐ y
 ≤₁-gives-≤₁ₐ x y l z = ∥∥-functor f
  where
   f : (Σ p   , (y < p) × (p < z))
      (Σ p   , (x < p) × (p < z))
   f (p , u , v) = p , l p u , v

 ≤₁ₐ-gives-≤₁ : (x y : )  x ≤₁ₐ y  x ≤₁ y
 ≤₁ₐ-gives-≤₁ x y l p m = II
  where
   I : x < ι p
   I = l (ι p) (ℚ-to-ℝ-right y p m)

   II : x < p
   II = ℚ-to-ℝ-right-converse x p I

 ≤₃ₐ-gives-≤₃ : (x y : )  x ≤₃ₐ y  x ≤₃ y
 ≤₃ₐ-gives-≤₃ x y l p q m o = ℚ-to-ℝ-reflects-< p q γ
  where
   γ : ι p < ι q
   γ = l (ι p) (ι q) (ℚ-to-ℝ-left p x m) (ℚ-to-ℝ-right y q o)

 ≤₃-gives-≤₃ₐ : (x y : )  x ≤₃ y  x ≤₃ₐ y
 ≤₃-gives-≤₃ₐ x y l z t m o = ∥∥-functor₂ f m o
  where
   f : (Σ p   , (z < p) × (p < x))
      (Σ q   , (y < q) × (q < t))
      (Σ p   , (z < p) × (p < t))
   f (p , i , j) (q , u , v) = p , i , II
    where
     I : p < q
     I = l p q j u

     II : p < t
     II = lowercut-is-lower t q v p I

\end{code}

Relationship between _<_ and _≤_ on ℝ:

\begin{code}

 <-gives-≤' : (x y : )  x < y  x  y
 <-gives-≤' x y l = ≤₀ₐ-gives-≤₀ x y f
  where
   f : (z : )  z < x  z < y
   f z m = <-ℝ-ℝ-trans z x y m l

 <-≤-trans : (x y z : )  x < y  y  z  x < z
 <-≤-trans x y z l m = ≤₀-gives-≤₀ₐ y z m x l

 ≤-<-ℝ-ℝ-trans : (x y z : )  x  y  y < z  x < z
 ≤-<-ℝ-ℝ-trans x y z l m = ≤₁-gives-≤₁ₐ x y (≤-gives-≤₁ x y l) z m

\end{code}

Apartness of real numbers and its basic properties:

\begin{code}

 _♯_ :     𝓤 ̇
 x  y = (x < y) + (y < x)

 ♯-is-prop-valued : (x y : )  is-prop (x  y)
 ♯-is-prop-valued x y = sum-of-contradictory-props
                          (<-ℝ-ℝ-is-prop-valued x y)
                          (<-ℝ-ℝ-is-prop-valued y x)
                           i j  <-irrefl x (<-ℝ-ℝ-trans x y x i j))

 ♯-irrefl : (x : )  ¬ (x  x)
 ♯-irrefl x (inl ) = <-irrefl x 
 ♯-irrefl x (inr ) = <-irrefl x 

 ♯-gives-≠ : (x y : )  x  y  x  y
 ♯-gives-≠ x x s refl = ♯-irrefl x s

 ♯-sym : (x y : )  x  y  y  x
 ♯-sym x y (inl ) = inr 
 ♯-sym x y (inr ) = inl 

 ♯-cotrans : (x y : )  x  y  (z : )  (x  z)  (y  z)
 ♯-cotrans x y (inl ) z = ∥∥-functor
                             (cases  ( : x < z)  inl (inl ))
                                     ( : z < y)  inr (inr )))
                             (<-cotrans x y  z)
 ♯-cotrans x y (inr ) z = ∥∥-functor
                             (cases  ( : y < z)  inr (inl ))
                                     ( : z < x)  inl (inr )))
                             (<-cotrans y x  z)
 ♯-is-tight : (x y : )  ¬ (x  y)  x  y
 ♯-is-tight x y ν = ≤-ℝ-ℝ-antisym x y III IV
  where
   I : x  y
   I  = ν (inl )

   II : y  x
   II  = ν (inr )

   III : x  y
   III = ≤₂-gives-≤ x y II

   IV : y  x
   IV = ≤₂-gives-≤ y x I

 ℝ-is-¬¬-separated : (x y : )  ¬¬ (x  y)  x  y
 ℝ-is-¬¬-separated x y ϕ = ♯-is-tight x y (c ϕ)
  where
   c : ¬¬ (x  y)  ¬ (x  y)
   c = contrapositive (♯-gives-≠ x y)

 ℝ-order-criterion : (x y : )  x  y  x  y  x < y
 ℝ-order-criterion x y  (inl m) = m
 ℝ-order-criterion x y  (inr m) = 𝟘-elim (≤-gives-≤₂ x y  m)

 is-irrational :   𝓤⁺ ̇
 is-irrational x = ¬ (Σ q   , ι q  x)

 is-strongly-irrational :   𝓤 ̇
 is-strongly-irrational x = (q : )  ι q  x

 being-irrational-is-prop : (x : )  is-prop (is-irrational x)
 being-irrational-is-prop x = negations-are-props fe

 being-strongly-irrational-is-prop : (x : )  is-prop (is-strongly-irrational x)
 being-strongly-irrational-is-prop x = Π-is-prop fe  q  ♯-is-prop-valued (ι q) x)

\end{code}

We now consider the existence of least upper bounds of bounded
families x : 𝐼 → ℝ with 𝐼 inhabited.

A sufficient condition, given by Bishop, is that

  (p q : ℚ) → p < q → (∃ i ꞉ 𝐼 , p < x i)
                    ∨ (Π i ꞉ 𝐼 , x i < q)

We observe that the weaker condition

  (p q : ℚ) → p < q →  (∃ i ꞉ 𝐼 , p < x i)
                    ∨ ¬(∃ i ꞉ 𝐼 , q < x i)

suffices.

If we define (p < x) = (∃ i ꞉ 𝐼 , p < x i), then this weaker sufficient
condition reads

  (p q : ℚ) → p < q → (p < x) ∨ (q ≮ x)

so that we see that it is analogous to Troelstra's locatedness
condition discussed above.

In the following, we write x ≤ y to mean that the real number y is an
upper bound of the family x.

\begin{code}

 module _ {𝐼 : 𝓤 ̇ } where

  private
   F = 𝐼  

  instance
   order-F-ℝ : Order F 
   _≤_ {{order-F-ℝ}} x y = (i : 𝐼)  x i  y

  ≤-F-ℝ-is-prop-valued : (x : F) (y : )
                            is-prop (x  y)
  ≤-F-ℝ-is-prop-valued x y = Π-is-prop fe  i  ≤₀-is-prop-valued (x i) y)

  _has-lub_ : F    𝓤⁺ ̇
  x has-lub y = (x  y) × ((z : )  x  z  y  z)

  _has-a-lub : F  𝓤⁺ ̇
  x has-a-lub = Σ y   , (x has-lub y)

  having-lub-is-prop : (x : F) (y : )
                      is-prop (x has-lub y)
  having-lub-is-prop x y = ×-is-prop
                            (≤-F-ℝ-is-prop-valued x y)
                            (Π₂-is-prop fe  z _  ≤₀-is-prop-valued y z))

  having-a-lub-is-prop : (x : F)  is-prop (x has-a-lub)
  having-a-lub-is-prop x (y , a , b) (y' , a' , b') = γ
   where
    I : y  y'
    I = ≤-ℝ-ℝ-antisym y y' (b y' a') (b' y a)

    γ : (y , a , b)  (y' , a' , b')
    γ = to-subtype-= (having-lub-is-prop x) I

  instance
   strict-order-ℚ-F : Strict-Order  F
   _<_ {{strict-order-ℚ-F}} p x =  i  𝐼 , p < x i

  strict-order-ℚ-F-is-prop : (p : ) (x : F)  is-prop (p < x)
  strict-order-ℚ-F-is-prop p x = ∃-is-prop

  strict-order-ℚ-F-observation : (p : ) (x : F)
                                (p  x)  (x  ι p)
  strict-order-ℚ-F-observation p x = f , g
   where
    f : p  x  x  ι p
    f ν i = I
     where
      I : (q : )  q < x i  q < p
      I q l = ℚ-order-criterion q p II III
       where
        II : p  q
        II m = ν  i , lowercut-is-lower (x i) q l p m 

        III : q  p
        III refl = ν  i , l 

    g : x  ι p  p  x
    g l = ∥∥-rec 𝟘-is-prop I
     where
      I : ¬ (Σ i  𝐼 , p < x i)
      I (i , m) = <-ℚ-ℚ-irrefl p (l i p m)

  is-upper-bounded : F  𝓤⁺ ̇
  is-upper-bounded x =  y   , (x  y)

  is-located-family : F  𝓤 ̇
  is-located-family x = (p q : )  p < q  (p < x)  (q  x)

  lub-sufficient-conditions : F  𝓤⁺ ̇
  lub-sufficient-conditions x =  𝐼 
                              × is-upper-bounded x
                              × is-located-family x

  lub : (x : F)  lub-sufficient-conditions x  x has-a-lub
  lub x (𝐼-inhabited , x-bounded , x-located) = y , a , b
   where
    L : 𝓟 
    L p = (p < x) , strict-order-ℚ-F-is-prop p x

    L-inhabited :  p   , p < x
    L-inhabited = ∥∥-rec ∃-is-prop I 𝐼-inhabited
     where
      I : 𝐼   p   ,  i  𝐼 , p < x i
      I i = III II
       where
        II : Σ i  𝐼 ,  p   , p < x i
        II = i , lowercut-is-inhabited (x i)

        III : type-of II   p   ,  i  𝐼 , p < x i
        III (i , s) = ∥∥-functor IV s
         where
          IV : (Σ p   , p < x i)  Σ p   ,  i  𝐼 , p < x i
          IV (p , l) = p ,  i , l 

    L-lower : (q : )  q < x  (p : )  p < q  p < x
    L-lower q l p m = ∥∥-functor  (i , k)  i , lowercut-is-lower (x i) q k p m) l

    L-upper-open : (p : )  p < x   p'   , ((p < p') × (p' < x))
    L-upper-open p = ∥∥-rec ∃-is-prop f
     where
      f : (Σ i  𝐼 , p < x i)   p'   , ((p < p') × (p' < x))
      f (i , l) = ∥∥-functor g (lowercut-is-upper-open (x i) p l)
       where
        g : (Σ p'   , (p < p') × (p' < x i))  Σ p'   , ((p < p') × (p' < x))
        g (p' , m , o) = p' , m ,  i , o 

    yᴸ : ℝᴸ
    yᴸ = (L , L-inhabited , L-lower , L-upper-open)

    L-bounded-above :  q   , q  x
    L-bounded-above = ∥∥-rec ∃-is-prop I x-bounded
     where
      I : (Σ β   , x  β)   q   , q  x
      I (β , l) = ∥∥-functor II (uppercut-is-inhabited β)
       where
        II : (Σ q   , β < q)  Σ q   , q  x
        II (q , m) = q , ∥∥-rec 𝟘-is-prop III
         where
          III : ¬ (Σ i  𝐼 , q < x i)
          III (i , o) = <-ℚ-ℚ-irrefl q (cuts-are-ordered β q q (l i q o) m)

    L-located : (p q : )  p < q  (p < x)  (q  x)
    L-located = x-located

    τ : is-troelstra yᴸ
    τ = L-bounded-above , L-located

    y : 
    y = (yᴸ , troelstra-gives-dedekind yᴸ τ)

    a : x  y
    a i p l =  i , l 

    b : (z : )  x  z  y  z
    b z l p = ∥∥-rec (<-ℚ-ℝ-is-prop-valued p z) f
     where
      f : (Σ i  𝐼 , p < x i)  p < z
      f (i , m) = l i p m

  instance
   strict-order-F-ℚ : Strict-Order F 
   _<_ {{strict-order-F-ℚ}} x q = (i : 𝐼)  x i < q

  <-F-ℚ-is-prop-valued : (q : ) (x : F)  is-prop (x < q)
  <-F-ℚ-is-prop-valued q x = Π-is-prop fe  i  <-ℝ-ℚ-is-prop-valued (x i) q)

  is-bishop-located : F  𝓤 ̇
  is-bishop-located x = (p q : )  p < q  (p < x)  (x < q)

  bishop-located-families-are-located : (x : F)
                                       is-bishop-located x
                                       is-located-family x
  bishop-located-families-are-located x located p q l = IV

   where
    I : x < q  q  x
    I m = ∥∥-rec 𝟘-is-prop II
     where
      II : ¬ (Σ i  𝐼 , q < x i)
      II (i , o) = <-ℚ-ℚ-irrefl q (cuts-are-ordered (x i) q q o (m i))

    III : (p < x) + (x < q)  (p < x) + (q  x)
    III (inl l) = inl l
    III (inr m) = inr (I m)

    IV : (p < x)  (q  x)
    IV = ∥∥-functor III (located p q l)

\end{code}

The partial reals, or interval domain, arise from dropping the
locatedness condition from the Dedekind reals.

\begin{code}

 instance
  strict-order-ℚ-ℝᴸ : Strict-Order  ℝᴸ
  _<_ {{strict-order-ℚ-ℝᴸ}} p (L , _) = p  L

  strict-order-ℝᵁ-ℚ : Strict-Order ℝᵁ 
  _<_ {{strict-order-ℝᵁ-ℚ}} (U , _) p = p  U

 instance
  order-ℝᴸ-ℝᵁ : Order ℝᴸ ℝᵁ
  _≤_ {{order-ℝᴸ-ℝᵁ}} x y = (p q : )  p < x  y < q  p < q

 𝓡 : 𝓤⁺ ̇
 𝓡 = Σ (x , y)  ℝᴸ × ℝᵁ , (x  y)

 𝓡-is-set : is-set 𝓡
 𝓡-is-set = subsets-of-sets-are-sets (ℝᴸ × ℝᵁ)  (x , y)  x  y)
              (×-is-set ℝᴸ-is-set ℝᵁ-is-set)
              (Π₄-is-prop fe  _ _ _ _  <-ℚ-ℚ-is-prop-valued _ _))

 NB₄ : 𝓡  (Σ (L , U)  𝓟  × 𝓟 
                  , (is-inhabited L × is-lower L × is-upper-open L)
                  × (is-inhabited U × is-upper U × is-lower-open U)
                  × are-ordered L U)

 NB₄ = qinveq  (((L , Li , Ll , Lo) , (U , Ui , Uu , Uo)) , o)
                (L , U) , (Li , Ll , Lo) , ((Ui , Uu , Uo) , o))
             ((λ ((L , U) , (Li , Ll , Lo) , ((Ui , Uu , Uo) , o))
                (((L , Li , Ll , Lo) , (U , Ui , Uu , Uo)) , o)) ,
               _  refl) ,
               _  refl))

 ℝ-to-𝓡 :   𝓡
 ℝ-to-𝓡 (x , y , o , _) = (x , y) , o

 instance
  canonical-map-ℝ-to-𝓡 : Canonical-Map  𝓡
  ι {{canonical-map-ℝ-to-𝓡}} = ℝ-to-𝓡

  order-ℝᴸ-ℝᴸ : Order ℝᴸ ℝᴸ
  _≤_ {{order-ℝᴸ-ℝᴸ}} x y = (p : )  p < x  p < y

  order-ℝᵁ-ℝᵁ : Order ℝᵁ ℝᵁ
  _≤_ {{order-ℝᵁ-ℝᵁ}} x y = (p : )  y < p  x < p

  square-order-𝓡-𝓡 : Square-Order 𝓡 𝓡
  _⊑_ {{square-order-𝓡-𝓡}} ((x , y) , _) ((x' , y') , _) = (x  x') × (y'  y)

 ℝ-to-𝓡-is-embedding : is-embedding (canonical-map  𝓡)
 ℝ-to-𝓡-is-embedding ((x , y) , o) ((x , y , o , l) , refl) ((x , y , o , m) , refl) = γ
  where
   δ : l  m
   δ = being-located-is-prop (ι x) (ι y) l m

   γ : ((x , y , o , l) , refl)  ((x , y , o , m) , refl)
   γ = ap  -  (x , y , o , -) , refl) δ

\end{code}

Notice that this is reverse inclusion of intervals: wider intervals
are lower in the square order.

If we drop the inhabitation conditions, the endpoints can be ±∞:

\begin{code}

 𝓡∞ = (Σ (L , U)  𝓟  × 𝓟 
             , (is-lower L × is-upper-open L)
             × (is-upper U × is-lower-open U)
             × are-ordered L U)

 𝓡-to-𝓡∞ : 𝓡  𝓡∞
 𝓡-to-𝓡∞ (((L , _ , Ll , Lo) , (U , _ , Uu , Uo)) , o) = (L , U) , (Ll , Lo) , (Uu , Uo) , o

 ⊥𝓡 : 𝓡∞
 ⊥𝓡 = ( , ) , ((λ _ ()) ,  _ ())) , ((λ _ ()) ,  _ ())) ,  p q ())

 instance
  canonical-map-𝓡-to-𝓡∞ : Canonical-Map 𝓡 𝓡∞
  ι {{canonical-map-𝓡-to-𝓡∞}} = 𝓡-to-𝓡∞

 𝓡-to-𝓡∞-is-embedding : is-embedding (canonical-map 𝓡 𝓡∞)
 𝓡-to-𝓡∞-is-embedding ((L , U) , (Ll , Lo) , (Uu , Uo) , o)
                        ((((L , i , Ll , Lo) , U , k , Uu , Uo) , o) , refl)
                        ((((L , j , Ll , Lo) , U , l , Uu , Uo) , o) , refl)
   = (((L , i , Ll , Lo) , U , k , Uu , Uo) , o) , refl =⟨ I 
     (((L , j , Ll , Lo) , U , l , Uu , Uo) , o) , refl 
  where
   I = ap₂  i k  (((L , i , Ll , Lo) , U , k , Uu , Uo) , o) , refl)
           (being-inhabited-is-prop L i j)
           (being-inhabited-is-prop U k l)

\end{code}

The notion of a locator for a real number was studied by my student
Auke Booij in his PhD thesis.

\begin{code}

 locator :   𝓤 ̇
 locator x = (p q : )  p < q  (p < x) + (x < q)

\end{code}

We also consider the following notion of locator for families:

\begin{code}

 bishop-locator : {𝐼 : 𝓤 ̇ }  (𝐼  )  𝓤 ̇
 bishop-locator {𝐼} x = (p q : )
                       p < q
                       (Σ i  𝐼 , p < x i)
                      + (Π i  𝐼 , x i < q)

 pointwise-locator-gives-bishop-locator : (𝐼 : 𝓤 ̇ ) (x : 𝐼  )
                                         is-compact∙ 𝐼
                                         ((i : 𝐼)  locator (x i))
                                         bishop-locator x
 pointwise-locator-gives-bishop-locator 𝐼 x κ  p q l = γ
  where
   γ : (Σ i  𝐼 , p < x i) + (Π i  𝐼 , x i < q)
   γ = compact-gives-Σ+Π 𝐼
         i  p < x i )  i  x i < q)
        (compact∙-types-are-compact κ)
         i   i p q l)

 lub-with-locators : (𝐼 : 𝓤 ̇ ) (x : 𝐼  )
                    is-compact∙ 𝐼
                    is-upper-bounded x
                    ((i : 𝐼)  locator (x i))
                    Σ y   , (x has-lub y) × locator y
 lub-with-locators 𝐼 x κ β  = γ
  where
   h :  𝐼 
   h =  compact∙-types-are-pointed κ 

   I : bishop-locator x
   I = pointwise-locator-gives-bishop-locator 𝐼 x κ 

   II : (p q : )  p < q  ((Σ i  𝐼 , p < x i) + (Π i  𝐼 , x i < q))  (p < x)  (x < q)
   II p q l (inl (i , m)) =  inl  i , m  
   II p q l (inr ϕ)       =  inr ϕ 

   III : is-bishop-located x
   III p q l = II p q l (I p q l)

   IV : x has-a-lub
   IV = lub x (h , β , bishop-located-families-are-located x III)

   y : 
   y = pr₁ IV

   V : x has-lub y
   V = pr₂ IV

   VI : (p q : )  p < q  (p < y) + (y < q)
   VI p q l = δ (ℚ-density p q l)
    where
     δ : (Σ q'   , (p < q') × (q' < q))  (p < y) + (y < q)
     δ (q' , i , j) = VII (I p q' i)
      where
       VII : ((Σ i  𝐼 , p < x i) + (Π i  𝐼 , x i < q'))  (p < y) + (y < q)
       VII (inl (o , m)) = inl  o , m 
       VII (inr ϕ)       = inr IX
        where
         VIII : q'  y
         VIII = ∥∥-rec 𝟘-is-prop  (i , o)  <-ℚ-ℚ-irrefl q' (cuts-are-ordered (x i) q' q' o (ϕ i)))

         IX :  q'   , (q' < q) × q'  y
         IX =  q' , j , VIII 

   γ : Σ y   , (x has-lub y) × locator y
   γ = (y , V , VI)

\end{code}

Limits of sequences, but using the topological, rather than metric, structure of the reals.

\begin{code}

 ⦅_,_⦆ :     (  Ω 𝓤)
  p , q  = λ x  ((p < x) × (x < q)) , ×-is-prop
                                         (<-ℚ-ℝ-is-prop-valued p x)
                                         (<-ℝ-ℚ-is-prop-valued x q)

 _has-limit_ : (  )    𝓤 ̇
 x has-limit x∞ = (p q : )
                  x∞   p , q 
                   n   , ((k : )  k  n  x k   p , q )

 open import CoNaturals.Type

 is-continuous-ℕ∞-ℝ : (ℕ∞  )  𝓤 ̇
 is-continuous-ℕ∞-ℝ x = (𝓃 : ℕ∞) (p q : )
                       x 𝓃   p , q 
                        𝓀  ℕ∞
                            , (𝓀  𝓃)
                            × ((𝒾 : ℕ∞)  𝒾  𝓀  x 𝒾   p , q )

\end{code}

Some (overlapping) problems:

\begin{code}

 Problem₁ = (x :   ) (x∞ : )
           x has-limit x∞
           Σ   (ℕ∞  )
                 , ((n : )   (ι n)  x n)
                 × (   x∞)

 Problem₂ = (x :   ) (x∞ : )
           ((n : )  locator (x n))
           locator x∞
           x has-limit x∞
           Σ   (ℕ∞  )
                 , ((n : )   (ι n)  x n)
                 × (   x∞)
                 × ((𝓃 : ℕ∞)  locator ( 𝓃))

 Problem₃ = (x : ℕ∞  )
           (x  ι) has-limit (x )
           ((n : )  locator (x (ι n)))
           locator (x )

 Problem₄ = Σ A  (  Ω 𝓤) , (Σ x   , x  A)  ℕ∞

 Problem₅ = Σ A  (  Ω 𝓤)
                , ((Σ x   , x  A)  ℕ∞)
                × ((x : )  x  A  locator x)

 Problem₆ = (A :   Ω 𝓤)
           ((Σ x   , x  A)  ℕ∞)
           (x : )
           x  A
           locator x

\end{code}

Should some of the above ∃ be Σ and/or vice-versa?

Added 22 August 2023. The lower reals have arbitrary sups if we remove
the inhabitation condition, so that we get a point -∞, in addition to
a point ∞ which is already present (this is well known).

TODO. Maybe remove the the inhabitation condition from the lower
reals. It doesn't reall belong there.

\begin{code}
{-
 ℝᴸᴼ : 𝓤⁺ ̇
 ℝᴸᴼ = Σ L ꞉ 𝓟 ℚ , is-lower L × is-upper-open L

 -∞ᴸᴼ : ℝᴸᴼ
 -∞ᴸᴼ = ?

 ∞ᴸᴼ : ℝᴸᴼ
 ∞ᴸᴼ = ?

 lowercutᴸᴼ : ℝᴸᴼ → 𝓟 ℚ
 lowercutᴸᴼ (L , _ , _) = L

 lowercutᴸᴼ-lc : (x y : ℝᴸᴼ) → lowercutᴸᴼ x = lowercutᴸᴼ y → x = y
 lowercutᴸᴼ-lc x y e = ?


 instance
  strict-order-ℚ-ℝᴸᴼ : Strict-Order ℚ ℝᴸᴼ
  _<_ {{strict-order-ℚ-ℝᴸᴼ}} p x = p ∈ lowercutᴸᴼ x

 instance
  order-ℝᴸᴼ-ℝᴸᴼ : Order ℝᴸᴼ ℝᴸᴼ
  _≤_ {{order-ℝᴸᴼ-ℝᴸᴼ}} x y = (p : ℚ) → p < x → p < y


 ≤-ℝᴸᴼ-ℝᴸᴼ-antisym : (x y : ℝᴸᴼ) → x ≤ y → y ≤ x → x = y
 ≤-ℝᴸᴼ-ℝᴸᴼ-antisym x y l m = lowercutᴸᴼ-lc x y γ
  where
   γ : lowercutᴸᴼ x = lowercutᴸᴼ y
   γ = subset-extensionality'' pe fe fe l m


 module _ {𝐼 : 𝓤 ̇ } where

  private
   Fᴸᴼ = 𝐼 → ℝᴸᴼ

  instance
   order-F-ℝᴸᴼ : Order Fᴸᴼ ℝᴸᴼ
   _≤_ {{order-F-ℝᴸᴼ}} x y = (i : 𝐼) → x i ≤ y

  ≤-F-ℝᴸᴼ-is-prop-valued : (x : Fᴸᴼ) (y : ℝᴸᴼ)
                           → is-prop (x ≤ y)
  ≤-F-ℝᴸᴼ-is-prop-valued x y = Π-is-prop fe (λ i → ?)

  _has-lubᴸᴼ_ : Fᴸᴼ → ℝᴸᴼ → 𝓤⁺ ̇
  x has-lubᴸᴼ y = (x ≤ y) × ((z : ℝᴸᴼ) → x ≤ z → y ≤ z)

  _has-a-lubᴸᴼ : Fᴸᴼ → 𝓤⁺ ̇
  x has-a-lubᴸᴼ = Σ y ꞉ ℝᴸᴼ , (x has-lubᴸᴼ y)

  having-lubᴸᴼ-is-prop : (x : Fᴸᴼ) (y : ℝᴸᴼ)
                      → is-prop (x has-lubᴸᴼ y)
  having-lubᴸᴼ-is-prop x y = ?

  having-a-lub-is-propᴸᴼ : (x : Fᴸᴼ) → is-prop (x has-a-lubᴸᴼ)
  having-a-lub-is-propᴸᴼ x (y , a , b) (y' , a' , b') = γ
   where
    I : y = y'
    I = ≤-ℝᴸᴼ-ℝᴸᴼ-antisym y y' (b y' a') (b' y a)

    γ : (y , a , b) = (y' , a' , b')
    γ = to-subtype-= (having-lubᴸᴼ-is-prop x) I

  instance
   strict-order-ℚ-Fᴸᴼ : Strict-Order ℚ Fᴸᴼ
   _<_ {{strict-order-ℚ-Fᴸᴼ}} p x = ∃ i ꞉ 𝐼 , p < x i

  strict-order-ℚ-Fᴸᴼ-is-prop : (p : ℚ) (x : Fᴸᴼ) → is-prop (p < x)
  strict-order-ℚ-Fᴸᴼ-is-prop p x = ∃-is-prop


{-
  instance
   strict-order-ℚ-F : Strict-Order ℚ F
   _<_ {{strict-order-ℚ-F}} p x = ∃ i ꞉ 𝐼 , p < x i

  strict-order-ℚ-F-is-prop : (p : ℚ) (x : F) → is-prop (p < x)
  strict-order-ℚ-F-is-prop p x = ∃-is-prop

  strict-order-ℚ-F-observation : (p : ℚ) (x : F)
                               → (p ≮ x) ↔ (x ≤ ι p)
  strict-order-ℚ-F-observation p x = f , g
   where
    f : p ≮ x → x ≤ ι p
    f ν i = I
     where
      I : (q : ℚ) → q < x i → q < p
      I q l = ℚ-order-criterion q p II III
       where
        II : p ≮ q
        II m = ν ∣ i , lowercut-is-lower (x i) q l p m ∣

        III : q ≠ p
        III refl = ν ∣ i , l ∣

    g : x ≤ ι p → p ≮ x
    g l = ∥∥-rec 𝟘-is-prop I
     where
      I : ¬ (Σ i ꞉ 𝐼 , p < x i)
      I (i , m) = <-ℚ-ℚ-irrefl p (l i p m)
-}
  is-upper-boundedᴸᴼ : Fᴸᴼ → 𝓤⁺ ̇
  is-upper-boundedᴸᴼ x = ∃ y ꞉ ℝᴸᴼ , (x ≤ y)


  lubᴸᴼ : (x : Fᴸᴼ) → x has-a-lubᴸᴼ
  lubᴸᴼ x = y , ?
   where
    L : 𝓟 ℚ
    L p = (p < x) , ? -- strict-order-ℚ-Fᴸᴼ-is-prop p x


    L-lower : (q : ℚ) → q < x → (p : ℚ) → p < q → p < x
    L-lower q l p m = ?
    -- ∥∥-functor (λ (i , k) → i , lowercut-is-lower (x i) q k p m) l

    L-upper-open : (p : ℚ) → p < x → ∃ p' ꞉ ℚ , ((p < p') × (p' < x))
    L-upper-open p = ∥∥-rec ∃-is-prop f
     where
      f : (Σ i ꞉ 𝐼 , p < x i) → ∃ p' ꞉ ℚ , ((p < p') × (p' < x))
      f (i , l) = ? {- ∥∥-functor g (lowercut-is-upper-open (x i) p l)
       where
        g : (Σ p' ꞉ ℚ , (p < p') × (p' < x i)) → Σ p' ꞉ ℚ , ((p < p') × (p' < x))
        g (p' , m , o) = p' , m , ∣ i , o ∣
-}
    y : ℝᴸᴼ
    y = (L , L-lower , L-upper-open)

    a : x ≤ y
    a i p l = ∣ i , l ∣
{-
    b : (z : ℝᴸᴼ) → x ≤ z → y ≤ z
    b z l p = ∥∥-rec (<-ℚ-ℝᴸᴼ-is-prop-valued p z) f
     where
      f : (Σ i ꞉ 𝐼 , p < x i) → p < z
      f (i , m) = l i p m
-}
  instance
   strict-order-F-ℚᴸᴼ : Strict-Order Fᴸᴼ ℚ
   _<_ {{strict-order-F-ℚᴸᴼ}} x q = (i : 𝐼) → x i < q

{-
  <-F-ℚᴸᴼ-is-prop-valued : (q : ℚ) (x : F) → is-prop (x < q)
  <-F-ℚᴸᴼ-is-prop-valued q x = Π-is-prop fe (λ i → <-ℝᴸᴼ-ℚ-is-prop-valued (x i) q)
-}
-}
\end{code}