2014-12-22 20:33:29 +00:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Author: Leonardo de Moura, Jeremy Avigad
|
|
|
|
-/
|
2015-08-13 01:37:33 +00:00
|
|
|
prelude
|
|
|
|
import init.datatypes init.logic
|
2014-09-03 23:00:38 +00:00
|
|
|
open decidable
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2014-12-09 20:40:09 +00:00
|
|
|
set_option structure.proj_mk_thm true
|
|
|
|
|
2014-11-16 22:19:35 +00:00
|
|
|
structure subtype {A : Type} (P : A → Prop) :=
|
|
|
|
tag :: (elt_of : A) (has_property : P elt_of)
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2015-07-31 18:27:38 +00:00
|
|
|
notation `{` binder `|` r:(scoped:1 P, subtype P) `}` := r
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2015-07-17 02:48:33 +00:00
|
|
|
definition ex_of_sub {A : Type} {P : A → Prop} : { x | P x } → ∃ x, P x
|
|
|
|
| (subtype.tag a h) := exists.intro a h
|
|
|
|
|
2014-08-15 03:12:54 +00:00
|
|
|
namespace subtype
|
2014-10-09 14:13:06 +00:00
|
|
|
variables {A : Type} {P : A → Prop}
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2014-09-02 02:04:15 +00:00
|
|
|
theorem tag_irrelevant {a : A} (H1 H2 : P a) : tag a H1 = tag a H2 :=
|
|
|
|
rfl
|
2014-08-15 03:12:54 +00:00
|
|
|
|
|
|
|
theorem tag_eq {a1 a2 : A} {H1 : P a1} {H2 : P a2} (H3 : a1 = a2) : tag a1 H1 = tag a2 H2 :=
|
2015-07-24 15:56:18 +00:00
|
|
|
eq.subst H3 (tag_irrelevant H1) H2
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2015-07-24 15:56:18 +00:00
|
|
|
protected theorem eq : ∀ {a1 a2 : {x | P x}} (H : elt_of a1 = elt_of a2), a1 = a2
|
|
|
|
| (tag x1 H1) (tag x2 H2) := tag_eq
|
2014-08-15 03:12:54 +00:00
|
|
|
|
2014-11-16 22:19:35 +00:00
|
|
|
protected definition is_inhabited [instance] {a : A} (H : P a) : inhabited {x | P x} :=
|
2014-09-04 23:36:06 +00:00
|
|
|
inhabited.mk (tag a H)
|
2014-08-22 00:54:50 +00:00
|
|
|
|
2015-05-04 04:40:33 +00:00
|
|
|
protected definition has_decidable_eq [instance] [H : decidable_eq A] : ∀ s₁ s₂ : {x | P x}, decidable (s₁ = s₂)
|
|
|
|
| (tag v₁ p₁) (tag v₂ p₂) :=
|
2015-07-24 15:56:18 +00:00
|
|
|
decidable_of_decidable_of_iff (H v₁ v₂)
|
|
|
|
(iff.intro tag_eq (λh, subtype.no_confusion h (λa b, a)))
|
2014-08-22 00:54:50 +00:00
|
|
|
end subtype
|