stable/scripts/plot_profit.py

107 lines
3.0 KiB
Python
Raw Normal View History

2018-01-12 09:55:49 +00:00
#!/usr/bin/env python3
"""
Script to display profits
2019-06-29 18:07:25 +00:00
Use `python plot_profit.py --help` to display the command line arguments
"""
2018-03-25 19:37:14 +00:00
import logging
2018-01-12 09:55:49 +00:00
import sys
2019-06-30 07:28:49 +00:00
from typing import Any, Dict, List
2018-01-12 09:55:49 +00:00
import pandas as pd
2019-03-23 18:18:10 +00:00
import plotly.graph_objs as go
from plotly import tools
from freqtrade.arguments import ARGS_PLOT_PROFIT, Arguments
2019-06-30 07:42:10 +00:00
from freqtrade.data.btanalysis import create_cum_profit
2019-06-30 07:28:49 +00:00
from freqtrade.optimize import setup_configuration
2019-06-30 07:42:10 +00:00
from freqtrade.plot.plotting import FTPlots, store_plot_file
from freqtrade.state import RunMode
2018-03-25 19:37:14 +00:00
logger = logging.getLogger(__name__)
2018-01-12 09:55:49 +00:00
2019-06-30 07:28:49 +00:00
def plot_profit(config: Dict[str, Any]) -> None:
2018-01-12 09:55:49 +00:00
"""
Plots the total profit for all pairs.
Note, the profit calculation isn't realistic.
But should be somewhat proportional, and therefor useful
in helping out to find a good algorithm.
"""
2019-06-30 07:42:10 +00:00
plot = FTPlots(config)
2018-01-12 09:55:49 +00:00
2019-06-30 07:42:10 +00:00
trades = plot.trades[plot.trades['pair'].isin(plot.pairs)]
2019-06-30 07:28:49 +00:00
# Create an average close price of all the pairs that were involved.
# this could be useful to gauge the overall market trend
2018-01-12 09:55:49 +00:00
# Combine close-values for all pairs, rename columns to "pair"
2019-06-30 07:42:10 +00:00
df_comb = pd.concat([plot.tickers[pair].set_index('date').rename(
{'close': pair}, axis=1)[pair] for pair in plot.tickers], axis=1)
df_comb['mean'] = df_comb.mean(axis=1)
2018-01-12 09:55:49 +00:00
# Add combined cumulative profit
df_comb = create_cum_profit(df_comb, trades, 'cum_profit')
2018-01-12 09:55:49 +00:00
# Plot the pairs average close prices, and total profit growth
avgclose = go.Scattergl(
x=df_comb.index,
y=df_comb['mean'],
name='Avg close price',
)
profit = go.Scattergl(
x=df_comb.index,
y=df_comb['cum_profit'],
name='Profit',
)
fig = tools.make_subplots(rows=3, cols=1, shared_xaxes=True, row_width=[1, 1, 1])
fig.append_trace(avgclose, 1, 1)
fig.append_trace(profit, 2, 1)
2018-01-12 09:55:49 +00:00
2019-06-30 07:42:10 +00:00
for pair in plot.pairs:
profit_col = f'cum_profit_{pair}'
df_comb = create_cum_profit(df_comb, trades[trades['pair'] == pair], profit_col)
pair_profit = go.Scattergl(
x=df_comb.index,
y=df_comb[profit_col],
name=f"Profit {pair}",
)
fig.append_trace(pair_profit, 3, 1)
2019-06-30 07:42:10 +00:00
store_plot_file(fig, filename='freqtrade-profit-plot.html', auto_open=True)
2018-03-05 04:24:01 +00:00
2019-06-30 07:28:49 +00:00
def plot_parse_args(args: List[str]) -> Dict[str, Any]:
"""
Parse args passed to the script
:param args: Cli arguments
:return: args: Array with all arguments
"""
arguments = Arguments(args, 'Graph profits')
2019-06-22 18:27:29 +00:00
arguments.build_args(optionlist=ARGS_PLOT_PROFIT)
2019-06-30 07:28:49 +00:00
parsed_args = arguments.parse_args()
# Load the configuration
config = setup_configuration(parsed_args, RunMode.OTHER)
return config
def main(sysargv: List[str]) -> None:
"""
This function will initiate the bot and start the trading loop.
:return: None
"""
logger.info('Starting Plot Dataframe')
plot_profit(
plot_parse_args(sysargv)
)
2018-01-12 09:55:49 +00:00
if __name__ == '__main__':
main(sys.argv[1:])