Mark implicit arguments of builtin symbols

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-08-30 15:56:04 -07:00
parent 4ef4655183
commit 1b6d51b0aa
5 changed files with 42 additions and 20 deletions

View file

@ -21,6 +21,6 @@ Eval true => a
(* Simple proof *) (* Simple proof *)
Axiom H1 : a Axiom H1 : a
Axiom H2 : a => b Axiom H2 : a => b
Check MP Check MP::explicit
Show MP a b H2 H1 Show MP H2 H1
Check MP a b H2 H1 Check MP H2 H1

View file

@ -10,27 +10,15 @@ Variable EqNice {A : Type} (lhs rhs : A) : Bool
Infix 50 === : EqNice Infix 50 === : EqNice
Show n1 === n2 Show n1 === n2
Check f n1 n2 Check f n1 n2
Check Congr Check Congr::explicit
Show f n1 n2 Show f n1 n2
Theorem CongrI {A : Type u} {B : A → Type u} {f g : Π x : A, B x} {a b : A} (H1 : f = g) (H2 : a = b) : (f a) = (g b) :=
Congr A B f g a b H1 H2
Theorem TransI {A : Type u} {a b c : A} (H1 : a = b) (H2 : b = c) : a = c :=
Trans A a b c H1 H2
Theorem ReflI {A : Type u} (a : A) : a = a :=
Refl A a
Theorem SymmI {A : Type u} {a b : A} (H : a = b) : b = a :=
Symm A a b H
Theorem Conj1I {a b : Bool} (H : a && b) : a :=
Conjunct1 a b H
Theorem Conj2I {a b : Bool} (H : a && b) : b :=
Conjunct2 a b H
Variable a : N Variable a : N
Variable b : N Variable b : N
Variable c : N Variable c : N
Variable g : N -> N Variable g : N -> N
Axiom H1 : a = b && b = c Axiom H1 : a = b && b = c
Theorem Pr : (g a) = (g c) := Theorem Pr : (g a) = (g c) :=
CongrI (ReflI g) (TransI (Conj1I H1) (Conj2I H1)) Congr (Refl g) (Trans (Conjunct1 H1) (Conjunct2 H1))
Show Environment 1 Show Environment 2

View file

@ -5,7 +5,7 @@ Eval xor true true
Eval xor true false Eval xor true false
Variable a : Bool Variable a : Bool
Show a ⊕ a ⊕ a Show a ⊕ a ⊕ a
Check Subst Check Subst::explicit
Theorem EM2 (a : Bool) : a \/ (not a) := Theorem EM2 (a : Bool) : a \/ (not a) :=
Case (fun x : Bool, x \/ (not x)) Trivial Trivial a Case (fun x : Bool, x \/ (not x)) Trivial Trivial a
Check EM2 Check EM2

View file

@ -126,6 +126,7 @@ public:
*/ */
void mark_implicit_arguments(name const & n, unsigned sz, bool const * mask); void mark_implicit_arguments(name const & n, unsigned sz, bool const * mask);
void mark_implicit_arguments(name const & n, std::initializer_list<bool> const & l); void mark_implicit_arguments(name const & n, std::initializer_list<bool> const & l);
void mark_implicit_arguments(expr const & n, std::initializer_list<bool> const & l) { mark_implicit_arguments(const_name(n), l); }
/** \brief Return true iff \c n has implicit arguments */ /** \brief Return true iff \c n has implicit arguments */
bool has_implicit_arguments(name const & n) const; bool has_implicit_arguments(name const & n) const;
/** \brief Return the position of the arguments that are implicit. */ /** \brief Return the position of the arguments that are implicit. */

View file

@ -5,6 +5,7 @@ Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura Author: Leonardo de Moura
*/ */
#include "builtin.h" #include "builtin.h"
#include "basic_thms.h"
#include "lean_frontend.h" #include "lean_frontend.h"
namespace lean { namespace lean {
@ -12,7 +13,7 @@ namespace lean {
\brief Initialize builtin notation. \brief Initialize builtin notation.
*/ */
void init_builtin_notation(frontend & f) { void init_builtin_notation(frontend & f) {
f.mark_implicit_arguments("heq", {true, false, false}); f.mark_implicit_arguments(mk_homo_eq_fn(), {true, false, false});
f.add_infix("==", 50, mk_homo_eq_fn()); f.add_infix("==", 50, mk_homo_eq_fn());
f.add_infix("", 50, mk_homo_eq_fn()); f.add_infix("", 50, mk_homo_eq_fn());
@ -27,5 +28,37 @@ void init_builtin_notation(frontend & f) {
f.add_infixr("\u21D2", 25, mk_implies_fn()); // "⇒" f.add_infixr("\u21D2", 25, mk_implies_fn()); // "⇒"
f.add_infixr("<=>", 25, mk_iff_fn()); // "<=>" f.add_infixr("<=>", 25, mk_iff_fn()); // "<=>"
f.add_infixr("\u21D4", 25, mk_iff_fn()); // "⇔" f.add_infixr("\u21D4", 25, mk_iff_fn()); // "⇔"
// implicit arguments for builtin axioms
f.mark_implicit_arguments(mk_mp_fn(), {true, true, false, false});
f.mark_implicit_arguments(mk_discharge_fn(), {true, true, false});
f.mark_implicit_arguments(mk_refl_fn(), {true, false});
f.mark_implicit_arguments(mk_subst_fn(), {true, true, true, false, false, false});
f.mark_implicit_arguments(mk_eta_fn(), {true, true, false});
f.mark_implicit_arguments(mk_imp_antisym_fn(), {true, true, false, false});
// implicit arguments for basic theorems
f.mark_implicit_arguments(mk_absurd_fn(), {true, false, false});
f.mark_implicit_arguments(mk_double_neg_elim_fn(), {true, true, false});
f.mark_implicit_arguments(mk_mt_fn(), {true, true, false, false});
f.mark_implicit_arguments(mk_contrapos_fn(), {true, true, false});
f.mark_implicit_arguments(mk_eq_mp_fn(), {true, true, false, false});
f.mark_implicit_arguments(mk_not_imp1_fn(), {true, true, false});
f.mark_implicit_arguments(mk_not_imp2_fn(), {true, true, false});
f.mark_implicit_arguments(mk_conj_fn(), {true, true, false, false});
f.mark_implicit_arguments(mk_conjunct1_fn(), {true, true, false});
f.mark_implicit_arguments(mk_conjunct2_fn(), {true, true, false});
f.mark_implicit_arguments(mk_disj1_fn(), {true, false, false});
f.mark_implicit_arguments(mk_disj2_fn(), {true, false, false});
f.mark_implicit_arguments(mk_disj_cases_fn(), {true, true, true, false, false, false});
f.mark_implicit_arguments(mk_symm_fn(), {true, true, true, false});
f.mark_implicit_arguments(mk_trans_fn(), {true, true, true, true, false, false});
f.mark_implicit_arguments(mk_trans_ext_fn(), {true, true, true, true, true, false, false});
f.mark_implicit_arguments(mk_eqt_elim_fn(), {true, false});
f.mark_implicit_arguments(mk_eqt_intro_fn(), {true, false});
f.mark_implicit_arguments(mk_congr1_fn(), {true, true, true, true, false, false});
f.mark_implicit_arguments(mk_congr2_fn(), {true, true, true, true, false, false});
f.mark_implicit_arguments(mk_congr_fn(), {true, true, true, true, true, true, false, false});
f.mark_implicit_arguments(mk_forall_elim_fn(), {true, true, false, false});
} }
} }