-
Notifications
You must be signed in to change notification settings - Fork 13
Open
Description
kontrol merge-nodes can run into an issue where one branch simplifies an expression and the other doesn't, which causes problems when the two branches are merged. For example, the following happens when trying to use it for the test in PR #162:
- One of the side conditions
Cin our configuration contains the subexpressionX modInt 2 ==Int 0. - We branch on the condition
X /Int 2 ==Int 0. - In the branch where
X /Int 2 ==Int 0,X modInt 2 ==Int 0can be simplified toX ==Int 0. This turnsCinto a different side conditionC'. - In the branch where
X /Int 2 =/=Int 0, the simplification doesn't apply, so it remains asC. - As a result, when we merge the two nodes, instead of getting
C #And ( ( X /Int 2 =/=Int 0 andBool B ) orBool ( X /Int 2 ==Int 0 andBool B' ) )(whereBandB'are the constraints that are different between the two branches) we instead get( ( X /Int 2 =/=Int 0 andBool B andBool C ) orBool ( X /Int 2 ==Int 0 andBool B' andBool C' ) ).
Because this can happen when C is alread a merged expression like (P andBool Q) orBool (notBool P andBool Q'), this can quickly compound over multiple applications of merge-nodes and grow into a large unreadable expression with multiple nested andBool and orBool operators.
What can we do about this?
- While we can write a lemma to turn
( ( X /Int 2 =/=Int 0 andBool B andBool C ) orBool ( X /Int 2 ==Int 0 andBool B' andBool C' ) )back intoC #And ( ( X /Int 2 =/=Int 0 andBool B ) orBool ( X /Int 2 ==Int 0 andBool B' ) ), this lemma is both very complex and very non-generalizable (we would need to write a different lemma for every case). So this approach doesn't seem ideal. - If we were able to specify what we want our merged node to look like, Kontrol should be able to determine that it subsumes both of the individual nodes being merged. This is similar to a loop invariant, and if we implement a way to specify loop invariants as annotations in the Solidity code, that functionality can probably also be used for this.
Metadata
Metadata
Assignees
Labels
No labels