2015-02-26 13:19:54 -05:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Jakob von Raumer. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
2015-04-24 19:58:50 -04:00
|
|
|
Module: init.ua
|
2015-02-26 13:19:54 -05:00
|
|
|
Author: Jakob von Raumer
|
|
|
|
|
|
|
|
Ported from Coq HoTT
|
|
|
|
-/
|
|
|
|
|
2014-12-12 13:17:50 -05:00
|
|
|
prelude
|
2015-04-24 19:58:50 -04:00
|
|
|
import .equiv
|
2015-04-27 17:39:23 -04:00
|
|
|
open eq equiv is_equiv equiv.ops
|
2014-12-11 23:14:53 -05:00
|
|
|
|
|
|
|
--Ensure that the types compared are in the same universe
|
|
|
|
section
|
|
|
|
universe variable l
|
|
|
|
variables {A B : Type.{l}}
|
|
|
|
|
2015-04-27 17:39:23 -04:00
|
|
|
definition is_equiv_cast_of_eq (H : A = B) : is_equiv (cast H) :=
|
2015-02-20 19:30:32 -05:00
|
|
|
(@is_equiv_tr Type (λX, X) A B H)
|
2014-12-11 23:14:53 -05:00
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
definition equiv_of_eq (H : A = B) : A ≃ B :=
|
2015-04-27 17:39:23 -04:00
|
|
|
equiv.mk _ (is_equiv_cast_of_eq H)
|
2014-12-11 23:14:53 -05:00
|
|
|
|
|
|
|
end
|
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
axiom univalence (A B : Type) : is_equiv (@equiv_of_eq A B)
|
2014-12-11 23:14:53 -05:00
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
attribute univalence [instance]
|
2014-12-11 23:14:53 -05:00
|
|
|
|
2014-12-17 11:58:47 -05:00
|
|
|
-- This is the version of univalence axiom we will probably use most often
|
2015-04-27 17:39:23 -04:00
|
|
|
definition ua [reducible] {A B : Type} : A ≃ B → A = B :=
|
|
|
|
equiv_of_eq⁻¹
|
|
|
|
|
2015-04-28 17:31:26 -04:00
|
|
|
definition eq_equiv_equiv (A B : Type) : (A = B) ≃ (A ≃ B) :=
|
|
|
|
equiv.mk equiv_of_eq _
|
|
|
|
|
2015-04-27 17:39:23 -04:00
|
|
|
definition equiv_of_eq_ua [reducible] {A B : Type} (f : A ≃ B) : equiv_of_eq (ua f) = f :=
|
|
|
|
right_inv equiv_of_eq f
|
|
|
|
|
|
|
|
definition cast_ua_fn {A B : Type} (f : A ≃ B) : cast (ua f) = f :=
|
|
|
|
ap to_fun (equiv_of_eq_ua f)
|
|
|
|
|
|
|
|
definition cast_ua {A B : Type} (f : A ≃ B) (a : A) : cast (ua f) a = f a :=
|
|
|
|
ap10 (cast_ua_fn f) a
|
|
|
|
|
|
|
|
definition ua_equiv_of_eq [reducible] {A B : Type} (p : A = B) : ua (equiv_of_eq p) = p :=
|
|
|
|
left_inv equiv_of_eq p
|
|
|
|
|
2014-12-11 23:14:53 -05:00
|
|
|
|
|
|
|
-- One consequence of UA is that we can transport along equivalencies of types
|
2015-02-20 19:30:32 -05:00
|
|
|
namespace equiv
|
2014-12-11 23:14:53 -05:00
|
|
|
universe variable l
|
|
|
|
|
2015-05-02 15:15:35 -07:00
|
|
|
protected definition transport_of_equiv [subst] (P : Type → Type) {A B : Type.{l}} (H : A ≃ B)
|
2014-12-17 11:58:47 -05:00
|
|
|
: P A → P B :=
|
|
|
|
eq.transport P (ua H)
|
2014-12-11 23:14:53 -05:00
|
|
|
|
|
|
|
-- We can use this for calculation evironments
|
|
|
|
|
2015-03-13 10:32:48 -04:00
|
|
|
definition rec_on_of_equiv_of_eq {A B : Type} {P : (A ≃ B) → Type}
|
|
|
|
(p : A ≃ B) (H : Π(q : A = B), P (equiv_of_eq q)) : P p :=
|
2015-04-27 15:39:36 -04:00
|
|
|
right_inv equiv_of_eq p ▹ H (ua p)
|
2015-03-13 10:32:48 -04:00
|
|
|
|
2015-02-20 19:30:32 -05:00
|
|
|
end equiv
|