refactor(kernel/metavar): remove unnecessary functionality
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
50f76fd138
commit
9517f31a71
4 changed files with 29 additions and 65 deletions
|
@ -83,7 +83,7 @@ substitution substitution::assign(name const & m, level const & l) const {
|
||||||
return assign(m, l, justification());
|
return assign(m, l, justification());
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<level, justification> substitution::d_instantiate_metavars(level const & l, bool use_jst, bool updt, name_set * unassigned) {
|
std::pair<level, justification> substitution::d_instantiate_metavars(level const & l, bool use_jst, bool updt) {
|
||||||
if (!has_meta(l))
|
if (!has_meta(l))
|
||||||
return mk_pair(l, justification());
|
return mk_pair(l, justification());
|
||||||
justification j;
|
justification j;
|
||||||
|
@ -94,7 +94,7 @@ std::pair<level, justification> substitution::d_instantiate_metavars(level const
|
||||||
} else if (is_meta(l)) {
|
} else if (is_meta(l)) {
|
||||||
auto p1 = get_assignment(l);
|
auto p1 = get_assignment(l);
|
||||||
if (p1) {
|
if (p1) {
|
||||||
auto p2 = d_instantiate_metavars(p1->first, use_jst, updt, unassigned);
|
auto p2 = d_instantiate_metavars(p1->first, use_jst, updt);
|
||||||
if (use_jst) {
|
if (use_jst) {
|
||||||
justification new_jst = mk_composite1(p1->second, p2.second);
|
justification new_jst = mk_composite1(p1->second, p2.second);
|
||||||
if (updt)
|
if (updt)
|
||||||
|
@ -104,8 +104,6 @@ std::pair<level, justification> substitution::d_instantiate_metavars(level const
|
||||||
d_assign(meta_id(l), p2.first);
|
d_assign(meta_id(l), p2.first);
|
||||||
}
|
}
|
||||||
return some_level(p2.first);
|
return some_level(p2.first);
|
||||||
} else if (unassigned) {
|
|
||||||
unassigned->insert(meta_id(l));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return none_level();
|
return none_level();
|
||||||
|
@ -119,13 +117,11 @@ protected:
|
||||||
justification m_jst;
|
justification m_jst;
|
||||||
bool m_use_jst;
|
bool m_use_jst;
|
||||||
bool m_update;
|
bool m_update;
|
||||||
name_set * m_unassigned_lvls;
|
|
||||||
name_set * m_unassigned_exprs;
|
|
||||||
|
|
||||||
void save_jst(justification const & j) { m_jst = mk_composite1(m_jst, j); }
|
void save_jst(justification const & j) { m_jst = mk_composite1(m_jst, j); }
|
||||||
|
|
||||||
level visit_level(level const & l) {
|
level visit_level(level const & l) {
|
||||||
auto p1 = m_subst.d_instantiate_metavars(l, m_use_jst, m_update, m_unassigned_lvls);
|
auto p1 = m_subst.d_instantiate_metavars(l, m_use_jst, m_update);
|
||||||
if (m_use_jst)
|
if (m_use_jst)
|
||||||
save_jst(p1.second);
|
save_jst(p1.second);
|
||||||
return p1.first;
|
return p1.first;
|
||||||
|
@ -153,19 +149,17 @@ protected:
|
||||||
return p1->first;
|
return p1->first;
|
||||||
} else if (m_use_jst) {
|
} else if (m_use_jst) {
|
||||||
if (m_update) {
|
if (m_update) {
|
||||||
auto p2 = m_subst.d_instantiate_metavars(p1->first, m_unassigned_lvls, m_unassigned_exprs);
|
auto p2 = m_subst.d_instantiate_metavars(p1->first);
|
||||||
justification new_jst = mk_composite1(p1->second, p2.second);
|
justification new_jst = mk_composite1(p1->second, p2.second);
|
||||||
m_subst.d_assign(m_name, p2.first, new_jst);
|
m_subst.d_assign(m_name, p2.first, new_jst);
|
||||||
save_jst(new_jst);
|
save_jst(new_jst);
|
||||||
return p2.first;
|
return p2.first;
|
||||||
} else {
|
} else {
|
||||||
auto p2 = m_subst.instantiate_metavars(p1->first, m_unassigned_lvls, m_unassigned_exprs);
|
auto p2 = m_subst.instantiate_metavars(p1->first);
|
||||||
save_jst(mk_composite1(p1->second, p2.second));
|
save_jst(mk_composite1(p1->second, p2.second));
|
||||||
return p2.first;
|
return p2.first;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lean_assert(m_unassigned_exprs == nullptr);
|
|
||||||
lean_assert(m_unassigned_lvls == nullptr);
|
|
||||||
if (m_update) {
|
if (m_update) {
|
||||||
expr r = m_subst.d_instantiate_metavars_wo_jst(p1->first);
|
expr r = m_subst.d_instantiate_metavars_wo_jst(p1->first);
|
||||||
m_subst.d_assign(m_name, r);
|
m_subst.d_assign(m_name, r);
|
||||||
|
@ -175,8 +169,6 @@ protected:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (m_unassigned_exprs)
|
|
||||||
m_unassigned_exprs->insert(m_name);
|
|
||||||
return m;
|
return m;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -207,54 +199,53 @@ protected:
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
instantiate_metavars_fn(substitution & s, bool use_jst, bool updt, name_set * unassigned_lvls, name_set * unassigned_exprs):
|
instantiate_metavars_fn(substitution & s, bool use_jst, bool updt):
|
||||||
m_subst(s), m_use_jst(use_jst), m_update(updt), m_unassigned_lvls(unassigned_lvls), m_unassigned_exprs(unassigned_exprs) {}
|
m_subst(s), m_use_jst(use_jst), m_update(updt) {}
|
||||||
justification const & get_justification() const { return m_jst; }
|
justification const & get_justification() const { return m_jst; }
|
||||||
};
|
};
|
||||||
|
|
||||||
std::pair<expr, justification> substitution::instantiate_metavars(expr const & e, name_set * unassigned_lvls, name_set * unassigned_exprs) const {
|
std::pair<expr, justification> substitution::instantiate_metavars(expr const & e) const {
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
instantiate_metavars_fn fn(s, true, false, unassigned_lvls, unassigned_exprs);
|
instantiate_metavars_fn fn(s, true, false);
|
||||||
expr r = fn(e);
|
expr r = fn(e);
|
||||||
return mk_pair(r, fn.get_justification());
|
return mk_pair(r, fn.get_justification());
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<expr, justification> substitution::d_instantiate_metavars(expr const & e, name_set * unassigned_lvls, name_set * unassigned_exprs) {
|
std::pair<expr, justification> substitution::d_instantiate_metavars(expr const & e) {
|
||||||
instantiate_metavars_fn fn(*this, true, true, unassigned_lvls, unassigned_exprs);
|
instantiate_metavars_fn fn(*this, true, true);
|
||||||
expr r = fn(e);
|
expr r = fn(e);
|
||||||
return mk_pair(r, fn.get_justification());
|
return mk_pair(r, fn.get_justification());
|
||||||
}
|
}
|
||||||
|
|
||||||
std::tuple<expr, justification, substitution> substitution::updt_instantiate_metavars(expr const & e, name_set * unassigned_lvls,
|
std::tuple<expr, justification, substitution> substitution::updt_instantiate_metavars(expr const & e) const {
|
||||||
name_set * unassigned_exprs) const {
|
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
instantiate_metavars_fn fn(s, true, true, unassigned_lvls, unassigned_exprs);
|
instantiate_metavars_fn fn(s, true, true);
|
||||||
expr r = fn(e);
|
expr r = fn(e);
|
||||||
return std::make_tuple(r, fn.get_justification(), s);
|
return std::make_tuple(r, fn.get_justification(), s);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<level, justification> substitution::instantiate_metavars(level const & l, name_set * unassigned) const {
|
std::pair<level, justification> substitution::instantiate_metavars(level const & l) const {
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
return s.d_instantiate_metavars(l, true, false, unassigned);
|
return s.d_instantiate_metavars(l, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
expr substitution::instantiate_metavars_wo_jst(expr const & e) const {
|
expr substitution::instantiate_metavars_wo_jst(expr const & e) const {
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
return instantiate_metavars_fn(s, false, false, nullptr, nullptr)(e);
|
return instantiate_metavars_fn(s, false, false)(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
expr substitution::d_instantiate_metavars_wo_jst(expr const & e) {
|
expr substitution::d_instantiate_metavars_wo_jst(expr const & e) {
|
||||||
return instantiate_metavars_fn(*this, false, true, nullptr, nullptr)(e);
|
return instantiate_metavars_fn(*this, false, true)(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<expr, substitution> substitution::updt_instantiate_metavars_wo_jst(expr const & e) const {
|
std::pair<expr, substitution> substitution::updt_instantiate_metavars_wo_jst(expr const & e) const {
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
return mk_pair(instantiate_metavars_fn(s, false, true, nullptr, nullptr)(e), s);
|
return mk_pair(instantiate_metavars_fn(s, false, true)(e), s);
|
||||||
}
|
}
|
||||||
|
|
||||||
level substitution::instantiate_metavars_wo_jst(level const & l) const {
|
level substitution::instantiate_metavars_wo_jst(level const & l) const {
|
||||||
substitution s(*this);
|
substitution s(*this);
|
||||||
return s.d_instantiate_metavars(l, false, false, nullptr).first;
|
return s.d_instantiate_metavars(l, false, false).first;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool substitution::occurs_expr(name const & m, expr const & e) const {
|
bool substitution::occurs_expr(name const & m, expr const & e) const {
|
||||||
|
|
|
@ -23,9 +23,9 @@ class substitution {
|
||||||
jst_map m_expr_jsts;
|
jst_map m_expr_jsts;
|
||||||
jst_map m_level_jsts;
|
jst_map m_level_jsts;
|
||||||
|
|
||||||
std::pair<expr, justification> d_instantiate_metavars(expr const & e, name_set * unassigned_lvls, name_set * unassigned_exprs);
|
std::pair<expr, justification> d_instantiate_metavars(expr const & e);
|
||||||
expr d_instantiate_metavars_wo_jst(expr const & e);
|
expr d_instantiate_metavars_wo_jst(expr const & e);
|
||||||
std::pair<level, justification> d_instantiate_metavars(level const & l, bool use_jst, bool updt, name_set * unassigned);
|
std::pair<level, justification> d_instantiate_metavars(level const & l, bool use_jst, bool updt);
|
||||||
friend class instantiate_metavars_fn;
|
friend class instantiate_metavars_fn;
|
||||||
|
|
||||||
justification get_expr_jst(name const & m) const { if (auto it = m_expr_jsts.find(m)) return *it; else return justification(); }
|
justification get_expr_jst(name const & m) const { if (auto it = m_expr_jsts.find(m)) return *it; else return justification(); }
|
||||||
|
@ -87,12 +87,8 @@ public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
\brief Instantiate metavariables in \c e assigned in this substitution.
|
\brief Instantiate metavariables in \c e assigned in this substitution.
|
||||||
|
|
||||||
\remark If \c unassigned_exprs and \c unassigned_lvls are not nullptr, then this method
|
|
||||||
stores unassigned metavariables in them.
|
|
||||||
*/
|
*/
|
||||||
std::pair<expr, justification> instantiate_metavars(expr const & e, name_set * unassigned_lvls = nullptr,
|
std::pair<expr, justification> instantiate_metavars(expr const & e) const;
|
||||||
name_set * unassigned_exprs = nullptr) const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
\brief Similar to the previous function, but it compress the substitution.
|
\brief Similar to the previous function, but it compress the substitution.
|
||||||
|
@ -100,15 +96,10 @@ public:
|
||||||
if s[m] = t, and t has asssigned metavariables, then s[m] <- instantiate_metavars(t, s).
|
if s[m] = t, and t has asssigned metavariables, then s[m] <- instantiate_metavars(t, s).
|
||||||
The updated substitution is returned.
|
The updated substitution is returned.
|
||||||
*/
|
*/
|
||||||
std::tuple<expr, justification, substitution> updt_instantiate_metavars(expr const & e, name_set * unassigned_lvls = nullptr,
|
std::tuple<expr, justification, substitution> updt_instantiate_metavars(expr const & e) const;
|
||||||
name_set * unassigned_exprs = nullptr) const;
|
|
||||||
|
|
||||||
/**
|
/** \brief Instantiate level metavariables in \c l. */
|
||||||
\brief Instantiate level metavariables in \c l.
|
std::pair<level, justification> instantiate_metavars(level const & l) const;
|
||||||
|
|
||||||
\remark If \c unassigned is not nullptr, then store unassigned meta universe parameters in it.
|
|
||||||
*/
|
|
||||||
std::pair<level, justification> instantiate_metavars(level const & l, name_set * unassigned = nullptr) const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
\brief Instantiate metavariables in \c e assigned in the substitution \c s,
|
\brief Instantiate metavariables in \c e assigned in the substitution \c s,
|
||||||
|
|
|
@ -760,7 +760,7 @@ struct unifier_fn {
|
||||||
lean_assert(is_choice_cnstr(c));
|
lean_assert(is_choice_cnstr(c));
|
||||||
expr const & m = cnstr_expr(c);
|
expr const & m = cnstr_expr(c);
|
||||||
choice_fn const & fn = cnstr_choice_fn(c);
|
choice_fn const & fn = cnstr_choice_fn(c);
|
||||||
auto m_type_jst = m_subst.instantiate_metavars(m_tc->infer(m), nullptr, nullptr);
|
auto m_type_jst = m_subst.instantiate_metavars(m_tc->infer(m));
|
||||||
lazy_list<constraints> alts = fn(m, m_type_jst.first, m_subst, m_ngen.mk_child());
|
lazy_list<constraints> alts = fn(m, m_type_jst.first, m_subst, m_ngen.mk_child());
|
||||||
return process_lazy_constraints(alts, mk_composite1(c.get_justification(), m_type_jst.second));
|
return process_lazy_constraints(alts, mk_composite1(c.get_justification(), m_type_jst.second));
|
||||||
}
|
}
|
||||||
|
|
|
@ -143,36 +143,18 @@ static void tst4() {
|
||||||
level l1 = mk_meta_univ("l1");
|
level l1 = mk_meta_univ("l1");
|
||||||
level u = mk_global_univ("u");
|
level u = mk_global_univ("u");
|
||||||
substitution s;
|
substitution s;
|
||||||
name_set exprs;
|
|
||||||
name_set lvls;
|
|
||||||
expr f = Const("f");
|
expr f = Const("f");
|
||||||
expr g = Const("g");
|
expr g = Const("g");
|
||||||
expr a = Const("a");
|
expr a = Const("a");
|
||||||
expr T1 = mk_sort(l1);
|
expr T1 = mk_sort(l1);
|
||||||
expr T2 = mk_sort(u);
|
expr T2 = mk_sort(u);
|
||||||
expr t = f(T1, T2, m1, m2);
|
expr t = f(T1, T2, m1, m2);
|
||||||
lean_assert(s.instantiate_metavars(t, &lvls, &exprs).first == t);
|
lean_assert(s.instantiate_metavars(t).first == t);
|
||||||
lean_assert(exprs.contains("m1"));
|
|
||||||
lean_assert(exprs.contains("m2"));
|
|
||||||
lean_assert(!exprs.contains("m3"));
|
|
||||||
lean_assert(lvls.contains("l1"));
|
|
||||||
s = s.assign(m1, a, justification());
|
s = s.assign(m1, a, justification());
|
||||||
s = s.assign(m2, m3, justification());
|
s = s.assign(m2, m3, justification());
|
||||||
lvls = name_set();
|
lean_assert(s.instantiate_metavars(t).first == f(T1, T2, a, m3));
|
||||||
exprs = name_set();
|
|
||||||
lean_assert(s.instantiate_metavars(t, &lvls, &exprs).first == f(T1, T2, a, m3));
|
|
||||||
lean_assert(!exprs.contains("m1"));
|
|
||||||
lean_assert(!exprs.contains("m2"));
|
|
||||||
lean_assert(exprs.contains("m3"));
|
|
||||||
lean_assert(lvls.contains("l1"));
|
|
||||||
s = s.assign(l1, level(), justification());
|
s = s.assign(l1, level(), justification());
|
||||||
lvls = name_set();
|
lean_assert(s.instantiate_metavars(t).first == f(Bool, T2, a, m3));
|
||||||
exprs = name_set();
|
|
||||||
lean_assert(s.instantiate_metavars(t, &lvls, &exprs).first == f(Bool, T2, a, m3));
|
|
||||||
lean_assert(!exprs.contains("m1"));
|
|
||||||
lean_assert(!exprs.contains("m2"));
|
|
||||||
lean_assert(exprs.contains("m3"));
|
|
||||||
lean_assert(!lvls.contains("l1"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
|
Loading…
Reference in a new issue