From 1e2d4cbdd88c8deeeaa32020fe396b79315539be Mon Sep 17 00:00:00 2001 From: Georgy Lukyanov Date: Thu, 31 Oct 2024 12:35:22 +0100 Subject: [PATCH] Assume the rule remainder condition when checking ensures --- booster/library/Booster/Pattern/Rewrite.hs | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/booster/library/Booster/Pattern/Rewrite.hs b/booster/library/Booster/Pattern/Rewrite.hs index 0c60754a7e..920c8ea18e 100644 --- a/booster/library/Booster/Pattern/Rewrite.hs +++ b/booster/library/Booster/Pattern/Rewrite.hs @@ -460,7 +460,10 @@ applyRule pat@Pattern{ceilConditions} rule = -- check ensures constraints (new) from rhs: stop and return `Trivial` if -- any are false, remove all that are trivially true, return the rest - ensuredConditions <- checkEnsures ruleSubstitution + -- + -- we need to add unclearRequiresAfterSmt (if any) as additional known truth, + -- as it may allow us to prune a vacuous state + ensuredConditions <- checkEnsures ruleSubstitution unclearRequiresAfterSmt -- if a new constraint is going to be added, the equation cache is invalid unless (null ensuredConditions) $ do @@ -603,12 +606,15 @@ applyRule pat@Pattern{ceilConditions} rule = SMT.IsValid -> pure [] -- can proceed checkEnsures :: - Substitution -> RewriteRuleAppT (RewriteT io) [Predicate] - checkEnsures matchingSubst = do + Substitution -> [Predicate] -> RewriteRuleAppT (RewriteT io) [Predicate] + checkEnsures matchingSubst unclearRequiresAfterSmt = do -- apply substitution to rule ensures let ruleEnsures = concatMap (splitBoolPredicates . coerce . substituteInTerm matchingSubst . coerce) rule.ensures - knownConstraints = pat.constraints <> (Set.fromList . asEquations $ pat.substitution) + knownConstraints = + pat.constraints + <> (Set.fromList . asEquations $ pat.substitution) + <> Set.fromList unclearRequiresAfterSmt newConstraints <- catMaybes <$> mapM