feat(library/unifier): option 'unifier.computation true' will force elaborator to always consider an extra case-split when the right-hand-side of a flex-rigid constraint is not in weak-head-normal-form

This commit is contained in:
Leonardo de Moura 2014-09-09 08:40:16 -07:00
parent d9afb3ca96
commit ebde1bcfad

View file

@ -33,7 +33,7 @@ Author: Leonardo de Moura
#endif #endif
#ifndef LEAN_DEFAULT_UNIFIER_COMPUTATION #ifndef LEAN_DEFAULT_UNIFIER_COMPUTATION
#define LEAN_DEFAULT_UNIFIER_COMPUTATION true #define LEAN_DEFAULT_UNIFIER_COMPUTATION false
#endif #endif
#ifndef LEAN_DEFAULT_UNIFIER_EXPENSIVE_CLASSES #ifndef LEAN_DEFAULT_UNIFIER_EXPENSIVE_CLASSES
@ -47,7 +47,7 @@ unsigned get_unifier_max_steps(options const & opts) { return opts.get_unsigned(
static name g_unifier_computation {"unifier", "computation"}; static name g_unifier_computation {"unifier", "computation"};
RegisterBoolOption(g_unifier_computation, LEAN_DEFAULT_UNIFIER_COMPUTATION, RegisterBoolOption(g_unifier_computation, LEAN_DEFAULT_UNIFIER_COMPUTATION,
"(unifier) case-split on reduction/computational steps when solving flex-rigid constraints"); "(unifier) always case-split on reduction/computational steps when solving flex-rigid constraints");
bool get_unifier_computation(options const & opts) { return opts.get_bool(g_unifier_computation, LEAN_DEFAULT_UNIFIER_COMPUTATION); } bool get_unifier_computation(options const & opts) { return opts.get_bool(g_unifier_computation, LEAN_DEFAULT_UNIFIER_COMPUTATION); }
static name g_unifier_expensive_classes {"unifier", "expensive_classes"}; static name g_unifier_expensive_classes {"unifier", "expensive_classes"};
@ -1700,7 +1700,7 @@ struct unifier_fn {
buffer<constraints> alts; buffer<constraints> alts;
process_flex_rigid_core(lhs, rhs, j, relax, alts); process_flex_rigid_core(lhs, rhs, j, relax, alts);
append_auxiliary_constraints(alts, to_list(aux.begin(), aux.end())); append_auxiliary_constraints(alts, to_list(aux.begin(), aux.end()));
if (!all_local(lhs)) { if (m_config.m_computation || !all_local(lhs)) {
expr rhs_whnf = whnf(rhs, j, relax, aux); expr rhs_whnf = whnf(rhs, j, relax, aux);
if (rhs_whnf != rhs) { if (rhs_whnf != rhs) {
if (is_meta(rhs_whnf)) { if (is_meta(rhs_whnf)) {