zoukankan      html  css  js  c++  java
  • R语言代写隐马尔可夫模型HMM识别不断变化的市场条件

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

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

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

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

    隐马尔可夫模型

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

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

    多雨的多雨的65%

    多雨的多云的25%

    多雨的晴朗10%

    多云的多雨的55%

    多云的多云的20%

    多云的晴朗25%

    晴朗多雨的10%

    晴朗多云的30%

    晴朗晴朗60%

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

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

    构建真实数据模型

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

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

    ModelData <-data.frame(LogReturns,ATR)#为我们的HMM模型创建数据框
    
    ModelData <-ModelData [-c(1:14),]#删除正在计算指标的数据
    
    colnames(ModelData)< - c(“LogReturns”,“ATR”)#name我们的列
    

      

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

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

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

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

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

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

    每个制度分别的概率:

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

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

    如果您有任何疑问,请在下面发表评论。

  • 相关阅读:
    angularjs 判断是否包含 permIDs|filter:'10'
    js日期格式化
    JSON格式检验
    CodeSmith Generator 6.5
    Hosts文件说明
    正则表达式匹配换行实例代码
    Codeforces 311E Biologist
    URAL 1349 Farm
    [SDOI2015] 序列统计
    洛谷 P3803 多项式乘法
  • 原文地址:https://www.cnblogs.com/tecdat/p/11065642.html
Copyright © 2011-2022 走看看