Skip to content

Commit

Permalink
Assume the rule remainder condition when checking ensures
Browse files Browse the repository at this point in the history
  • Loading branch information
geo2a committed Oct 31, 2024
1 parent b7a6b36 commit 5d5ec32
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions booster/library/Booster/Pattern/Rewrite.hs
Original file line number Diff line number Diff line change
Expand Up @@ -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 prone 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
Expand Down Expand Up @@ -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
Expand Down

0 comments on commit 5d5ec32

Please sign in to comment.