2014-08-25 02:58:48 +00:00
|
|
|
import logic
|
2014-08-20 22:49:44 +00:00
|
|
|
using tactic inhabited
|
2014-07-09 01:21:22 +00:00
|
|
|
|
2014-07-10 12:12:53 +00:00
|
|
|
inductive sum (A : Type) (B : Type) : Type :=
|
2014-08-22 22:46:10 +00:00
|
|
|
inl : A → sum A B,
|
|
|
|
inr : B → sum A B
|
2014-07-09 01:21:22 +00:00
|
|
|
|
|
|
|
theorem inl_inhabited {A : Type} (B : Type) (H : inhabited A) : inhabited (sum A B)
|
2014-08-20 22:49:44 +00:00
|
|
|
:= inhabited_destruct H (λ a, inhabited_mk (inl B a))
|
2014-07-09 01:21:22 +00:00
|
|
|
|
|
|
|
theorem inr_inhabited (A : Type) {B : Type} (H : inhabited B) : inhabited (sum A B)
|
2014-08-20 22:49:44 +00:00
|
|
|
:= inhabited_destruct H (λ b, inhabited_mk (inr A b))
|
2014-07-09 01:21:22 +00:00
|
|
|
|
|
|
|
infixl `..`:100 := append
|
|
|
|
|
|
|
|
definition my_tac := repeat (trace "iteration"; state;
|
|
|
|
( apply @inl_inhabited; trace "used inl"
|
|
|
|
.. apply @inr_inhabited; trace "used inr"
|
2014-08-20 22:49:44 +00:00
|
|
|
.. apply @num.num_inhabited; trace "used num")) ; now
|
2014-07-09 01:21:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
tactic_hint [inhabited] my_tac
|
|
|
|
|
|
|
|
theorem T : inhabited (sum false num.num)
|