Backtrader - order.executed.value в ордере на продажу ошибочен? - PullRequest
0 голосов
/ 02 мая 2020

Использование стратегии котельной пластины, предполагающей покупку и продажу одной акции (только длинная / каждый ордер на покупку связан с ордером на продажу).

По какой-то причине, когда я продаю акцию, она регистрирует стоимость сделка (цена акций *) на ту же сумму, которая была установлена ​​при открытии позиции, несмотря на разные цены акций.

Выход:

2018-02-15 10:30:00, BUY ORDER PLACED,    Price:  169.79, Cost:    0.00, Comm:    0.00
2018-02-15 10:30:00, BUY ORDER EXECUTED,  Price:  172.06, Cost:  172.06, Comm:    0.17

2018-03-19 14:30:00, SELL ORDER PLACED,   Price:  174.19, Cost:    0.00, Comm:    0.00
2018-03-19 14:30:00, SELL ORDER EXECUTED, Price:  174.88, Cost:  172.06, Comm:    0.17

Выше мы видим, что покупка была исполнена в 172.06 (стоимость сделки (то есть стоимость) является той же самой, что и при торговле 1 акцией), однако, ордер на продажу был исполнен по другой цене (174.88), но все еще имеет ту же стоимость сделки и комиссию?

Пример кода:

class Test(bt.SignalStrategy):

    def __init__(self):
        self.sma1 = bt.ind.SMA(period=100)
        self.dataclose= self.datas[0].close    
        self.order = None 
        self.buyprice = None
        self.buycomm = None
        self.sellprice = None
        self.sellcomm = None

    def log(self, txt, dt=None):
        dt = dt or self.data.datetime.datetime(0)
        print('%s, %s' % (dt, txt)) 

    def notify_order(self, order):
        # 1. If order is submitted/accepted, do nothing 
        if order.status in [order.Submitted, order.Accepted]:
            return
        # 2. If order is buy/sell executed, report price executed
        if order.status in [order.Completed]: 

            if order.isbuy():
                self.log('BUY ORDER PLACED,    Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.created.price,order.created.value,order.created.comm))
                self.log('BUY ORDER EXECUTED,  Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.executed.price,order.executed.value,order.executed.comm))
                self.buyprice = order.executed.price
                self.buycomm = order.executed.comm


            if order.issell():
                self.log('SELL ORDER PLACED,   Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.created.price,order.created.value,order.created.comm))
                self.log('SELL ORDER EXECUTED, Price:{0:8.2f}, Cost:{1:8.2f}, Comm:{2:8.2f}'.format(order.executed.price, order.executed.value,order.executed.comm))
                self.sellprice = order.executed.price
                self.sellcomm = order.executed.comm

        self.bar_executed = len(self) #when was trade executed
    # 3. If order is canceled/margin/rejected, report order canceled
    elif order.status in [order.Canceled, order.Margin, order.Rejected]:
        self.log('Order Canceled/Margin/Rejected')

    self.order = None

def next(self):

    if self.order: 
        return

    if self.getposition(data=self.data).size == 0:
        if data.close[0] > self.sma1:
            self.buy()

    else:
        if data.close[0] < self.sma1:
            self.close()
...