lean2/hott/init/axioms/funext.hlean

29 lines
836 B
Text
Raw Normal View History

2014-12-11 23:14:53 -05:00
-- Copyright (c) 2014 Microsoft Corporation. All rights reserved.
-- Released under Apache 2.0 license as described in the file LICENSE.
-- Author: Jeremy Avigad, Jakob von Raumer
-- Ported from Coq HoTT
2014-12-12 13:17:50 -05:00
prelude
import ..path ..equiv
open eq
2014-12-11 23:14:53 -05:00
-- Funext
-- ------
-- Define function extensionality as a type class
structure funext [class] : Type :=
(elim : Π (A : Type) (P : A → Type ) (f g : Π x, P x), is_equiv (@apD10 A P f g))
2014-12-11 23:14:53 -05:00
namespace funext
2014-12-11 23:14:53 -05:00
attribute elim [instance]
2014-12-11 23:14:53 -05:00
definition eq_of_homotopy [F : funext] {A : Type} {P : A → Type} {f g : Π x, P x} : f g → f = g :=
2014-12-11 23:14:53 -05:00
is_equiv.inv (@apD10 A P f g)
definition eq_of_homotopy2 [F : funext] {A B : Type} {P : A → B → Type}
2014-12-12 13:17:50 -05:00
(f g : Πx y, P x y) : (Πx y, f x y = g x y) → f = g :=
λ E, eq_of_homotopy (λx, eq_of_homotopy (E x))
2014-12-11 23:14:53 -05:00
end funext