forked from pdaian/mev
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkutils.py
60 lines (52 loc) · 1.92 KB
/
kutils.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
from subprocess import Popen, PIPE
import re, random, os
BLANK_SPEC = """module BOUND
imports MEV
rule <k>
%s
=> ?X
</k>
<S> .Map =>?S:Map </S>
<M> .Set => ?_:Set </M>
<B> .List => ?_ </B>
<P> .Map => ?_ </P>
<V> .Map => ?_ </V>
<N> 1 => ?_ </N>
ensures (?X ==K DONE andBool(%s)) orBool (?X ==K FAIL)
endmodule
"""
def find_integer_bound(program, outfile, bound_clause, starting_value):
bound = starting_value
previous_output = ""
output = ""
while True:
spec = BLANK_SPEC % (program, bound_clause % (bound))
open("bound.k", "w").write(spec)
print("Starting proof...")
pipe = Popen("kprove -v --debug --default-claim-type all-path --z3-impl-timeout 500 bound.k", shell=True, stdout=PIPE, stderr=PIPE)
output = pipe.stdout.read() + pipe.stderr.read()
output = str(output, "utf-8")
if "#True" in output:
print("BOUND FOUND!", bound)
print("Writing best configuration to", outfile, "...")
print(previous_output)
open(outfile, "w").write(previous_output)
break
output = output[output.find("<generatedTop>"):]
output = output[:output.find("</generatedTop>")+15]
print("Found new bound", output)
if not "Uniswap in 0 |-> " in output and "<S>" in output:
bound = 0
else:
bound = int(output.split("Uniswap in 0 |-> ")[1].split(" ")[0])
print("-" * 15, "\nBETTER BOUND:", bound)
previous_output = output
print("All done :)")
def get_final_configuration(program):
os.system('kompile mev.k --backend llvm') # use llvm backend for faster execution
open('torun.mev', 'w').write(program)
pipe = Popen("krun torun.mev", shell=True, stdout=PIPE, stderr=PIPE)
output = pipe.stdout.read() + pipe.stderr.read()
output = str(output, "utf-8")
print("K OUTPUT")
print(output)