VeighNa量化社区
你的开源社区量化交易平台 | vn.py | vnpy
Member
avatar
加入于:
帖子: 4
声望: 0

from vnpy_ctastrategy import (
CtaTemplate,
StopOrder,
TickData,
BarData,
TradeData,
OrderData,
BarGenerator,
ArrayManager,
)

class QSJL(CtaTemplate):
""""""

author = "天才交易员"




def __init__(self, cta_engine, strategy_name, vt_symbol, setting):
    """"""
    super().__init__(cta_engine, strategy_name, vt_symbol, setting)

    self.bg = BarGenerator(self.on_bar)
    self.am = ArrayManager()

def on_init(self):
    """
    Callback when strategy is inited.
    """
    self.write_log("策略初始化")
    self.load_bar(10)

def on_start(self):
    """
    Callback when strategy is started.
    """
    self.write_log("策略启动")
    self.put_event()

def on_stop(self):
    """
    Callback when strategy is stopped.
    """
    self.write_log("策略停止")

    self.put_event()

def on_tick(self, tick: TickData):
    """
    Callback of new tick data update.
    """
    self.bg.update_tick(tick)

def on_bar(self, bar: BarData):
    """
    Callback of new bar data update.
    """
    #self.cancel_all()

    am = self.am
    am.update_bar(bar)
    if not am.inited:
        return

    # 计算历史收盘价

    if len(am.close) < 10:  # 确保有足够的历史数据
        return   


    #ZZ = am.ema(3,array=True)

    ZXX_values0 = (bar.close_price + 0.618 * am.close[-2] + 0.382 * am.close[-3] + 0.236 * am.close[-4] + 0.146 * am.close[-5]) / 2.382
    ZXX_values1 = (bar.close_price+ 0.618 * am.close[-3] + 0.382 * am.close[-4] + 0.236 * am.close[-5] + 0.146 * am.close[-6]) / 2.382

    self.ZXX0 = ZXX_values0
    self.ZXX1 = ZXX_values1



    #参考线:EMA(重心线,4);
    CKX = am.ema(self.ZXX0, 4) 
    self.CKX0 = CKX[-1]
    self.CKX1 = CKX[-2]

    cross_over = self.ZXX0 > self.CKX0  and self.ZXX1 < self.CKX1
    cross_below = self.CKX0 > self.ZXX0 and self.CKX1 < self.ZXX1

    if cross_over:
        if self.pos == 0:
            self.buy(bar.close_price, 1)
        elif self.pos < 0:
            self.cover(bar.close_price, 1)
            self.buy(bar.close_price, 1)

    elif cross_below:
        if self.pos == 0:
            self.short(bar.close_price, 1)
        elif self.pos > 0:
            self.sell(bar.close_price, 1)
            self.short(bar.close_price, 1)

    self.put_event()

def on_order(self, order: OrderData):
    """
    Callback of new order data update.
    """
    pass

def on_trade(self, trade: TradeData):
    """
    Callback of new trade data update.
    """
    self.put_event()

def on_stop_order(self, stop_order: StopOrder):
    """
    Callback of stop order update.
    """
    pass

哪位大佬能帮我看看我的策略为啥回测一直没结果,谢谢大佬

Member
avatar
加入于:
帖子: 5331
声望: 323

可以自己在on_bar函数下进行打印排查

Member
avatar
加入于:
帖子: 4
声望: 0

管理员大人您好,请帮忙删掉我所有的帖子,谢谢。@管理员

Member
avatar
加入于:
帖子: 1814
声望: 136

关于论坛权限管理相关请求,可以通过您的论坛注册微信在vnpy-community公众号后台留言,方便确认账户所有权

© 2015-2022 上海韦纳软件科技有限公司
备案服务号:沪ICP备18006526号

沪公网安备 31011502017034号

【用户协议】
【隐私政策】
【免责条款】