Python编写动量交易策略(上)

简介: Python编写动量交易策略(上)

1. 概念介绍

动量交易策略,即Momentum Trading Strategy。在经典力学里,动量即物体质量和速度的乘积,动量一方面描述了物体的运动状态,另一方面也描述了惯性的大小。
在证券市场上,我们也可以把“证券的价格”类比成运动的物体,价格上涨时,可以说价格有着上涨的动量,价格下跌时其具有下跌的动量。这种动量可能会使上涨或下跌继续维持下去,也可能该动量会越来越小,直到使之运动状态发生改变。股票资产组合的中期收益存在延续性,即中期价格具有向某一方向连续变动的动量效应。
关于动量产生的原因,有三种说法:

  1. 反应不足,即利好或利空不能一次完全消化,会持续在股价上体现。
  2. 正反馈模式,即赢者恒赢,输者恒输。
  3. 过度反应,即投资人对信息的高估而作出的决策。

2.计算动量

2.1 作差法求动量

即用今天的价格减去一段时间间隔(m期)以前的价格

在这里插入图片描述
Momentumt为该股票t时期的m期动量
Pt为该股票t时期的价格
Pt-m为该股票在t-m期的价格

以平安银行(000001.SZ)日线数据为例:

# 导入相关模块
import numpy as np
import tushare as ts
import pandas as pd
import mplfinance as mpf
import matplotlib.pyplot as plt

token = 'Your token'   # 输入你的接口密匙,获取方式及相关权限见Tushare官网。
pro = ts.pro_api(token)
df = pro.daily(ts_code='000001.SZ')  # daily为tushare的股票数据接口。

# 将获取到的DataFrame数据进行标准化处理,转换为方便自己使用的一种规范格式。
df = df.loc[:, ['trade_date', 'open', 'high', 'low', 'close', 'vol']]
df.rename(
    columns={
    
        'trade_date': 'Date', 'open': 'Open',
        'high': 'High', 'low': 'Low',
        'close': 'Close', 'vol': 'Volume'},
    inplace=True)       # 重定义列名,方便统一规范操作。
df['Date'] = pd.to_datetime(df['Date'])  # 转换日期列的格式,便于作图
df.set_index(['Date'], inplace=True)  # 将日期列作为行索引
df = df.sort_index()  # 倒序,因为Tushare的数据是最近的交易日数据显示在DataFrame上方,倒序后方能保证作图时X轴从左到右时间序列递增。

查看一下df:
在这里插入图片描述
好,我们继续进行。

# 提取2020年日度收盘价
PABank =df.Close['2020']
PABank.describe()

在这里插入图片描述

# 假设时间跨度m为5,即求滞后5期的收盘价变量
lag5PABank = PABank.shift(5)
# 求5日动量
momentum5 = PABank - lag5PABank
# 绘制收盘价时序图与动量曲线图
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
plt.subplot(211)
plt.plot(PABank,'b*')
plt.xlabel('date')
plt.ylabel('Close')
plt.title('平安银行2020年收盘价时序图&5日动量图')

plt.subplot(212)
plt.plot(momentum5,'r-*')
plt.xlabel('date')
plt.ylabel('momentum5')
plt.show()

效果如图所示:
在这里插入图片描述


2.2 作除法求动量

另一种求动量的方法是作除法,使用t期的价格减去其m期以前的价格Pt-m再除以Pt-m。这种用动量变化率来表示动量的方式,将作差法得到的绝对指标转化成了一套相对指标。可以将不同的股票的股价放在一起有了一定的可比性,但是考虑到不同股票的状况不同,也要参考其本身的波动性情况。
用公式表示t时期的ROC(Rate of Change):
在这里插入图片描述
其中,ROCt表示股票t时期的m期动量值。
依然以平安银行2020年收盘价为例

Momen5 = PABank/lag5PABank -1
Momen5 = Momen5.dropna()
# 然后基本同上:
# 绘制收盘价时序图与动量曲线图
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
plt.subplot(211)
plt.plot(PABank,'b*')
plt.xlabel('date')
plt.ylabel('Close')
plt.title('平安银行2020年收盘价时序图&5日动量图(作除法)')

plt.subplot(212)
plt.plot(Momen5,'r-*')
plt.xlabel('date')
plt.ylabel('momentum5')
plt.show()

效果如图:
在这里插入图片描述

3.定义求动量与作图函数

两个方法求得的动量图在图像上差别并不大。动量值一般采用作差法求得,可以编写一个求动量和作差法绘动量图的函数,以方便我们使用:

# 定义求动量的函数
def momentum(price, period):
    lagPrice = price.shift(period)
    momen = price - lagPrice
    momen = momen.dropna()
    return momen

# 定义求动量且绘时序图及动量图的函数
def momentum_plot(price, period):
    import matplotlib.pyplot as plt
    lagPrice = price.shift(period)
    momen = price - lagPrice
    momen = momen.dropna()
    
    plt.rcParams['font.sans-serif'] = ['SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    plt.subplot(211)
    plt.plot(price,'b*')
    plt.xlabel('date')
    plt.ylabel('Close')
    plt.grid(True)
    plt.title('收盘价时序图(上)&{}日动量图(下)'.format(period))
    
    plt.subplot(212)
    plt.grid(True)
    plt.plot(momen,'r-*')
    plt.xlabel('date')
    plt.ylabel('Momentum')
    plt.show()
# 更多图像美化细节待你完善。
# 调用,求平安银行2020年十日动量图
momentum_plot(PABank,10)

效果如图:
在这里插入图片描述

目录
相关文章
|
2月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
62 3
|
3月前
|
数据可视化 数据处理 Python
如何使用Python实现一个基于均线的交易策略
【10月更文挑战第9天】本文介绍了如何使用Python实现一个基于均线的交易策略。主要步骤包括导入所需库(如`pandas`、`numpy`和`matplotlib`),加载股票或期货的历史数据,计算均线和其他指标,实现交易策略逻辑,以及可视化交易结果。示例代码展示了如何根据均线交叉点进行开仓、止损和止盈操作,并提供了注意事项,如数据来源、交易成本和风险管理。
104 7
|
2月前
|
数据采集 存储 算法
Python 中的数据结构和算法优化策略
Python中的数据结构和算法如何进行优化?
|
3月前
|
机器学习/深度学习 数据采集 TensorFlow
智能市场营销策略优化:使用Python实现深度学习模型
【10月更文挑战第1天】 智能市场营销策略优化:使用Python实现深度学习模型
190 63
|
2月前
|
算法 数据处理 开发者
超越传统:Python二分查找的变种策略,让搜索效率再上新台阶!
本文介绍了二分查找及其几种Python实现的变种策略,包括经典二分查找、查找第一个等于给定值的元素、查找最后一个等于给定值的元素以及旋转有序数组的搜索。通过调整搜索条件和边界处理,这些变种策略能够适应更复杂的搜索场景,提升搜索效率和应用灵活性。
39 5
|
2月前
|
Python
不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感
本文介绍了Python中图的表示方法及遍历策略。图可通过邻接表或邻接矩阵表示,前者节省空间适合稀疏图,后者便于检查连接但占用更多空间。文章详细展示了邻接表和邻接矩阵的实现,并讲解了深度优先搜索(DFS)和广度优先搜索(BFS)的遍历方法,帮助读者掌握图的基本操作和应用技巧。
41 4
|
2月前
|
算法 IDE API
Python编码规范与代码可读性提升策略####
本文探讨了Python编码规范的重要性,并深入分析了如何通过遵循PEP 8等标准来提高代码的可读性和可维护性。文章首先概述了Python编码规范的基本要求,包括命名约定、缩进风格、注释使用等,接着详细阐述了这些规范如何影响代码的理解和维护。此外,文章还提供了一些实用的技巧和建议,帮助开发者在日常开发中更好地应用这些规范,从而编写出更加清晰、简洁且易于理解的Python代码。 ####
|
2月前
|
数据采集 Web App开发 JavaScript
爬虫策略规避:Python爬虫的浏览器自动化
爬虫策略规避:Python爬虫的浏览器自动化
|
2月前
|
数据采集 数据可视化 数据处理
如何使用Python实现一个交易策略。主要步骤包括:导入所需库(如`pandas`、`numpy`、`matplotlib`)
本文介绍了如何使用Python实现一个交易策略。主要步骤包括:导入所需库(如`pandas`、`numpy`、`matplotlib`),加载历史数据,计算均线和其他技术指标,实现交易逻辑,记录和可视化交易结果。示例代码展示了如何根据均线交叉和价格条件进行开仓、止损和止盈操作。实际应用时需注意数据质量、交易成本和风险管理。
86 5
|
算法 Python 设计模式
python设计模式(二十二):策略模式
策略模式,让一个类的行为或其算法可以在运行时更改,策略是让实例化对象动态的更改自身的某些方法使用的是types.MethodType绑定。 说起策略的动态更改方法,就不得不对比一下元类的动态增加方法,元类是类的抽象,它负责一个抽象类创建、实例化,是通过type函数来绑定方法。
1381 0