2015-10-20 01:42:41 +00:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Authors: Floris van Doorn
|
|
|
|
|
|
|
|
|
|
Attributes of functors (full, faithful, split essentially surjective, ...)
|
|
|
|
|
|
|
|
|
|
Adjoint functors, isomorphisms and equivalences have their own file
|
|
|
|
|
-/
|
|
|
|
|
|
2016-07-15 16:20:42 +00:00
|
|
|
|
import .basic function arity
|
2015-10-20 01:42:41 +00:00
|
|
|
|
|
2015-10-23 05:12:34 +00:00
|
|
|
|
open eq functor trunc prod is_equiv iso equiv function is_trunc
|
2015-10-20 01:42:41 +00:00
|
|
|
|
|
|
|
|
|
namespace category
|
|
|
|
|
variables {C D E : Precategory} {F : C ⇒ D} {G : D ⇒ C}
|
|
|
|
|
|
|
|
|
|
definition faithful [class] (F : C ⇒ D) := Π⦃c c' : C⦄ ⦃f f' : c ⟶ c'⦄, F f = F f' → f = f'
|
|
|
|
|
definition full [class] (F : C ⇒ D) := Π⦃c c' : C⦄, is_surjective (@(to_fun_hom F) c c')
|
|
|
|
|
definition fully_faithful [class] (F : C ⇒ D) := Π(c c' : C), is_equiv (@(to_fun_hom F) c c')
|
|
|
|
|
definition split_essentially_surjective [class] (F : C ⇒ D) := Π(d : D), Σ(c : C), F c ≅ d
|
|
|
|
|
definition essentially_surjective [class] (F : C ⇒ D) := Π(d : D), ∃(c : C), F c ≅ d
|
2015-10-22 22:41:55 +00:00
|
|
|
|
definition is_weak_equivalence [class] (F : C ⇒ D) :=
|
|
|
|
|
fully_faithful F × essentially_surjective F
|
2015-10-20 01:42:41 +00:00
|
|
|
|
|
2016-02-25 20:26:20 +00:00
|
|
|
|
definition is_equiv_of_fully_faithful [instance] (F : C ⇒ D)
|
2015-10-22 22:41:55 +00:00
|
|
|
|
[H : fully_faithful F] (c c' : C) : is_equiv (@(to_fun_hom F) c c') :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
!H
|
|
|
|
|
|
|
|
|
|
definition hom_inv [reducible] (F : C ⇒ D) [H : fully_faithful F] (c c' : C) (f : F c ⟶ F c')
|
|
|
|
|
: c ⟶ c' :=
|
|
|
|
|
(to_fun_hom F)⁻¹ᶠ f
|
|
|
|
|
|
2015-10-22 22:41:55 +00:00
|
|
|
|
definition reflect_is_iso [constructor] (F : C ⇒ D) [H : fully_faithful F] {c c' : C}
|
|
|
|
|
(f : c ⟶ c') [H : is_iso (F f)] : is_iso f :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
begin
|
|
|
|
|
fconstructor,
|
|
|
|
|
{ exact (to_fun_hom F)⁻¹ᶠ (F f)⁻¹},
|
|
|
|
|
{ apply eq_of_fn_eq_fn' (to_fun_hom F),
|
|
|
|
|
rewrite [respect_comp,right_inv (to_fun_hom F),respect_id,left_inverse]},
|
|
|
|
|
{ apply eq_of_fn_eq_fn' (to_fun_hom F),
|
|
|
|
|
rewrite [respect_comp,right_inv (to_fun_hom F),respect_id,right_inverse]},
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
definition reflect_iso [constructor] (F : C ⇒ D) [H : fully_faithful F] {c c' : C}
|
|
|
|
|
(f : F c ≅ F c') : c ≅ c' :=
|
|
|
|
|
begin
|
|
|
|
|
fconstructor,
|
|
|
|
|
{ exact (to_fun_hom F)⁻¹ᶠ f},
|
2016-02-29 20:11:17 +00:00
|
|
|
|
{ have H : is_iso (F ((to_fun_hom F)⁻¹ᶠ f)), from
|
|
|
|
|
have H' : is_iso (to_hom f), from _,
|
|
|
|
|
(right_inv (to_fun_hom F) (to_hom f))⁻¹ ▸ H',
|
2015-10-20 01:42:41 +00:00
|
|
|
|
exact reflect_is_iso F _},
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem reflect_inverse (F : C ⇒ D) [H : fully_faithful F] {c c' : C} (f : c ⟶ c')
|
2016-03-02 21:50:20 +00:00
|
|
|
|
[H' : is_iso f] : (to_fun_hom F)⁻¹ᶠ (F f)⁻¹ = f⁻¹ :=
|
|
|
|
|
@inverse_eq_inverse _ _ _ _ _ _ (reflect_is_iso F f) H' idp
|
2015-10-20 01:42:41 +00:00
|
|
|
|
|
|
|
|
|
definition hom_equiv_F_hom_F [constructor] (F : C ⇒ D)
|
|
|
|
|
[H : fully_faithful F] (c c' : C) : (c ⟶ c') ≃ (F c ⟶ F c') :=
|
|
|
|
|
equiv.mk _ !H
|
|
|
|
|
|
|
|
|
|
definition iso_of_F_iso_F (F : C ⇒ D)
|
|
|
|
|
[H : fully_faithful F] (c c' : C) (g : F c ≅ F c') : c ≅ c' :=
|
|
|
|
|
begin
|
|
|
|
|
induction g with g G, induction G with h p q, fapply iso.MK,
|
|
|
|
|
{ rexact (to_fun_hom F)⁻¹ᶠ g},
|
|
|
|
|
{ rexact (to_fun_hom F)⁻¹ᶠ h},
|
|
|
|
|
{ exact abstract begin
|
|
|
|
|
apply eq_of_fn_eq_fn' (to_fun_hom F),
|
|
|
|
|
rewrite [respect_comp, respect_id,
|
|
|
|
|
right_inv (to_fun_hom F), right_inv (to_fun_hom F), p],
|
|
|
|
|
end end},
|
|
|
|
|
{ exact abstract begin
|
|
|
|
|
apply eq_of_fn_eq_fn' (to_fun_hom F),
|
|
|
|
|
rewrite [respect_comp, respect_id,
|
|
|
|
|
right_inv (to_fun_hom F), right_inv (@(to_fun_hom F) c' c), q],
|
|
|
|
|
end end}
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
definition iso_equiv_F_iso_F [constructor] (F : C ⇒ D)
|
|
|
|
|
[H : fully_faithful F] (c c' : C) : (c ≅ c') ≃ (F c ≅ F c') :=
|
|
|
|
|
begin
|
|
|
|
|
fapply equiv.MK,
|
|
|
|
|
{ exact to_fun_iso F},
|
|
|
|
|
{ apply iso_of_F_iso_F},
|
|
|
|
|
{ exact abstract begin
|
|
|
|
|
intro f, induction f with f F', induction F' with g p q, apply iso_eq,
|
|
|
|
|
esimp [iso_of_F_iso_F], apply right_inv end end},
|
|
|
|
|
{ exact abstract begin
|
|
|
|
|
intro f, induction f with f F', induction F' with g p q, apply iso_eq,
|
|
|
|
|
esimp [iso_of_F_iso_F], apply right_inv end end},
|
|
|
|
|
end
|
|
|
|
|
|
2015-10-22 22:41:55 +00:00
|
|
|
|
definition full_of_fully_faithful [instance] (F : C ⇒ D) [H : fully_faithful F] : full F :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
λc c' g, tr (fiber.mk ((@(to_fun_hom F) c c')⁻¹ᶠ g) !right_inv)
|
|
|
|
|
|
2015-10-22 22:41:55 +00:00
|
|
|
|
definition faithful_of_fully_faithful [instance] (F : C ⇒ D) [H : fully_faithful F]
|
|
|
|
|
: faithful F :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
λc c' f f' p, is_injective_of_is_embedding p
|
|
|
|
|
|
2015-10-22 22:41:55 +00:00
|
|
|
|
definition is_embedding_of_faithful [instance] (F : C ⇒ D) [H : faithful F] (c c' : C)
|
|
|
|
|
: is_embedding (to_fun_hom F : c ⟶ c' → F c ⟶ F c') :=
|
|
|
|
|
begin
|
|
|
|
|
apply is_embedding_of_is_injective,
|
|
|
|
|
apply H
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
definition is_surjective_of_full [instance] (F : C ⇒ D) [H : full F] (c c' : C)
|
|
|
|
|
: is_surjective (to_fun_hom F : c ⟶ c' → F c ⟶ F c') :=
|
|
|
|
|
@H c c'
|
|
|
|
|
|
|
|
|
|
definition fully_faithful_of_full_of_faithful (H : faithful F) (K : full F)
|
|
|
|
|
: fully_faithful F :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
begin
|
|
|
|
|
intro c c',
|
|
|
|
|
apply is_equiv_of_is_surjective_of_is_embedding,
|
|
|
|
|
end
|
|
|
|
|
|
2016-02-15 20:18:07 +00:00
|
|
|
|
theorem is_prop_fully_faithful [instance] (F : C ⇒ D) : is_prop (fully_faithful F) :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
by unfold fully_faithful; exact _
|
|
|
|
|
|
2016-02-15 20:18:07 +00:00
|
|
|
|
theorem is_prop_full [instance] (F : C ⇒ D) : is_prop (full F) :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
by unfold full; exact _
|
|
|
|
|
|
2016-02-15 20:18:07 +00:00
|
|
|
|
theorem is_prop_faithful [instance] (F : C ⇒ D) : is_prop (faithful F) :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
by unfold faithful; exact _
|
|
|
|
|
|
2016-02-15 20:18:07 +00:00
|
|
|
|
theorem is_prop_essentially_surjective [instance] (F : C ⇒ D)
|
|
|
|
|
: is_prop (essentially_surjective F) :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
by unfold essentially_surjective; exact _
|
|
|
|
|
|
2016-02-15 20:18:07 +00:00
|
|
|
|
theorem is_prop_is_weak_equivalence [instance] (F : C ⇒ D) : is_prop (is_weak_equivalence F) :=
|
2015-10-20 01:42:41 +00:00
|
|
|
|
by unfold is_weak_equivalence; exact _
|
|
|
|
|
|
|
|
|
|
definition fully_faithful_equiv (F : C ⇒ D) : fully_faithful F ≃ (faithful F × full F) :=
|
2016-02-15 20:18:07 +00:00
|
|
|
|
equiv_of_is_prop (λH, (faithful_of_fully_faithful F, full_of_fully_faithful F))
|
2015-10-20 01:42:41 +00:00
|
|
|
|
(λH, fully_faithful_of_full_of_faithful (pr1 H) (pr2 H))
|
|
|
|
|
|
|
|
|
|
/- alternative proof using direct calculation with equivalences
|
|
|
|
|
|
|
|
|
|
definition fully_faithful_equiv (F : C ⇒ D) : fully_faithful F ≃ (faithful F × full F) :=
|
|
|
|
|
calc
|
|
|
|
|
fully_faithful F
|
|
|
|
|
≃ (Π(c c' : C), is_embedding (to_fun_hom F) × is_surjective (to_fun_hom F))
|
2016-02-15 21:05:31 +00:00
|
|
|
|
: pi_equiv_pi_right (λc, pi_equiv_pi_right
|
2015-10-20 01:42:41 +00:00
|
|
|
|
(λc', !is_equiv_equiv_is_embedding_times_is_surjective))
|
|
|
|
|
... ≃ (Π(c : C), (Π(c' : C), is_embedding (to_fun_hom F)) ×
|
|
|
|
|
(Π(c' : C), is_surjective (to_fun_hom F)))
|
2016-02-15 21:05:31 +00:00
|
|
|
|
: pi_equiv_pi_right (λc, !equiv_prod_corec)
|
2015-10-20 01:42:41 +00:00
|
|
|
|
... ≃ (Π(c c' : C), is_embedding (to_fun_hom F)) × full F
|
|
|
|
|
: equiv_prod_corec
|
|
|
|
|
... ≃ faithful F × full F
|
2016-02-15 21:05:31 +00:00
|
|
|
|
: prod_equiv_prod_right (pi_equiv_pi_right (λc, pi_equiv_pi_right
|
2015-10-20 01:42:41 +00:00
|
|
|
|
(λc', !is_embedding_equiv_is_injective)))
|
|
|
|
|
-/
|
|
|
|
|
|
|
|
|
|
end category
|