feat(library/data/axioms): add 'type_decidable'
In Lean standard mode, Hilbert choice implies that all types are decidable.
This commit is contained in:
parent
ef4b4d19ce
commit
ff5022c2f4
1 changed files with 8 additions and 2 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue