|
@ -10,43 +10,42 @@ EXAMPLE_DIR= "/Users/mvolk/develop/storm/examples/dft/" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
benchmarks = [ |
|
|
benchmarks = [ |
|
|
("and", False, 3), |
|
|
|
|
|
("and_param", True, "(4*x^2+2*x+1)/((x) * (2*x+1))"), |
|
|
|
|
|
("cm2", False, 0.256272), |
|
|
|
|
|
#("cm4", False, 0), |
|
|
|
|
|
("cps", False, "inf"), |
|
|
|
|
|
#("fdep", False, 0), |
|
|
|
|
|
("mdcs", False, 2.85414), |
|
|
|
|
|
("mdcs2", False, 2.85414), |
|
|
|
|
|
("mp", False, 1.66667), |
|
|
|
|
|
("or", False, 1), |
|
|
|
|
|
("pand", False, "inf"), |
|
|
|
|
|
("pand_param", True, "-1"), |
|
|
|
|
|
("spare", False, 3.53846), |
|
|
|
|
|
("spare2", False, 1.86957), |
|
|
|
|
|
("spare3", False, 1.27273), |
|
|
|
|
|
("spare4", False, 4.8459), |
|
|
|
|
|
("spare5", False, 2.16667), |
|
|
|
|
|
("spare6", False, 1.4), |
|
|
|
|
|
("tripple_and1", False, 4.16667), |
|
|
|
|
|
("tripple_and2", False, 3.66667), |
|
|
|
|
|
("tripple_and2_c", False, 3.6667), |
|
|
|
|
|
("tripple_and_c", False, 4.16667), |
|
|
|
|
|
("tripple_or", False, 0.5), |
|
|
|
|
|
("tripple_or2", False, 0.666667), |
|
|
|
|
|
("tripple_or2_c", False, 0.66667), |
|
|
|
|
|
("tripple_or_c", False, 0.5), |
|
|
|
|
|
("tripple_pand", False, "inf"), |
|
|
|
|
|
("tripple_pand2", False, "inf"), |
|
|
|
|
|
("tripple_pand2_c", False, "inf"), |
|
|
|
|
|
("tripple_pand_c", False, "inf"), |
|
|
|
|
|
("voting", False, 1.66667), |
|
|
|
|
|
("voting2", False, 0.588235) |
|
|
|
|
|
|
|
|
("and", False, [3, 1]), |
|
|
|
|
|
("and_param", True, ["(4*x^2+2*x+1)/((x) * (2*x+1))", "1"]), |
|
|
|
|
|
("cm2", False, [0.256272, 1]), |
|
|
|
|
|
#("cm4", False, [0, 1]), |
|
|
|
|
|
("cps", False, ["inf", 0.333333]), |
|
|
|
|
|
#("fdep", False, [0, 1]), |
|
|
|
|
|
("mdcs", False, [2.85414, 1]), |
|
|
|
|
|
("mdcs2", False, [2.85414, 1]), |
|
|
|
|
|
("mp", False, [1.66667, 1]), |
|
|
|
|
|
("or", False, [1, 1]), |
|
|
|
|
|
("pand", False, ["inf", 0.666667]), |
|
|
|
|
|
("pand_param", True, ["-1", "(x)/(y+x)"]), |
|
|
|
|
|
("spare", False, [3.53846, 1]), |
|
|
|
|
|
("spare2", False, [1.86957, 1]), |
|
|
|
|
|
("spare3", False, [1.27273, 1]), |
|
|
|
|
|
("spare4", False, [4.8459, 1]), |
|
|
|
|
|
("spare5", False, [2.16667, 1]), |
|
|
|
|
|
("spare6", False, [1.4, 1]), |
|
|
|
|
|
("tripple_and1", False, [4.16667, 1]), |
|
|
|
|
|
("tripple_and2", False, [3.66667, 1]), |
|
|
|
|
|
("tripple_and2_c", False, [3.6667, 1]), |
|
|
|
|
|
("tripple_and_c", False, [4.16667, 1]), |
|
|
|
|
|
("tripple_or", False, [0.5, 1]), |
|
|
|
|
|
("tripple_or2", False, [0.666667, 1]), |
|
|
|
|
|
("tripple_or2_c", False, [0.66667, 1]), |
|
|
|
|
|
("tripple_or_c", False, [0.5, 1]), |
|
|
|
|
|
("tripple_pand", False, ["inf", 0.0416667]), |
|
|
|
|
|
("tripple_pand2", False, ["inf", 0.166667]), |
|
|
|
|
|
("tripple_pand2_c", False, ["inf", 0.166667]), |
|
|
|
|
|
("tripple_pand_c", False, ["inf", 0.0416667]), |
|
|
|
|
|
("voting", False, [1.66667, 1]), |
|
|
|
|
|
("voting2", False, [0.588235, 1]) |
|
|
] |
|
|
] |
|
|
|
|
|
|
|
|
def run_storm_dft(filename, parametric, quiet): |
|
|
|
|
|
|
|
|
def run_storm_dft(filename, prop, parametric, quiet): |
|
|
# Run storm-dft on filename and return result |
|
|
# Run storm-dft on filename and return result |
|
|
prop = "ET=? [F \"failed\"]" |
|
|
|
|
|
dft_file = os.path.join(EXAMPLE_DIR, filename + ".dft") |
|
|
dft_file = os.path.join(EXAMPLE_DIR, filename + ".dft") |
|
|
args = [STORM_PATH, |
|
|
args = [STORM_PATH, |
|
|
dft_file, |
|
|
dft_file, |
|
@ -84,24 +83,27 @@ def run_tool(args, quiet=False): |
|
|
if __name__ == "__main__": |
|
|
if __name__ == "__main__": |
|
|
count = 0 |
|
|
count = 0 |
|
|
correct = 0 |
|
|
correct = 0 |
|
|
|
|
|
properties = ["ET=? [F \"failed\"]", "P=? [F \"failed\"]"] |
|
|
start = time.time() |
|
|
start = time.time() |
|
|
for (benchmark, parametric, result_original) in benchmarks: |
|
|
|
|
|
# Run benchmark and check result |
|
|
|
|
|
count += 1; |
|
|
|
|
|
print("Running '{}'".format(benchmark)) |
|
|
|
|
|
result = run_storm_dft(benchmark, parametric, True) |
|
|
|
|
|
if not parametric: |
|
|
|
|
|
# Float |
|
|
|
|
|
result = float(result) |
|
|
|
|
|
if not math.isclose(result, float(result_original), rel_tol=1e-05): |
|
|
|
|
|
print("!!! File '{}': result: {}, Expected: {}".format(benchmark, result, result_original)) |
|
|
|
|
|
|
|
|
for index, prop in enumerate(properties): |
|
|
|
|
|
for (benchmark, parametric, result_original) in benchmarks: |
|
|
|
|
|
expected_result = result_original[index] |
|
|
|
|
|
# Run benchmark and check result |
|
|
|
|
|
count += 1; |
|
|
|
|
|
print("Running '{}' with property '{}'".format(benchmark, prop)) |
|
|
|
|
|
result = run_storm_dft(benchmark, prop, parametric, True) |
|
|
|
|
|
if not parametric: |
|
|
|
|
|
# Float |
|
|
|
|
|
result = float(result) |
|
|
|
|
|
if not math.isclose(result, float(expected_result), rel_tol=1e-05): |
|
|
|
|
|
print("!!! File '{}': result: {}, Expected: {}".format(benchmark, result, expected_result)) |
|
|
|
|
|
else: |
|
|
|
|
|
correct += 1 |
|
|
else: |
|
|
else: |
|
|
correct += 1 |
|
|
|
|
|
else: |
|
|
|
|
|
# Parametric |
|
|
|
|
|
if result != result_original: |
|
|
|
|
|
print("!!! File {}: result: {}, Expected: {}".format(benchmark, result, result_original)) |
|
|
|
|
|
else: |
|
|
|
|
|
correct += 1 |
|
|
|
|
|
|
|
|
# Parametric |
|
|
|
|
|
if result != expected_result: |
|
|
|
|
|
print("!!! File {}: result: {}, Expected: {}".format(benchmark, result, expected_result)) |
|
|
|
|
|
else: |
|
|
|
|
|
correct += 1 |
|
|
end = time.time() |
|
|
end = time.time() |
|
|
print("Correct results for {} of {} DFTs in {}s".format(correct, count, end-start)) |
|
|
|
|
|
|
|
|
print("Correct results for {} of {} DFT checks in {}s".format(correct, count, end-start)) |