module Homotopy.Connectedness where

Connectedness🔗

We say that a type is nn-connected if its nn-truncation is contractible.

While being nn-truncated expresses that all homotopy groups above nn are trivial, being nn-connected means that all homotopy groups below nn are trivial. A type that is both nn-truncated and nn-connected is contractible.

We give definitions in terms of the propositional truncation and set truncation for the lower levels, and then defer to the general “hubs and spokes” truncation. Note that our indices are offset by 2, just like h-levels.

is-n-connected :  {}  Type ℓ  Nat  Type _
is-n-connected A zero = Lift _
is-n-connected A (suc zero) = ∥ A ∥
is-n-connected A (suc (suc zero)) = is-contr ∥ A ∥₀
is-n-connected A n@(suc (suc (suc _))) = is-contr (n-Tr A n)

Being nn-connected is a proposition:

is-n-connected-is-prop : (n : Nat)  is-prop (is-n-connected A n)
is-n-connected-is-prop 0 _ _ = refl
is-n-connected-is-prop 1     = is-prop-∥-∥
is-n-connected-is-prop 2     = is-contr-is-prop
is-n-connected-is-prop (suc (suc (suc n))) = is-contr-is-prop

For short, we say that a type is connected if it is 00-connected, and simply connected if it is 11-connected:

is-connected :  {}  Type ℓ  Type _
is-connected A = is-n-connected A 2

is-simply-connected :  {}  Type ℓ  Type _
is-simply-connected A = is-n-connected A 3

Furthermore, we say that a map is nn-connected if all of its fibres are nn-connected.

is-n-connected-map : (A  B)  Nat  Type _
is-n-connected-map f n =  x  is-n-connected (fibre f x) n

Pointed connected types🔗

In the case of pointed types, there is an equivalent definition of being connected that is sometimes easier to work with: a pointed type is connected if every point is merely equal to the base point.

is-connected∙ :  {}  Type∙ ℓ  Type _
is-connected∙ (X , pt) = (x : X)  ∥ x ≡ pt ∥

module _ {} {X@(_ , pt) : Type∙ ℓ} where
  is-connected∙→is-connected : is-connected∙ X  is-connected ⌞ X ⌟
  is-connected∙→is-connected c .centre = inc pt
  is-connected∙→is-connected c .paths =
    ∥-∥₀-elim  _  is-hlevel-suc 2 squash (inc pt) _) λ x 
      ∥-∥-rec! {pprop = squash _ _} (ap inc ∘ sym) (c x)

  is-connected→is-connected∙ : is-connected ⌞ X ⌟  is-connected∙ X
  is-connected→is-connected∙ c x =
    ∥-∥₀-path.to (is-contr→is-prop c (inc x) (inc pt))

This alternative definition lets us formulate a nice elimination principle for pointed connected types: any family of propositions PP that holds on the base point holds everywhere.

In particular, since being a proposition is a proposition, we only need to check that P()P(\bullet_{}) is a proposition.

connected∙-elim-prop
  :  {ℓ ℓ'} {X : Type∙ ℓ} {P : ⌞ X ⌟  Type ℓ'}
   is-connected∙ X
   is-prop (P (X .snd))
   P (X .snd)
    x  P x
connected∙-elim-prop {X = X} {P} conn prop pb x =
  ∥-∥-rec propx  e  subst P (sym e) pb) (conn x)
  where abstract
    propx : is-prop (P x)
    propx = ∥-∥-rec is-prop-is-prop  e  subst (is-prop ∘ P) (sym e) prop) (conn x)

We can similarly define an elimination principle into sets.

module connected∙-elim-set
  {ℓ ℓ'} {X : Type∙ ℓ} {P : ⌞ X ⌟  Type ℓ'}
  (conn : is-connected∙ X)
  (set : is-set (P (X .snd)))
  (pb : P (X .snd))
  (loops :  (p : X .snd ≡ X .snd)  PathP  i  P (p i)) pb pb)
  where opaque

  elim :  x  P x
  elim x = work (conn x)
    module elim where
      setx : is-set (P x)
      setx = ∥-∥-rec (is-hlevel-is-prop 2)  e  subst (is-set ∘ P) (sym e) set) (conn x)

      work : ∥ x ≡ X .snd ∥  P x
      work = ∥-∥-rec-set setx
         p  subst P (sym p) pb)
         p q i  subst P (sym (∙-filler'' (sym p) q i)) (loops (sym p ∙ q) i))

  elim-β-point : elim (X .snd) ≡ pb
  elim-β-point = subst  c  elim.work (X .snd) c ≡ pb)
    (squash (inc refl) (conn (X .snd)))
    (transport-refl pb)

Examples of pointed connected types include the circle and the delooping of a group.

Closure properties🔗

As a property of types, nn-connectedness enjoys closure properties very similar to those of nn-truncatedness; and we establish them in much the same way, by proving that nn-connectedness is preserved by retractions.

However, the definition of is-n-connected, which uses the explicit constructions of truncations for the base cases, is slightly annoying to work when nn is arbitrary: that’s the trade-off for it being easy to work with when nn is a known, and usually small, number. Therefore, we prove the following lemma by the recursion, establishing that the notion of connectedness could very well have been defined using the general nn-truncation uniformly.

is-n-connected-Tr :  {} {A : Type ℓ} n  is-n-connected A (suc n)  is-contr (n-Tr A (suc n))
is-n-connected-Tr zero a-conn = ∥-∥-proj! do
  pt ← a-conn
  pure $ contr (inc pt)  x  n-Tr-is-hlevel 0 _ _)
is-n-connected-Tr (suc zero) a-conn =
  retract→is-hlevel 0
    (∥-∥₀-rec (n-Tr-is-hlevel 1) inc)
    (n-Tr-rec squash inc)
    (n-Tr-elim _  _  is-prop→is-set (n-Tr-is-hlevel 1 _ _)) λ _  refl)
    a-conn
is-n-connected-Tr (suc (suc n)) a-conn = a-conn

The first closure property we’ll prove is very applicable: it says that any retract of an nn-connected type is again nn-connected. Intuitively this is because any retraction f:ABf : A \to B can be extended to a retraction AnBn\| A \|_n \to \| B \|_n, and contractible types are closed under retractions.

retract→is-n-connected
  : (n : Nat) (f : A  B) (g : B  A)
   is-left-inverse f g  is-n-connected A n  is-n-connected B n
retract→is-n-connected 0 = _
retract→is-n-connected 1 f g h a-conn = f <$> a-conn
retract→is-n-connected (suc (suc n)) f g h a-conn =
  n-connected.from (suc n) $ retract→is-contr
    (n-Tr-rec! (inc ∘ f))
    (n-Tr-rec! (inc ∘ g))
    (n-Tr-elim! _ λ x  ap n-Tr.inc (h x))
    (is-n-connected-Tr (suc n) a-conn)

Since the truncation operator n\| - \|_n also preserves products, a remarkably similar argument shows that if AA and BB are nn-connected, then so is A×BA \times B is.

×-is-n-connected
  :  n  is-n-connected A n  is-n-connected B n  is-n-connected (A × B) n
×-is-n-connected 0 = _
×-is-n-connected (suc n) a-conn b-conn = n-connected.from n $ is-hlevel≃ 0
  n-Tr-product (×-is-hlevel 0 (n-connected.to n a-conn) (n-connected.to n b-conn))

Finally, we show the dual of two properties of truncations: if AA is (1+n)(1+n)-connected, then each path space xAyx \equiv_A y is nn-connected; And if AA is (2+n)(2+n)-connected, then it is also (1+n(1+n) connected. This latter property lets us count down in precisely the same way that is-hlevel-suc lets us count up.

Path-is-connected :  n  is-n-connected A (suc n)  is-n-connected (Path A x y) n
Path-is-connected 0 = _
Path-is-connected {x = x} (suc n) conn = n-connected.from n (contr (ps _ _) $
  n-Tr-elim _  _  hlevel!)
    (J  y p  ps x y ≡ inc p) (Equiv.injective (Equiv.inverse n-Tr-path-equiv)
      (is-contr→is-set (is-n-connected-Tr _ conn) _ _ _ _))))
  where
    ps :  x y  n-Tr (x ≡ y) (suc n)
    ps x y = Equiv.to n-Tr-path-equiv (is-contr→is-prop (is-n-connected-Tr _ conn) _ _)

is-connected-suc
  :  {} {A : Type ℓ} n
   is-n-connected A (suc n)  is-n-connected A n
is-connected-suc {A = A} zero _ = _
is-connected-suc {A = A} (suc n) w = n-connected.from n $ n-Tr-elim! _
     x  contr (inc x) (n-Tr-elim _  _  hlevel!) (rem₁ n w x)))
    (is-n-connected-Tr (suc n) w .centre)
  where
    rem₁ :  n  is-n-connected A (2 + n)   x y  Path (n-Tr A (suc n)) (inc x) (inc y)
    rem₁ zero a-conn x y = n-Tr-is-hlevel 0 _ _
    rem₁ (suc n) a-conn x y = Equiv.from n-Tr-path-equiv
      (n-Tr-rec (is-hlevel-suc _ (n-Tr-is-hlevel n)) inc
        (is-n-connected-Tr _ (Path-is-connected (2 + n) a-conn) .centre))

is-connected-+
  :  {} {A : Type ℓ} (n k : Nat)
   is-n-connected A (k + n)  is-n-connected A n
is-connected-+ n zero w = w
is-connected-+ n (suc k) w = is-connected-+ n k (is-connected-suc _ w)

In terms of propositional truncations🔗

There is an alternative definition of connectedness that avoids talking about arbitrary truncations, and is thus sometimes easier to work with. Generalising the special cases for n=1n = -1 (a type is (1)(-1)-connected if and only if it is inhabited) and n=0n = 0 (a type is 00-connected if and only if it is inhabited and all points are merely equal), we can prove that a type is nn-connected if and only if it is inhabited and all its path spaces are (n1)(n-1)-connected.

We can use this to give a definition of connectedness that only makes use of propositional truncations, with the base case being that all types are (n2)(n-2)-connected:

is-n-connected-∥-∥ :  {}  Type ℓ  Nat  Type ℓ
is-n-connected-∥-∥ A zero = Lift _
is-n-connected-∥-∥ A (suc n) =
  ∥ A ∥ ×  (a b : A)  is-n-connected-∥-∥ (a ≡ b) n

is-n-connected-∥-∥-is-prop :  n  is-prop (is-n-connected-∥-∥ A n)
is-n-connected-∥-∥-is-prop zero = hlevel 1
is-n-connected-∥-∥-is-prop (suc n) = ×-is-hlevel 1 (hlevel 1)
  (Π-is-hlevel² 1 λ _ _  is-n-connected-∥-∥-is-prop n)

We show that this is equivalent to the nn-truncation of a type being contractible, hence in turn to our first definition.

is-contr-n-Tr→∥-∥
  :  n  is-contr (n-Tr A (suc n))  is-n-connected-∥-∥ A (suc n)
is-contr-n-Tr→∥-∥ zero h .fst = n-Tr-rec! inc (h .centre)
is-contr-n-Tr→∥-∥ zero h .snd = _
is-contr-n-Tr→∥-∥ (suc n) h .fst = n-Tr-rec! inc (h .centre)
is-contr-n-Tr→∥-∥ (suc n) h .snd a b = is-contr-n-Tr→∥-∥ n
  (is-hlevel≃ 0 (n-Tr-path-equiv e⁻¹) (Path-is-hlevel 0 h))

∥-∥→is-contr-n-Tr
  :  n  is-n-connected-∥-∥ A (suc n)  is-contr (n-Tr A (suc n))
∥-∥→is-contr-n-Tr zero (a , _) = is-prop∙→is-contr hlevel! (∥-∥-rec! inc a)
∥-∥→is-contr-n-Tr (suc n) (a , h) = ∥-∥-rec!  a  is-prop∙→is-contr
  (n-Tr-elim! _ λ a  n-Tr-elim! _ λ b 
    Equiv.from n-Tr-path-equiv (∥-∥→is-contr-n-Tr n (h a b) .centre))
  (inc a)) a

is-n-connected→∥-∥
  :  n  is-n-connected A n  is-n-connected-∥-∥ A n
is-n-connected→∥-∥ zero _ = _
is-n-connected→∥-∥ (suc n) h = is-contr-n-Tr→∥-∥ n (n-connected.to n h)

∥-∥→is-n-connected
  :  n  is-n-connected-∥-∥ A n  is-n-connected A n
∥-∥→is-n-connected zero _ = _
∥-∥→is-n-connected (suc n) h = n-connected.from n (∥-∥→is-contr-n-Tr n h)

is-n-connected≃∥-∥
  :  n  is-n-connected A n ≃ is-n-connected-∥-∥ A n
is-n-connected≃∥-∥ {A = A} n = prop-ext
  (is-n-connected-is-prop {A = A} n) (is-n-connected-∥-∥-is-prop n)
  (is-n-connected→∥-∥ n) (∥-∥→is-n-connected n)

module n-connected-∥-∥ {} {A : Type ℓ} (n : Nat) =
  Equiv (is-n-connected≃∥-∥ {A = A} n)

In relation to truncatedness🔗

The following lemmas define nn-connectedness of a type AA by how it can map into the nn-truncated types. We then expand this idea to cover the nn-connected maps, too. At the level of types, the “relative” characterisation of nn-connectedness says that, if AA is nn-connected and BB is nn-truncated, then the function const:B(AB)\mathrm{const} : B \to (A \to B) is an equivalence.

The intuitive idea behind this theorem is as follows: we have assumed that AA has no interesting information below dimension nn, and that BB has no interesting information in the dimensions nn and above. Therefore, the functions ABA \to B can’t be interesting, since they’re mapping boring data into boring data.

The proof is a direct application of the definition of nn-connectedness and the universal property of truncations: ABA \to B is equivalent to AnB\| A \|_n \to B, but this is equivalent to BB since An\| A \|_n is contractible.

is-n-connected→n-type-const
  :  n  is-hlevel B (suc n)  is-n-connected A (suc n)
   is-equiv {B = A  B}  b a  b)
is-n-connected→n-type-const {B = B} {A = A} n B-hl A-conn =
  subst is-equiv  i x z  transp  i  B) i x) $ snd $
  B                      ≃⟨ Π-contr-eqv (is-n-connected-Tr n A-conn) e⁻¹ ⟩
  (n-Tr A (suc n)  B)   ≃⟨ n-Tr-univ n B-hl ⟩
  (A  B)                ≃∎

This direction of the theorem is actually half of an equivalence. In the other direction, since An\| A \|_n is nn-truncated by definition, we suppose that const:An(AAn)\mathrm{const} : \| A \|_n \to (A \to \| A \|_n) is an equivalence. From the constructor inc:AAn\operatorname{inc} : A \to \| A \|_n we obtain a point p:Anp : \| A \|_n, and, for all aa, we have

p=const(p)(a)=inc(a). p = \operatorname{const}(p)(a) = \operatorname{inc}(a)\text{.}

But by induction on truncation, this says precisely that any a:Ana : \| A \|_n is equal to pp; so pp is a centre of contraction, and AA is nn-connected.

n-type-const→is-n-connected
  :  {} {A : Type ℓ} n
   (∀ {B : Type ℓ}  is-hlevel B (suc n)  is-equiv {B = A  B}  b a  b))
   is-n-connected A (suc n)
n-type-const→is-n-connected {A = A} n eqv =
  n-connected.from n $ contr (rem.from inc) $ n-Tr-elim _
     h  Path-is-hlevel (suc n) (n-Tr-is-hlevel n)) (rem.ε inc $ₚ_)
  where module rem = Equiv (_ , eqv {n-Tr A (suc n)} hlevel!)

We can now generalise this to work with an nn-connected map f:ABf : A \to B and a family PP of nn-types over BB: in this setting, precomposition with ff is an equivalence

(Πa:AP(fa))(Πb:BP(b)). (\Pi_{a : A} P(fa)) \to (\Pi_{b : B} P(b))\text{.}

This is somewhat analogous to generalising from a recursion principle to an elimination principle. When we were limited to talking about types, we could extend points b:Bb : B to functions ABA \to B, but no dependency was possible. With the extra generality, we think of ff as including a space of “constructors”, and the equivalence says that exhibiting PP at these constructors is equivalent to exhibiting it for the whole type.

relative-n-type-const
  : (P : B  Type ℓ'') (f : A  B)
    n  is-n-connected-map f n
   (∀ x  is-hlevel (P x) n)
   is-equiv {A = (∀ b  P b)} {B = (∀ a  P (f a))} (_∘ f)

Despite the generality, the proof is just a calculation: observing that we have the following chain of equivalences suffices.

  rem₁ =
    ((b : B)  P b)                             ≃⟨ Π-cod≃  x  Π-contr-eqv {B = λ _  P x} (is-n-connected-Tr _ (n-conn x)) e⁻¹)
    ((b : B)  n-Tr (fibre f b) (suc n)  P b)  ≃⟨ Π-cod≃  x  n-Tr-univ n (phl _))
    ((b : B)  fibre f b  P b)                 ≃⟨ shuffle ⟩
    ((a : A)  P (f a))                         ≃∎
There’s also the shuffle isomorphism that eliminates the fibre argument using path induction, but its construction is mechanical.
  shuffle = Iso→Equiv λ where
    .fst      g a          g (f a) (a , refl)
    .snd .inv g b (a , p)  subst P p (g a)
    .snd .rinv g  funext λ a  transport-refl _
    .snd .linv g  funext λ b  funext λ { (a , p) 
      J  b p  subst P p (g (f a) (a , refl)) ≡ g b (a , p))
        (transport-refl _) p }

We can specialise this to get a literal elimination principle: If PP is a family of nn-types over an (1+n)(1+n)-connected pointed type (A,a0)(A, a_0), then PP holds everywhere if P(a0)P(a_0) holds. Moreover, this has the expected computation rule.

module _ n (P : A  Type ℓ) (tr :  x  is-hlevel (P x) n)
           {a₀ : A} (pa₀ : P a₀)
           (a-conn : is-n-connected A (suc n))
  where

  connected-elimination-principle : fibre  z x  z a₀)  _  pa₀)
  connected-elimination-principle = relative-n-type-const {A =} P  _  a₀) n
     x  retract→is-n-connected n  p  tt , p) snd  _  refl)
      (Path-is-connected n a-conn))
    tr .is-eqv  _  pa₀) .centre

  opaque
    connected-elim :  x  P x
    connected-elim = connected-elimination-principle .fst

    connected-elim-β : connected-elim a₀ ≡ pa₀
    connected-elim-β = connected-elimination-principle .snd $ₚ tt

Using these elimination principles, we can prove that a pointed type (A,a0)(A,a_0) is (1+n)(1+n)-connected if and only if the inclusion of a0a_0 is nn-connected when considered as a map A\top \to A.

is-n-connected-point
  :  {} {A : Type ℓ} (a₀ : A) n
   is-n-connected-map {A =}  _  a₀) n
   is-n-connected A (suc n)
is-n-connected-point {A = A} a₀ n pt-conn = done where
  rem :  {B : Type ℓ}  is-hlevel B (suc n)   (f : A  B) a  f a₀ ≡ f a
  rem b-hl f = equiv→inverse
    (relative-n-type-const  a  f a₀ ≡ f a) _ n pt-conn λ x  Path-is-hlevel' n b-hl _ _)
     _  refl)

  done : is-n-connected A (suc n)
  done = n-type-const→is-n-connected n λ hl  is-iso→is-equiv $
    iso  f  f a₀)  f  funext λ a  rem hl f a) λ _  refl

point-is-n-connected
  :  {} {A : Type ℓ} (a₀ : A) n
   is-n-connected A (2 + n)
   is-n-connected-map {A =}  _  a₀) (suc n)
point-is-n-connected a₀ n a-conn =
  connected-elim (suc n)  x  is-n-connected (⊤ × (a₀ ≡ x)) (suc n))
     x  is-prop→is-hlevel-suc (is-n-connected-is-prop (suc n)))
    (retract→is-n-connected (suc n) (tt ,_) snd  _  refl)
      (Path-is-connected {y = a₀} (suc n) a-conn))
    a-conn