R语言隐马尔可夫模型HMM识别不断变化的股票市场条件

2020-09-04 11:39:08 浏览数 (1)

原文:http://tecdat.cn/?p=3784

了解不同的市场状况如何影响您的策略表现可能会对您的回报产生巨大的影响。

某些策略在波动剧烈的市场中表现良好,而其他策略则需要强劲而平稳的趋势,否则将面临长时间的下跌风险。搞清楚什么时候开始或停止交易策略,调整风险和资金管理技巧,甚至设置进入和退出条件的参数都取决于市场“制度”或当前的情况。

能够识别不同的市场制度并相应地改变您的策略可能意味着市场成功和失败之间的差异。在本文中,我们将探讨如何通过使用一种强大的机器学习算法来识别不同的市场机制,称为“隐马尔可夫模型”。

隐马尔可夫模型

马尔科夫模型是一个概率过程,看当前的状态来预测下一个状态。一个简单的例子就是看天气。假设我们有三个天气条件:多雨,阴天,晴天。如果今天下雨,马尔可夫模型寻找每个不同的天气情况发生的概率。例如,明天可能继续下雨的概率较高,多云的可能性略低,晴天可能性较小。

今天的天气明天的天气变化的概率

多雨的多雨的65%

多雨的多云的25%

多雨的晴朗10%

多云的多雨的55%

多云的多云的20%

多云的晴朗25%

晴朗多雨的10%

晴朗多云的30%

晴朗晴朗60%

这似乎是一个非常简单的过程,但其复杂性在于不知道每个机制转移的概率,以及如何解释这些随时间变化的概率。这就是隐马尔可夫模型(HMM)发挥作用的地方。他们能够估计每个制度的转变概率,然后根据目前的情况输出最可能的制度。

交易申请非常清晰。我们可以将市场定义为看涨,看跌,横盘整理,或者波动率高或者低,或者我们知道的一些因素的综合影响我们的策略的表现,而不是天气条件。

构建真实数据模型

我们正在寻找基于这些因素的不同的市场制度,然后我们可以用它来优化我们的交易策略。为此,我们将使用depmixS4 R库以及可追溯到2012年的EUR / USD日图来构建模型。

首先,我们安装这些库并在R中构建我们的数据集。

代码语言:javascript复制

ModelData <-data.frame(LogReturns,ATR)#为我们的HMM模型创建数据框


ModelData <-ModelData [-c(1:14),]#删除正在计算指标的数据


colnames(ModelData)< - c(“LogReturns”,“ATR”)#name我们的列

我们将LogReturns和ATR设置为我们的响应变量。我们将LogReturns和ATR设置为我们的响应变量。我们将LogReturns和ATR设置为响应变量使用我们刚刚构建的数据框架,要设置3个不同的机制,并将响应分布设置为高斯。

代码语言:javascript复制


HMMfit <-fit(HMM,verbose = FALSE)#将我们的模型添加到数据集中

转换矩阵给了我们从一个状态移动到下一个状态的概率。

代码语言:javascript复制

HMMpost <-posterior(HMMfit)#查找我们的数据集中每个状态的后验概率


#我们可以看到,我们现在有每个状态的概率每天以及最高概率类。

让我们看看我们发现了什么:

每个制度分别的概率:

我们可以看到,机制3往往是高波动和大幅度波动的时期,机制2的特点是中等波动,机制1是低波动的。

隐马尔可夫模型是强大的工具,可以让你洞察不断变化的市场条件。

点击标题查阅往期内容

R语言连续时间马尔科夫链模拟案例 Markov Chains

R语言中实现马尔可夫链蒙特卡罗MCMC模型

R语言使用马尔可夫链对营销中的渠道归因建模

R语言如何做马尔科夫转换模型markov switching model

matlab中的隐马尔可夫模型(HMM)实现

matlab贝叶斯隐马尔可夫hmm模型实现

R语言马尔可夫体制转换模型Markov regime switching

R语言马尔可夫转换模型研究交通伤亡人数事故预测

R语言中的马尔科夫机制转换(Markov regime switching)模型

更多内容,请点击左下角“阅读原文”查看

0 人点赞