feat(library/data/axioms): add 'type_decidable'

In Lean standard mode, Hilbert choice implies that all types are
decidable.
This commit is contained in:
Leonardo de Moura 2015-06-14 17:33:22 -07:00
parent ef4b4d19ce
commit ff5022c2f4

View file

@ -5,8 +5,8 @@ Author: Leonardo de Moura
Excluded middle + Hilbert implies every proposition is decidable. Excluded middle + Hilbert implies every proposition is decidable.
-/ -/
import logic.axioms.prop_complete logic.axioms.hilbert import logic.axioms.prop_complete logic.axioms.hilbert data.sum
open decidable inhabited nonempty open decidable inhabited nonempty sum
theorem decidable_inhabited [instance] (a : Prop) : inhabited (decidable a) := theorem decidable_inhabited [instance] (a : Prop) : inhabited (decidable a) :=
inhabited_of_nonempty inhabited_of_nonempty
@ -16,3 +16,9 @@ inhabited_of_nonempty
theorem prop_decidable [instance] (a : Prop) : decidable a := theorem prop_decidable [instance] (a : Prop) : decidable a :=
arbitrary (decidable a) arbitrary (decidable a)
theorem type_decidable (A : Type) : A + (A → false) :=
match prop_decidable (nonempty A) with
| inl Hp := sum.inl (inhabited.value (inhabited_of_nonempty Hp))
| inr Hn := sum.inr (λ a, absurd (nonempty.intro a) Hn)
end