量化研究 | 残差动量策略刻画与构建(一)

2023-11-23 07:59

本文主要是介绍量化研究 | 残差动量策略刻画与构建(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 致力于分享量化策略,培训视频,Python,程序化交易等相关内容

作者简介

吕洋洋 

某大型资管公司在职量化策略研究员,熟悉数据清洗工作,擅于运用宏观因子、行业因子等进行对期货品种价格影响建模与相关性分析,理解机器学习多元回归法,SVM,XGboost,金融时间序列等底层算法逻辑,部分算法可自定义函数封装。掌 握各种机器学习包与数据计算分析包的运用。包括不限于:Alphalens,pandans,爬虫技术,sklearn,statsmodels 等。

『正文』

ˇ

引言

本期是之前“复权系列”量化研究课题探究的新篇章,本期相对传统CTA策略研究,在基于套利的逻辑基础上,开辟了新的CTA动量捕捉模式。

废话不多说,直接进入正题(笔者最近比较忙,没工夫闲扯了)。残差——该词来源于统计学中的线性回归,回归后无法解释的那部分既是残差,英文称为residual。

一般情况对两组时间序列数据进行回归是统计套利干的事儿,我们如何利用到CTA当中,刻画出择时信号?下面作为该系列的首篇,也是本课题研究的首篇,就先从逻辑→策略构建→代码,一步一步的来构建和实现。

逻辑

在套利当中,我们一般做的是“跨期”、“跨品种”两种套利,但是套利的玩法有很多,其中一种便是将两种具有协整关系的标的资产进行回归,根据回归后的残差进行多空开仓进行套利。而将该逻辑改为趋势择时,实乃笔者一位朋友,偶然之间的发现。在此,笔者也深深感谢这位朋友的无私奉献和耐心给予笔者本人的讲解。

上面谈到了,该逻辑是起于套利,根据两个具有协整性标的资产进行的线性回归刻画,依据残差进行规则性处理后的择时判断,加入传统CTA的波动率止盈止损。

残差

图1 计算残差代码

如上图所示,我们要计算出残差,就要计算出两个品种收盘价格时间序列的斜率和截距,斜率也就是贝塔值。依据中学所学y=ax+b,当我们求得贝塔值→a,随即也就求得b→截距,那么我们首先要求得就是斜率。

斜率

图2 计算斜率公式

上图是计算贝塔值也就是斜率的公式,我们首先要计算出两个标的资产的协方差和某个标的资产的方差,我们举例说明,假设X是铁矿石,Y是螺纹钢,也就是我们需要求出铁矿石和螺纹钢的协方差和铁矿石的方差。

求出协方差同样要按照下面的公式分成两步,第一步求出length周期的平均值,类似均线。第二步求出铁矿石和螺纹钢的变量值与平均值的差值的乘积,后再求期望值(平均)。如下图所示,方差亦然。

方差

图3 计算协方差和方差公式

应用

在我们求得协方差和方差后,根据公式我们即可求得斜率也就是贝塔值。带入到图1中,我们即可求得残差。如下图所示:

上图子图黄色的线既是残差曲线,本文采用时间周期为2016.1.1-至今。从统计套利了角度来看,一般理论上我们是在黄色线的上下极值区间进行相对应的残差回归操作,但是在残差动量策略里面,我们是要跟随残差的趋势进行开平仓择时信号的处理。

那么我们还要对该时间序列数据进行规则型的刻画处理,在这里笔者只是采用教学式思想,加入一个海龟通道,如下图所示:

止盈止损我们采用的是波动率刻画的方法进行止盈止损,如下图所示:

代码如下:

至此,整个策略的进出场我们已经构建完成了,除了策略自身改进迭代以外,本策略采用的日线周期,缺点是交易次数少,也就是频率较低,作为策略的补充所用。最后放上一张样本内外参数优化过的绩效回测图:

结语

本篇是量化研究模块的第二课题——残差动量的第一篇,后续笔者将采用更加“广义”的思路进行策略的迭代和深入的量化研究。本篇内容不仅仅局限于螺纹和铁矿石,可以延展到任何产业链的品种,例如:RB-J,MA-PP,MA-EG,AL-CU,JM-ZC,油脂类等等产业链品种当中。在这里我就不进行重复量的工作,感兴趣的大家可以自行探索和研究。当然也可以加入我们的VIP客户群,找小松鼠客服即可。

最后非常感谢我的朋友濮元恺提供的思路,为我后续的策略开发提供了广阔的思想。

本策略仅作学习交流使用,实盘交易盈亏投资者个人负责。

这篇关于量化研究 | 残差动量策略刻画与构建(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/m0_56236921/article/details/123863201
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/416498

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件