1、alpha对冲(期货)

投资者在市场交易中面临着系统性风险(即贝塔或Beta、β风险)和非系统性风险(即阿尔法或Alpha、α风险),通过对系统性风险进行度量并将其分离,从而获取超额绝对收益(即阿尔法收益)的策略组合,即为阿尔法策略。

alpha对冲源代码:

import pandas as pd

# 加载历史数据欧美5.5

data = pd.read_csv('data.csv')

# 计算Alpha

data['Alpha'] = data['Alpha_Indicator'] - data['Beta_Indicator']

# 生成交易信号大恒指35

data['Signal'] = 0

data.loc[data['Alpha'] > 0, 'Signal'] = 1  # Alpha指标大于0时买入

data.loc[data['Alpha'] < 0, 'Signal'] = -1  # Alpha指标小于0时卖出

# 计算持仓小恒指25

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果扣1839716836

print(data)

代码中使用了pandas库来处理数据和计算指标,你需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据和Alpha指标数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还需要根据实际情况进行Alpha指标的计算和调整,该示例中使用了Alpha_Indicator和Beta_Indicator两个指标来计算Alpha。

2、双均线策略(期货)

双均线策略是简单移动平均线策略的加强版。移动平均线目的是过滤掉时间序列中的高频扰动,保留有用的低频趋势。它以滞后性的代价获得了平滑性,比如,在一轮牛市行情后,只有当价格出现大幅度的回撤之后才会在移动平均线上有所体现,而对于投资者而言则大大增加了交易成本。如果使用双均线策略,就可以在考虑长周期趋势的同时,兼顾比较敏感的小周期趋势,无疑是解决简单移动平均线滞后性弱点的一项有效方法。  

双均线策略源代码:

import pandas as pd

# 加载历史数据

data = pd.read_csv('data.csv')

# 计算短期均线

data['Short_MA'] = data['Close'].rolling(window=10).mean()

# 计算长期均线

data['Long_MA'] = data['Close'].rolling(window=20).mean()

# 生成交易信号

data['Signal'] = 0

data.loc[data['Short_MA'] > data['Long_MA'], 'Signal'] = 1 # 短期均线上穿长期均线时买入

data.loc[data['Short_MA'] < data['Long_MA'], 'Signal'] = -1 # 短期均线下穿长期均线时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据和计算指标,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。

3、做市商交易(期货)

做市商的主要利润来自于双向报价的买卖价差。因而,做市商需要计算期权的理论价格,在大量买入和卖出交易中,逐渐积累每笔交易价格和理论价格的差价,并根据持仓头寸特征,动态调整价差。由于做市商以被动成交为主,因而在一些对手方持续大量单边交易的情况下,做市商可能面临损失。

做市商交易期货源代码:

import pandas as pd

# 加载历史数据

data = pd.read_csv('data.csv')

# 设置做市商参数

spread = 0.01 # 买卖价差

inventory = 100 # 初始库存量

position = 0 # 初始仓位

# 生成交易信号

data['Signal'] = 0

data.loc[data['Ask_Price'] - data['Bid_Price'] > spread, 'Signal'] = 1 # 买卖价差大于设定值时进行交易

# 计算持仓

data['Position'] = data['Signal'].diff()

# 执行做市商交易策略

for i, row in data.iterrows():

         if row['Position'] == 1: # 买入信号

             position += inventory

         elif row['Position'] == -1: # 卖出信号

             position -= inventory

        data.at[i, 'Position'] = position

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据和买卖价位数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,你还可以根据实际情况进行做市商策略的参数设置和调整,该示例中设置了买卖价差和初始库存量。

4、菲阿里四价(期货)

昨天高点、昨天低点、昨日收盘价、今天开盘价,可并称为菲阿里四价。它由日本期货冠军菲阿里实盘采用的主要突破交易参照系。此外,因菲阿里主观心智交易的模式,决定了其在实际交易中还大量结合并运用了“阻溢线”的方式,即阻力线、支撑线。

主要特点:日内交易策略,收盘平仓;菲阿里四价指昨日高点、昨日低点、昨日收盘、今日开盘;上轨=昨日高点;下轨=昨日低点;当价格突破上轨,买入开仓;当价格跌穿下轨,卖出开仓。

菲阿里四价策略源代码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 计算菲阿里指标

data['High_MA'] = data['High'].rolling(window=5).mean()

data['Low_MA'] = data['Low'].rolling(window=5).mean()

data['Close_MA'] = data['Close'].rolling(window=5).mean()

# 生成交易信号

data['Signal'] = 0

data.loc[(data['Close'] > data['High_MA']) & (data['Close'] > data['Close_MA']), 'Signal'] = 1

data.loc[(data['Close'] < data['Low_MA']) & (data['Close'] < data['Close_MA']), 'Signal'] = -1

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据和计算指标,你需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还可以根据实际情况进行参数设置和调整,该示例中使用了5日均线作为菲阿里指标的计算窗口。

5、R-Breaker(期货)

R-Breaker是一种短线日内交易策略,该策略已经在市场上存活了二十年之久,尤其当指数波动较大时,该策略表现越好,根据S&P至2011年底的统计,R-Break也多次名列前十,由于进入榜单的交易系统业绩并不稳定,尤其是一年业绩榜单,时常会发生变化,因此模型的稳定性和一致性其实比短期排名更加关键,杂志给出了长期来看一致性最好的十大交易模型,其中就包括 R-Breaker 等模型,它们的业绩不一定总是能排进前十名的榜单,但长期以来具有较高的一致性。

R-Breaker策略源代码:

import pandas as pd

# 加载历史数据

data = pd.read_csv('data.csv')

# 设置R-Breaker策略参数

n = 20 # 布林通道计算窗口

k1 = 0.4 # 突破上轨的阈值

k2 = 0.4 # 突破下轨的阈值

# 计算布林通道指标

data['MA'] = data['Close'].rolling(window=n).mean()

data['STD'] = data['Close'].rolling(window=n).std()

data['Upper'] = data['MA'] + k1 * data['STD']

data['Lower'] = data['MA'] - k2 * data['STD']

# 生成交易信号

data['Signal'] = 0

data.loc[data['Close'] > data['Upper'], 'Signal'] = 1 # 价格突破上轨时买入

data.loc[data['Close'] < data['Lower'], 'Signal'] = -1 # 价格突破下轨时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据和计算指标,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还可以根据实际情况进行R-Breaker策略参数的设置和调整,该示例中使用了布林通道指标计算上下轨,并设置了突破上轨和突破下轨的阈值。

6、布林线均值回归(期货)

BOLL指标是美国股市分析家约翰·布林根据统计学中的标准差原理设计出来的一种非常简单实用的技术分析指标。一般而言,股价的运动总是围绕某一价值中枢(如均线、成本线等)在一定的范围内变动,布林线指标正是在上述条件的基础上,引进了“股价通道”的概念,其认为股价通道的宽窄随着股价波动幅度的大小而变化,而且股价通道又具有变异性,它会随着股价的变化而自动调整。由于之前大部分交易策略都是选股或者趋势追踪的择时,所以基于这一指标我们设计了一个均值回归的交易策略。

布林线均值回归策略源代码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 设置布林线均值回归策略参数

n = 20 # 布林通道计算窗口

k = 2 # 布林线宽度的倍数

# 计算布林通道指标

data['MA'] = data['Close'].rolling(window=n).mean()

data['STD'] = data['Close'].rolling(window=n).std()

data['Upper'] = data['MA'] + k * data['STD']

data['Lower'] = data['MA'] - k * data['STD']

# 生成交易信号

data['Signal'] = 0

data.loc[data['Close'] < data['Lower'], 'Signal'] = 1 # 价格低于下轨时买入

data.loc[data['Close'] > data['Upper'], 'Signal'] = -1 # 价格高于上轨时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据和计算指标,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还可以根据实际情况进行布林线均值回归策略参数的设置和调整,该示例中使用了布林通道指标计算上下轨,并设置了布林线宽度的倍数。

7 、Dual Thrust(期货)

Dual Thrust是一个趋势跟踪系统,由Michael Chalek在20世纪80年代开发,曾被Future Thruth杂志评为最赚钱的策略之一。Dual Thrust系统具有简单易用、适用度广的特点,其思路简单、参数很少,配合不同的参数、止盈止损和仓位管理,可以为投资者带来长期稳定的收益,被投资者广泛应用于股票、货币、贵金属、债券、能源及股指期货市场等。

R-Breaker策略源代码:

import pandas as pd

# 加载历史数据

data = pd.read_csv('data.csv')

# 设置R-Breaker策略参数

n = 20 # 计算布林带的窗口大小

m = 0.3 # 确定突破买入价的参数

l = 0.3 # 确定突破卖出价的参数 #

计算布林带指标

data['MA'] = data['Close'].rolling(window=n).mean()

data['STD'] = data['Close'].rolling(window=n).std()

data['Upper'] = data['MA'] + m * data['STD']

data['Lower'] = data['MA'] - l * data['STD']

# 生成交易信号

data['Signal'] = 0

data.loc[data['Close'] > data['Upper'].shift(1), 'Signal'] = 1 # 价格突破上轨时买入 data.loc[data['Close'] < data['Lower'].shift(1), 'Signal'] = -1 # 价格突破下轨时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据和计算指标,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还可以根据实际情况进行R-Breaker策略参数的设置和调整,该示例中使用了布林带指标计算上下轨,并设置了突破买入价和突破卖出价的参数。

8、网格交易(期货)

网格交易是利用市场震荡行情获利的一种主动交易策略,其本质是利用投资标的在一段震荡行情中价格在网格区间内的反复运动以进行加仓减仓的操作以达到投资收益最大化的目的。通俗点讲就是根据建立不同数量.不同大小的网格,在突破网格的时候建仓,回归网格的时候减仓,力求能够捕捉到价格的震荡变化趋势,达到盈利的目的。

网格交易策略源代码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 设置网格交易策略参数

grid_size = 0.02 # 网格大小

initial_price = data['Close'].iloc[0] # 初始价格

num_grids = 10 # 网格数量

upper_price = initial_price * (1 + grid_size) # 上限价格

lower_price = initial_price * (1 - grid_size) # 下限价格

# 生成交易信号

data['Signal'] = 0

data.loc[data['Close'] >= upper_price, 'Signal'] = -1 # 价格上穿上限价格时卖出 data.loc[data['Close'] <= lower_price, 'Signal'] = 1 # 价格下穿下限价格时买入

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据,需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还可以根据实际情况进行网格交易策略参数的设置和调整,该示例中设置了网格大小、网格数量以及上限价格和下限价格。

9、海龟交易法(期货)

海龟交易法则属于趋势交易,首先建立唐奇安通道(下文会具体解释),即确定上突破线和下突破线,如果价格突破上线,则做多,如果价格突破下线就平仓或做空。

海龟交易法策略源码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 设置海龟交易法策略参数

entry_window = 20 # 进场窗口大小

exit_window = 10 # 出场窗口大小

n = 2 # 波动性单位倍数

# 计算ATR指标

data['High_Low'] = data['High'] - data['Low']

data['High_PreviousClose'] = abs(data['High'] - data['Close'].shift())

data['Low_PreviousClose'] = abs(data['Low'] - data['Close'].shift())

data['TR'] = data[['High_Low', 'High_PreviousClose', 'Low_PreviousClose']].max(axis=1)

data['ATR'] = data['TR'].rolling(window=entry_window).mean()

# 生成交易信号

data['Signal'] = 0

data.loc[data['Close'] > data['Close'].shift(), 'Signal'] = 1 # 价格上涨时买入

data.loc[data['Close'] < data['Close'].shift(), 'Signal'] = -1 # 价格下跌时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 出场条件

data['Exit_Signal'] = data['Close'].rolling(window=exit_window).mean()

# 回测

data['Return'] = data['Close'].pct_change()

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

10、跨期套利(期货)

跨期套利就是在同一期货品种的不同月份合约上建立数量相等、方向相反的交易头寸,最后以对冲或交割方式结束交易、获得收益的方式。最简单的跨期套利就是买入近期的期货品种,卖出远期的期货品种。

跨期套利策略源代码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 设置跨期套利策略参数

near_contract = 'ContractA' # 近月合约

far_contract = 'ContractB' # 远月合约

# 生成交易信号

data['Signal'] = 0

data.loc[data[far_contract] - data[near_contract] > 0, 'Signal'] = 1 # 远月合约价格高于近月合约价格时买入

data.loc[data[far_contract] - data[near_contract] < 0, 'Signal'] = -1 # 远月合约价格低于近月合约价格时卖出

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data[near_contract].pct_change() # 近月合约的收益率作为策略收益率

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

11、跨品种套利(期货)

跨品种套利是指利用两种不同的,但相互关联的商品之间的合约价格差异进行套利交易,即买入某一交割月份的某种商品合约,同时卖出另一相同交割月份、相互关联的商品合约,以期在有利时机同时将这两个合约对冲平仓获利。跨品种套利的主导思想是寻找两种或多种不同,但具有一定相关性的商品间的相对稳定关系(差值、比值或其他),在其脱离正常轨道时采取相关反向操作以获取利润。根据套利商品之间的关系,跨品种套利可分为相关商品套利和产业链跨品种套利两种类型。

跨品种套利策略源代码:

import pandas as pd

# 加载历史数据 data = pd.read_csv('data.csv')

# 设置跨品种套利策略参数

productA = 'ProductA' # 品种A

productB = 'ProductB' # 品种B

# 生成交易信号

data['Signal'] = 0

data.loc[data[productB] - data[productA] > 0, 'Signal'] = 1 # 品种B价格高于品种A价格时买入品种A,卖出品种B

data.loc[data[productB] - data[productA] < 0, 'Signal'] = -1 # 品种B价格低于品种A价格时卖出品种A,买入品种B

# 计算持仓

data['Position'] = data['Signal'].diff()

# 回测

data['Return'] = data[productA].pct_change() # 品种A的收益率作为策略收益率

data['Strategy_Return'] = data['Position'].shift() * data['Return']

data['Cumulative_Return'] = (1 + data['Strategy_Return']).cumprod()

# 输出结果

print(data)

代码中使用了pandas库来处理数据,你需要提前安装并导入该库。另外,data.csv是一个包含历史价格数据的CSV文件,需要根据自己的需求准备相应的数据文件。同时,还需要根据实际情况设置品种A和品种B的名称,并根据具体的跨品种套利策略进行买入和卖出信号的生成。在该示例中,如果品种B的价格高于品种A的价格,则产生买入品种A、卖出品种B的信号;如果品种B的价格低于品种A的价格,则产生卖出品种A、买入品种B的信号。

精彩链接

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。