From e7385d60fbfb5f9fd1ea862f10acedb56327c81c Mon Sep 17 00:00:00 2001 From: Nikolaj Bjorner Date: Sun, 21 Jun 2015 13:49:15 -0700 Subject: [PATCH] fixes to githup issue #133 and stackoverflow reported bug on assertion violation in poly_simplifier_plugin Signed-off-by: Nikolaj Bjorner --- src/ast/simplifier/poly_simplifier_plugin.cpp | 10 ++++++++-- src/opt/opt_solver.cpp | 4 +++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/src/ast/simplifier/poly_simplifier_plugin.cpp b/src/ast/simplifier/poly_simplifier_plugin.cpp index d64123e7bf2..c5dc275fd58 100644 --- a/src/ast/simplifier/poly_simplifier_plugin.cpp +++ b/src/ast/simplifier/poly_simplifier_plugin.cpp @@ -69,14 +69,20 @@ expr * poly_simplifier_plugin::mk_mul(unsigned num_args, expr * const * args) { } expr * poly_simplifier_plugin::mk_mul(numeral const & c, expr * body) { - numeral c_prime; + numeral c_prime, d; c_prime = norm(c); if (c_prime.is_zero()) return 0; if (body == 0) return mk_numeral(c_prime); if (c_prime.is_one()) - return body; + return body; + if (is_numeral(body, d)) { + c_prime = norm(c_prime*d); + if (c_prime.is_zero()) + return 0; + return mk_numeral(c_prime); + } set_curr_sort(body); expr * args[2] = { mk_numeral(c_prime), body }; return mk_mul(2, args); diff --git a/src/opt/opt_solver.cpp b/src/opt/opt_solver.cpp index dcbbc3faed1..bf7a394241e 100644 --- a/src/opt/opt_solver.cpp +++ b/src/opt/opt_solver.cpp @@ -46,7 +46,9 @@ namespace opt { m_dump_benchmarks(false), m_first(true) { m_params.updt_params(p); - m_params.m_relevancy_lvl = 0; + if (m_params.m_case_split_strategy == CS_ACTIVITY_DELAY_NEW) { + m_params.m_relevancy_lvl = 0; + } } unsigned opt_solver::m_dump_count = 0;