updated ratio_calc_profit function

This commit is contained in:
Sam Germain 2021-07-08 05:37:54 -06:00
parent e7d6fac553
commit c753bd0ddc
3 changed files with 63 additions and 24 deletions

View File

@ -609,12 +609,14 @@ class LocalTrade():
def update_order(self, order: Dict) -> None: def update_order(self, order: Dict) -> None:
Order.update_orders(self.orders, order) Order.update_orders(self.orders, order)
def _calc_open_trade_value(self) -> float: def _calc_open_trade_value(self, amount: Optional[float] = None) -> float:
""" """
Calculate the open_rate including open_fee. Calculate the open_rate including open_fee.
:return: Price in of the open trade incl. Fees :return: Price in of the open trade incl. Fees
""" """
open_trade = Decimal(self.amount) * Decimal(self.open_rate) if amount is None:
amount = self.amount
open_trade = Decimal(amount) * Decimal(self.open_rate)
fees = open_trade * Decimal(self.fee_open) fees = open_trade * Decimal(self.fee_open)
if self.is_short: if self.is_short:
return float(open_trade - fees) return float(open_trade - fees)
@ -651,6 +653,7 @@ class LocalTrade():
return self.interest_mode(borrowed=borrowed, rate=rate, hours=hours) return self.interest_mode(borrowed=borrowed, rate=rate, hours=hours)
def calc_close_trade_value(self, rate: Optional[float] = None, def calc_close_trade_value(self, rate: Optional[float] = None,
fee: Optional[float] = None, fee: Optional[float] = None,
interest_rate: Optional[float] = None) -> float: interest_rate: Optional[float] = None) -> float:
""" """
@ -718,23 +721,30 @@ class LocalTrade():
If interest_rate is not set self.interest_rate will be used If interest_rate is not set self.interest_rate will be used
:return: profit ratio as float :return: profit ratio as float
""" """
close_trade_value = self.calc_close_trade_value( close_trade_value = self.calc_close_trade_value(
rate=(rate or self.close_rate), rate=(rate or self.close_rate),
fee=(fee or self.fee_close), fee=(fee or self.fee_close),
interest_rate=(interest_rate or self.interest_rate) interest_rate=(interest_rate or self.interest_rate)
) )
if ((self.is_short and close_trade_value == 0.0) or
(not self.is_short and self.open_trade_value == 0.0)): if self.leverage is None:
leverage = 1.0
else:
leverage = self.leverage
stake_value = self._calc_open_trade_value(amount=(self.amount/leverage))
short_close_zero = (self.is_short and close_trade_value == 0.0)
long_close_zero = (not self.is_short and self.open_trade_value == 0.0)
if (short_close_zero or long_close_zero):
return 0.0 return 0.0
else: else:
if self.has_no_leverage: if self.is_short:
# TODO-mg: Use one profit_ratio calculation profit_ratio = ((self.open_trade_value - close_trade_value) / stake_value)
profit_ratio = (close_trade_value/self.open_trade_value) - 1
else: else:
if self.is_short: profit_ratio = ((close_trade_value - self.open_trade_value) / stake_value)
profit_ratio = ((self.open_trade_value - close_trade_value) / self.stake_amount)
else:
profit_ratio = ((close_trade_value - self.open_trade_value) / self.stake_amount)
return float(f"{profit_ratio:.8f}") return float(f"{profit_ratio:.8f}")

View File

@ -114,20 +114,49 @@ def test_update_with_binance(limit_buy_order, limit_sell_order, fee, caplog):
- Buy: 90.99181073 Crypto at 0.00001099 BTC - Buy: 90.99181073 Crypto at 0.00001099 BTC
(90.99181073*0.00001099 = 0.0009999 BTC) (90.99181073*0.00001099 = 0.0009999 BTC)
- Buying fee: 0.25% - Buying fee: 0.25%
- Total cost of buy trade: 0.001002500 BTC - open_trade_value: 0.0010024999999225066 BTC
((90.99181073*0.00001099) + ((90.99181073*0.00001099)*0.0025)) (90.99181073*0.00001099) + ((90.99181073*0.00001099)*0.0025)
Sell Sell
- Sell: 90.99181073 Crypto at 0.00001173 BTC - Sell: 90.99181073 Crypto at 0.00001173 BTC
(90.99181073*0.00001173 = 0,00106733394 BTC) (90.99181073*0.00001173 = 0.0010673339398629 BTC)
- Selling fee: 0.25% - Selling fee: 0.25%
- Total cost of sell trade: 0.001064666 BTC - close_trade_value: 0.0010646656050132426 BTC
((90.99181073*0.00001173) - ((90.99181073*0.00001173)*0.0025)) (90.99181073*0.00001173) - ((90.99181073*0.00001173)*0.0025)
Profit/Loss: +0.000062166 BTC Profit/Loss: +6.216560509073607e-05 BTC
(Sell:0.001064666 - Buy:0.001002500) (Sell:0.0010646656050132426 - Buy:0.0010024999999225066)
Profit/Loss percentage: 0.0620 Profit/Loss percentage: 0.0620
((0.001064666/0.001002500)-1 = 6.20%) (0.0010646656050132426/0.0010024999999225066)-1 = 6.20%
= 0.062010578648919124
6.216560509073607e-05 / 0.0010024999999225066
= 0.062010578648919186
amount = 90.99181073 Crypto
stake_amount = 0.0009999999999226999
open_rate = 0.00001099
close_rate = 0.00001173
fee: 0.0025 (0.25%)
open_trade_value = (amount * open_rate) + (amount * open_rate * fee)
= (90.99181073*0.00001099) + ((90.99181073*0.00001099)*0.0025)
= 0.0010024999999225066
close_trade_value = (amount * close_rate) - (amount * close_rate * fee)
= (90.99181073*0.00001173) - ((90.99181073*0.00001173)*0.0025)
= 0.0010646656050132426
#? ORIGINAL PROFIT RATIO CALCULATION
#? (close_trade_value/open_trade_value)-1 = original_answer
#? (0.0010646656050132426/0.0010024999999225066)-1 = 0.062010578648919
#? NEW PROFIT RATIO CALCULATION 1
#? (close_trade_value - open_trade_value)/stake_amount = new_answer
#? (0.0010646656050132426 - 0.0010024999999225068)/0.0009999999999226999 = 0.06216560509554
#? NEW PROFIT RATIO CALCULATION 2
#? (close_trade_value - open_trade_value)/open_trade_value = original_answer
#? (0.0010646656050132426 - 0.0010024999999225066)/0.0010024999999225066 = 0.062010578648919
:param limit_buy_order: :param limit_buy_order:
:param limit_sell_order: :param limit_sell_order:
@ -137,7 +166,7 @@ def test_update_with_binance(limit_buy_order, limit_sell_order, fee, caplog):
trade = Trade( trade = Trade(
id=2, id=2,
pair='ETH/BTC', pair='ETH/BTC',
stake_amount=0.001, stake_amount=0.0009999999999226999,
open_rate=0.01, open_rate=0.01,
amount=5, amount=5,
is_open=True, is_open=True,

View File

@ -231,9 +231,9 @@ def test_calc_open_close_trade_price_lev(limit_lev_buy_order, limit_lev_sell_ord
total_profit = close_value - open_value total_profit = close_value - open_value
= 0.003193788481706411 - 0.0030074999997675204 = 0.003193788481706411 - 0.0030074999997675204
= 0.00018628848193889044 = 0.00018628848193889044
total_profit_percentage = total_profit / stake_amount total_profit_percentage = total_profit / open_value
= 0.00018628848193889054 / 0.0009999999999226999 = 0.00018628848193889054 / 0.0030074999997675204
= 0.18628848195329067 = 0.06194130738264028
""" """
trade = Trade( trade = Trade(
pair='ETH/BTC', pair='ETH/BTC',
@ -257,7 +257,7 @@ def test_calc_open_close_trade_price_lev(limit_lev_buy_order, limit_lev_sell_ord
# Profit in BTC # Profit in BTC
assert round(trade.calc_profit(), 8) == round(0.00018628848193889054, 8) assert round(trade.calc_profit(), 8) == round(0.00018628848193889054, 8)
# Profit in percent # Profit in percent
assert round(trade.calc_profit_ratio(), 8) == round(0.18628848195329067, 8) assert round(trade.calc_profit_ratio(), 8) == round(0.06194130738264028, 8)
@pytest.mark.usefixtures("init_persistence") @pytest.mark.usefixtures("init_persistence")