: | : | :期货量化学习 | :期货量化 |
返回列表 发帖

鼎元C++期货量化/程序化教程【波动率(Volatility)计算方法及调用方法】

鼎元C++期货量化/程序化教程【波动率(Volatility)计算方法及调用方法】

过内外网搜集与整理,我们可以发现对于波动率有两种计算方式,一是atr计算方法。二是标准差计算方式。波动率做为一种计算证券期货价格无效波动幅度的指标多用到进场与出场模块中,也就是在进场和出场时设定一个免疫的波动幅度,在此波动幅度内是不进场或出场的。

计算历史波动率(calculating historical volatility),计算出来的是加权波动平均率。

1、头文件声明变量:
  1.         double Volatility(string period, string inst, int num);//计算历史波动率(CALCULATING HISTORICAL VOLATILITY)
复制代码
2、公式模块增加计算公式:
  1. //计算历史波动率(calculating historical volatility)
  2. double test::Volatility(string period, string inst, int num)
  3. {
  4.        double dPreClose = 0;//获取每个bar对前的前一个bar的收盘价
  5.         double tr = 0; //tr的值计算
  6.         vector<double>vtr; //建立一个数组,用来存放每个bar对应的truerange值,它们的下标号与bar的是一致的
  7.         if (mapK[period][inst].size() < num) return 0; //如果数据数量不够返回0;
  8.         map<string, TKVALUE >::iterator it; //建立正迭代器,标号从0开始,一般从左向右开始
  9.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it) //从第一开始的bar数据开始遍历
  10.         {
  11.                 if (dPreClose != 0) //如果值不为0说明是在中间的bar,开始在bar数据要素中采集需要的变量数值
  12.                 {
  13.                         double d = it->second.dHigh - it->second.dLow;
  14.                         double dHC = abs(it->second.dHigh - dPreClose);
  15.                         double dLC = abs(it->second.dLow - dPreClose);
  16.                         double e = max3(d, dHC, dLC); //获得每一个bar对应的truerange值
  17.                         vtr.push_back(e); //将上面e的值放到tr的vector(数组)里面供下面使用
  18.                 }
  19.                 dPreClose = it->second.dClose; //将第一个bar的收盘价数值赋给此变量
  20.         }
  21.         for (int i = 0; i < num; i++) //计算tr的num周期指数移动平均值
  22.         {
  23.                 tr = tr* (num-1)/(num + 1) + (vtr[vtr.size() - i]) * 2 /(num + 1); // 2/(num + 1)指数移动平均线的平滑因子
  24.         }
  25.         return tr;
  26. }
复制代码
3、调用方法:
  1. Volatility(sPeriod, sInst, length);//计算length周期的历史波动率
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   1.本站发布源码(包括函数、指标、策略等)均属开放源码,用意在于让使用者学习程序化语法撰写,使用者可以任意修改语法內容并调整参数。仅限用于个人学习使用,请勿转载、滥用,严禁私自连接实盘账户交易
  2.本站发布资讯(包括文章、视频、历史记录、教材、评论、资讯、交易方案等)均系转载自网络主流媒体,内容仅为作者当日个人观点,本网转载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网不对该类信息或数据做任何保证。不对您构成任何投资建议,不能依靠信息而取代自身独立判断,不对因使用本篇文章所诉信息或观点等导致的损失承担任何责任。
  3.本站发布资源(包括书籍、杂志、文档、软件等)均从互联网搜索而来,仅供个人免费交流学习,不可用作商业用途,本站不对显示的内容承担任何责任。请在下载后24小时内删除。如果喜欢,请购买正版,谢谢合作!
  4.龙听期货论坛原创文章属本网版权作品,转载须注明来源“龙听期货论坛”,违者本网将保留追究其相关法律责任的权力。本论坛除发布原创文章外,亦致力于优秀财经文章的交流分享,部分文章推送时若未能及时与原作者取得联系并涉及版权问题时,请及时联系删除。联系方式:http://www.qhlt.cn/thread-262-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

[C++源码] 波动率(Volatility)相关的程序化策略研究与源码:http://www.qhlt.cn/thread-160439-1-1.html
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

  1. for (int i = 0; i < num; i++) //计算tr的num周期指数移动平均值
  2.         {
  3.                 tr = tr* (num-1)/(num + 1) + (vtr[vtr.size() - i]) * 2 /(num + 1); // 2/(num + 1)指数移动平均线的平滑因子
  4.         }
复制代码
这里做个说明:

若是想用指数移动平均就延续上面。

还可以用简单平均:
  1. for (int i = 0; i < num; i++) //计算tr的num周期指数移动平均值
  2.         {
  3.                 tr = tr  + (vtr[vtr.size() - i])  / num;
  4.         }
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

有疑问或交流可以在这里回贴或进群交流。
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

今天对核心思路做一下修正:
  1. //计算历史波动率(calculating historical volatility)
  2. double test::Volatility(string period, string inst, int num)
  3. {
  4.         double PreClose = 0;//获取每个bar前一个bar的收盘价
  5.         double tr = 0; //tr的值计算
  6.         int key = 0; //计数器
  7.         vector<double>vtr; //建立一个数组,用来存放每个bar对应的truerange值,它们的下标号与bar的是一致的
  8.         if (mapK[period][inst].size() < num) return 0; //如果数据数量不够返回0;
  9.         map<string, TKVALUE >::iterator it; //建立正迭代器,标号从0开始,从左向右开始
  10.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it) //从第一开始的bar数据开始遍历
  11.         {
  12.                 if (PreClose != 0) //如果值不为0说明是在中间的bar,开始在bar数据要素中采集需要的变量数值
  13.                 {
  14.                         double dHL = it->second.dHigh - it->second.dLow; //当根bar的最高减最低
  15.                         double dHC = abs(it->second.dHigh - PreClose); //当根bar最高减昨日收盘
  16.                         double dLC = abs(it->second.dLow - PreClose); //当根bar最低减昨日收盘
  17.                         double e = max3(dHL, dHC, dLC); //获得每一个bar对应的truerange值(上面三者之最大者)
  18.                         vtr.push_back(e); //将上面e的值放到tr的vector(数组)里面供下面使用
  19.                 }
  20.                 PreClose = it->second.dClose; //将当前bar的收盘价数值赋给此变量供下一个bar使用
  21.         }
  22.         //计算tr的num周期指数移动平均值
  23.         if (key <= num)
  24.         {
  25.                 tr = 0;
  26.                 key++;
  27.         }
  28.         else
  29.         {
  30.                 tr = (vtr[vtr.size() - 1]) * 2 / (num+1) + tr * (num-1)/(num+1); // 2/(num + 1)指数移动平均线的平滑因子
  31.         }
  32.         return tr;
  33. }
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

上面修正主要是最后计算指数平均上面,不需要用for循环的。
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表