Correctness proof for SUB(NOT(0),X)->NOT(X).

This commit is contained in:
Daniel Kirchner 2019-06-14 14:08:21 +02:00
parent 7f322c9433
commit d3293cf0d0

View File

@ -0,0 +1,26 @@
from rule import Rule
from opcodes import *
"""
Rule:
SUB(~0, X) -> NOT(X)
Requirements:
"""
rule = Rule()
n_bits = 256
# Input vars
X = BitVec('X', n_bits)
# Constants
ZERO = BitVecVal(0, n_bits)
# Non optimized result
nonopt = SUB(~ZERO, X)
# Optimized result
opt = NOT(X)
rule.check(nonopt, opt)