improve backtesting result formatting
This commit is contained in:
parent
0c11d4443f
commit
ae52880f81
@ -41,27 +41,29 @@ def generate_text_table(
|
|||||||
Generates and returns a text table for the given backtest data and the results dataframe
|
Generates and returns a text table for the given backtest data and the results dataframe
|
||||||
:return: pretty printed table with tabulate as str
|
:return: pretty printed table with tabulate as str
|
||||||
"""
|
"""
|
||||||
|
floatfmt = ('s', 'd', '.2f', '.8f', '.1f')
|
||||||
tabular_data = []
|
tabular_data = []
|
||||||
headers = ['pair', 'buy count', 'avg profit', 'total profit', 'avg duration']
|
headers = ['pair', 'buy count', 'avg profit %',
|
||||||
|
'total profit ' + stake_currency, 'avg duration']
|
||||||
for pair in data:
|
for pair in data:
|
||||||
result = results[results.currency == pair]
|
result = results[results.currency == pair]
|
||||||
tabular_data.append([
|
tabular_data.append([
|
||||||
pair,
|
pair,
|
||||||
len(result.index),
|
len(result.index),
|
||||||
'{:.2f}%'.format(result.profit_percent.mean() * 100.0),
|
result.profit_percent.mean() * 100.0,
|
||||||
'{:.08f} {}'.format(result.profit_BTC.sum(), stake_currency),
|
result.profit_BTC.sum(),
|
||||||
'{:.2f}'.format(result.duration.mean() * ticker_interval),
|
result.duration.mean() * ticker_interval,
|
||||||
])
|
])
|
||||||
|
|
||||||
# Append Total
|
# Append Total
|
||||||
tabular_data.append([
|
tabular_data.append([
|
||||||
'TOTAL',
|
'TOTAL',
|
||||||
len(results.index),
|
len(results.index),
|
||||||
'{:.2f}%'.format(results.profit_percent.mean() * 100.0),
|
results.profit_percent.mean() * 100.0,
|
||||||
'{:.08f} {}'.format(results.profit_BTC.sum(), stake_currency),
|
results.profit_BTC.sum(),
|
||||||
'{:.2f}'.format(results.duration.mean() * ticker_interval),
|
results.duration.mean() * ticker_interval,
|
||||||
])
|
])
|
||||||
return tabulate(tabular_data, headers=headers)
|
return tabulate(tabular_data, headers=headers, floatfmt=floatfmt)
|
||||||
|
|
||||||
|
|
||||||
def backtest(stake_amount: float, processed: Dict[str, DataFrame],
|
def backtest(stake_amount: float, processed: Dict[str, DataFrame],
|
||||||
|
@ -18,11 +18,12 @@ def test_generate_text_table():
|
|||||||
'duration': [10, 30]
|
'duration': [10, 30]
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
print(generate_text_table({'BTC_ETH': {}}, results, 'BTC', 5))
|
||||||
assert generate_text_table({'BTC_ETH': {}}, results, 'BTC', 5) == (
|
assert generate_text_table({'BTC_ETH': {}}, results, 'BTC', 5) == (
|
||||||
'pair buy count avg profit total profit avg duration\n'
|
'pair buy count avg profit % total profit BTC avg duration\n'
|
||||||
'------- ----------- ------------ -------------- --------------\n'
|
'------- ----------- -------------- ------------------ --------------\n'
|
||||||
'BTC_ETH 2 15.00% 0.60000000 BTC 100\n'
|
'BTC_ETH 2 15.00 0.60000000 100.0\n'
|
||||||
'TOTAL 2 15.00% 0.60000000 BTC 100')
|
'TOTAL 2 15.00 0.60000000 100.0')
|
||||||
|
|
||||||
|
|
||||||
def test_get_timeframe():
|
def test_get_timeframe():
|
||||||
|
Loading…
Reference in New Issue
Block a user