-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathrun_benchmark.py
87 lines (72 loc) · 3.17 KB
/
run_benchmark.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
from json import loads
from json import dumps
from benchmark import impl
from benchmark import spec
from benchmark import assertAlmostEqual
def format(val):
return '{:.12f}'.format(val).rstrip('0').rstrip('.')
def execute(test, module):
directions = [int(strategy['orders'][0]['token'] == test['targetToken']) for strategy in test['strategies']]
strategies = [[module.Order(order) for order in strategy['orders']] for strategy in test['strategies']]
tradeFunc = [module.tradeBySourceAmount, module.tradeByTargetAmount][test['tradeByTargetAmount']]
test['sourceAmount'] = module.Amount(0)
test['targetAmount'] = module.Amount(0)
for tradeActions in test['tradeActions']:
strategyId = int(tradeActions['strategyId']) - 1
tokenAmount = module.Amount(tradeActions['amount'])
sourceIndex = directions[strategyId]
targetIndex = 1 - sourceIndex
sourceOrder = strategies[strategyId][sourceIndex]
targetOrder = strategies[strategyId][targetIndex]
sourceAmount, targetAmount = tradeFunc(tokenAmount, targetOrder)
sourceOrder.y += sourceAmount
targetOrder.y -= targetAmount
if sourceOrder.z < sourceOrder.y:
sourceOrder.z = sourceOrder.y
test['sourceAmount'] += sourceAmount
test['targetAmount'] += targetAmount
test['sourceAmount'] = format(test['sourceAmount'])
test['targetAmount'] = format(test['targetAmount'])
for dstStrategy, srcStrategy in zip(test['strategies'], strategies):
for dstOrder, srcOrder in zip(dstStrategy['orders'], srcStrategy):
dstOrder['expected'] = {key: format(val) for key, val in dict(srcOrder).items()}
def verify(implTest, specTest, maxError):
for implStrategy, specStrategy in zip(implTest['strategies'], specTest['strategies']):
for implOrder, specOrder in zip(implStrategy['orders'], specStrategy['orders']):
for key in maxError:
assertAlmostEqual(implOrder['expected'][key], specOrder['expected'][key], maxError[key])
def generate(fileName, module, suffix):
file = open(f'{fileName}.json', 'r')
tests = loads(file.read())
file.close()
for test in tests:
execute(test, module)
file = open(f'{fileName}.{suffix}.json', 'w')
file.write(dumps(tests, indent=2))
file.close()
return tests
def run(fileName, maxError):
implTests = generate(fileName, impl, 'impl')
specTests = generate(fileName, spec, 'spec')
for implTest, specTest in zip(implTests, specTests):
verify(implTest, specTest, maxError)
for batch in [
{
'fileName': 'resources/benchmark/ArbitraryTrade',
'maxError': {
'liquidity' : '0.0000046064',
'lowestRate' : '0.0000000007',
'highestRate' : '0.0000000007',
'marginalRate' : '0.0000015278',
}
},
{
'fileName': 'resources/benchmark/EthUsdcTrade',
'maxError': {
'liquidity' : '0.000001288756294',
'lowestRate' : '0.000000000000019',
'highestRate' : '0.000000000000012',
'marginalRate' : '0.000999000999001',
}
},
]: run(batch['fileName'], batch['maxError'])