From e01b5dc56194bfd73ae2f2d120a135333387fecc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Patrick=20L=C3=BChne?= Date: Sun, 25 Mar 2018 20:35:22 +0200 Subject: [PATCH] Move simplification rule to tableau MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This moves the rule “[primitive A] in [primitive B] === A = B” to the simplification rule tableau. --- src/anthem/Simplification.cpp | 33 ++++++++++++++++++++++++++------- 1 file changed, 26 insertions(+), 7 deletions(-) diff --git a/src/anthem/Simplification.cpp b/src/anthem/Simplification.cpp index 29eeb5d..2f2ab52 100644 --- a/src/anthem/Simplification.cpp +++ b/src/anthem/Simplification.cpp @@ -317,6 +317,30 @@ struct SimplificationRuleTrivialExists //////////////////////////////////////////////////////////////////////////////////////////////////// +struct SimplificationRuleInWithPrimitiveArguments +{ + static constexpr const auto Description = "[primitive A] in [primitive B] === A = B"; + + static SimplificationResult apply(ast::Formula &formula) + { + if (!formula.is()) + return SimplificationResult::Unchanged; + + auto &in = formula.get(); + + assert(ast::isPrimitive(in.element)); + + if (!ast::isPrimitive(in.element) || !ast::isPrimitive(in.set)) + return SimplificationResult::Unchanged; + + formula = ast::Comparison(ast::Comparison::Operator::Equal, std::move(in.element), std::move(in.set)); + + return SimplificationResult::Simplified; + } +}; + +//////////////////////////////////////////////////////////////////////////////////////////////////// + void simplify(ast::Exists &exists, ast::Formula &formula) { SimplificationRuleTrivialAssignmentInExists::apply(formula); @@ -341,14 +365,9 @@ struct SimplifyFormulaVisitor : public ast::RecursiveFormulaVisitor