海龟策略深入研究-策略回测系列-6 理解海龟策略代码

2024-04-21 09:48

本文主要是介绍海龟策略深入研究-策略回测系列-6 理解海龟策略代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

海龟策略文档


在运行策略回测前,至少要对策略代码有一个整体的概念,便于以后的策略调试以及改进。
v1.9.1提供了两个版本的海龟策略,分别是基于ctaTemple开发的,针对单标的的简化版,以及针对多标的的完整版。
这里只介绍完整版的海龟策略,该模块在"examples\TurtleStrategy"文件夹下,打开如图2-4所示。在这里只需关注4个文件
 

enter image description here
 

  • setting.csv:用于设置策略回测所用到的数据,包括期货品种、合约规模、最小价格变动、手续费、滑点。
  • turtleStrategy.py:具体的海龟策略
  • turtleEngine.py:海龟策略回测引擎
  • run.ipynb:在Jupyter Notebook上回测显示

现在只关注turleStrategy.py这个文件。海龟策略由3个类构成,分别是TurtleResult、TurtleSignal、TurtlePortfolio。阅读顺序并不是简单的从上到下,而是具有镶嵌结构。
所以呢,刚阅读时候容易一脸懵逼,一脸懵逼。。。
 
enter image description here
 
下面整理了策略代码的结构图,如图,箭头方向代表先定义,后调用。
 
enter image description here
 
 

a.TurtleResult类


用于计算单笔开平仓交易盈亏,是海龟策略中判断“若上一笔盈利当前信号无效”的基础

  • __init__(self):初始化单位头寸,开仓均价,平仓均价和单笔开平仓交易盈亏数
  • open(self,price,change):先计算开仓累计成本,然后统计开仓平均成本
  • close(self,price):缓存平仓均价,统计单笔开平仓交易盈亏

 
 

b.TurtleSignal类


用于产生海龟策略交易信号,包括入场,止损,止盈委托价格与目标仓位

  • __init__(self,porfolio,vtSymbol,entryWindow,entryDev,exitWindow,exitDev,protfolioCheck=False):初始化海龟信号的策略参数(默认不检查上一笔盈亏,默认缓存60根K线)
  • onBar(self,bar):缓存足够K线后,开始计算相关技术指标,判断交易信号
  • generateSignal:负责交易信号的判断,平仓信号与开仓信号是分开的:优先检查平仓,没有仓位或者持有多头仓位的时候,在设置好入场位做多或加仓;没有仓位或者持有空头仓位的时候,在设置好入场位做空或者加仓
  • calculateIndicator:负责计算指标的产生,包括计算入场和止盈离场的唐奇安通道上下轨,判断到有单位持仓后,计算ATR指标并且设定随后8个入场位置(做多4个和做空4个),同时初始化离场价格。
  • newSignal(self, direction, offset, price, volume):定义海龟投资组合的发单委托,分别是多空方向、开仓平仓、停止单价格、合约手数。
  • buy(self,price,volume):先传入计算好的停止单价格,缓存开仓委托的价格和手数,发出投资组合的多开委托,基于最后一次加仓价格计算止损离场位置。
  • sell(self,price,volume):先传入计算好的停止单价格,缓存平仓委托的价格,发出投资组合空平的委托
  • short(self,price,volume):先传入计算好的停止单价格,缓存开仓委托的价格和手数,发出投资组合的空开委托,基于最后一次加仓价格计算止损离场位置。
  • cover(self,price,volume):先传入计算好的停止单价格,缓存平仓委托的价格,发出投资组合多平的委托。
  • open(self,price,change):计算累计开仓手数/单位头寸,调用TurtleResult类定义的open函数计算开仓平均成本。
  • close(self,price):调用TurtleResult类定义的close函数计算单笔开平仓交易盈亏。创建列表专门缓存开平仓交易盈亏。
  • getLastPnl(self):在开平仓交易盈亏列表中获取上一笔交易的盈亏
  • calculateTradePrice(self,direction,price):设置停止单价格,要求买入时,停止单成交的最优价格不能低于当前K线开盘价;卖出时,停止单成交的最优价格不能高于当前K线开盘价

 
 

c.TurlePortofolio类


根据账户资金和品种合约规模,产生具体交易委托

  • __init__(self,engine):初始化海龟投资组合的组合市值(即账户资金)和多空头持仓,创建多个字典分别缓存海龟信号、每个品种持仓情况、交易中的信号、合约大小、单位头寸规模、真实持仓量。
  • init(self,portafolio,vtSymbolList,sizeDict):传入组合市值和合约大小字典,调用TurtleSignal类来产生短周期版本和长周期版的交易信号(包括入场,止盈,止损),同时缓存到信号字典中。
  • onBar(self,bar):根据信号字典产生具体交易委托
  • newSignal(self,signal,direction,offset,price,volume):先计算单位头寸规模,然后若委托指令是开仓需要检查上一次是否盈利,若无盈利发出买入/卖空委托;若委托指令是平仓,需要注意平仓量不能超过空头持仓。同时注意单品种和组合持仓都不能超过上限。
  • sendOrder(self, vtSymbol, direction, offset, price, volume, multiplier):计算单品种持仓和整体持仓,向回测引擎中发单记录

这篇关于海龟策略深入研究-策略回测系列-6 理解海龟策略代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922775

相关文章

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念