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

鼎元C++期货量化/程序化教程【averagetruerange、avgtruerange、truehigh、truelow的计算方法及调用方法】

鼎元C++期货量化/程序化教程【averagetruerange、avgtruerange、truehigh、truelow的计算方法及调用方法】

这里主要是集中整理与优化跟atr有关的一些公用与用法。

第一部分、说一下原理:

1、根据原始理论,计算truehigh与truelow;

计算方法是上一bar的收盘价与当根bar的最高和最低进行比较,获得truehigh,truelow;

2、计算truerange:上面的truehigh - truelow就是了。

3、然后平均一下获得avgtruerange。也就是atr了。

第二部分、公式计算方法:

1、在头文件声明变量:
  1.         double truehigh(string period, string inst, int num);
  2.         double truelow(string period, string inst, int num);
  3.         double truerange(string period, string inst, int num);
  4.         double avgtruerange(string period, string inst, int num);
复制代码
2、在源文件设计公式计算方法:
  1. //***********************AVGtruerange相关公式计算
  2. double test::truehigh(string period, string inst, int num)
  3. {
  4.         double dPreClose = 0; //声明上一bar收盘价变量
  5.         double truehigh = 0; //获取truehigh值

  6.         if(mapK[period][inst].size() < num) return 0; //如果数据不够就不计算

  7.         map<string, TKVALUE >::iterator it;//设计迭代器
  8.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  9.         {
  10.                 if(dPreClose == 0 ) dPreClose = it->second.dClose; //第一轮遍历获得时间最早的bar的收盘价

  11.                 if (dPreClose != 0) // 第二轮及以后获取bar的要素与前一bar的数据进行比较
  12.                 {
  13.                         double dH = it->second.dHigh; //获取下一根bar的最高价
  14.                        
  15.                         if (dPreClose > dH)
  16.                         {
  17.                                 truehigh = dH;
  18.                         }
  19.                         else
  20.                         {
  21.                                 truehigh = dPreClose;
  22.                         }
  23.                         dPreClose = it->second.dClose;//获取最新的收盘价以供下一bar进行比较计算用。
  24.                 }
  25.         }
  26.         return truehigh;
  27. }
  28. double test:: truelow(string period, string inst, int num)
  29. {
  30.         double dPreClose = 0; //声明上一bar收盘价变量
  31.         double truelow = 0; //获取truelow值

  32.         if (mapK[period][inst].size() < num) return 0; //如果数据不够就不计算

  33.         map<string, TKVALUE >::iterator it;//设计迭代器
  34.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  35.         {
  36.                 if (dPreClose == 0) dPreClose = it->second.dClose; //第一轮遍历获得时间最早的bar的收盘价

  37.                 if (dPreClose != 0) // 第二轮及以后获取bar的要素与前一bar的数据进行比较
  38.                 {
  39.                         double dL = it->second.dLow; //获取下一根bar的最高价

  40.                         if (dPreClose > dL)
  41.                         {
  42.                                 truelow = dL;
  43.                         }
  44.                         else
  45.                         {
  46.                                 truelow = dPreClose;
  47.                         }
  48.                         dPreClose = it->second.dClose;//获取最新的收盘价以供下一bar进行比较计算用。
  49.                 }

  50.         }
  51.         return truelow;
  52. }
  53. double test::truerange(string period, string inst, int num)
  54. {
  55.         double d = truehigh(sPeriod, sInst, num) - truelow(sPeriod, sInst, num);
  56.        
  57.                 return d;
  58. }
  59. double test::avgtruerange(string period, string inst, int num)
  60. {
  61.         double d = truerange(sPeriod, sInst, num);

  62.         return d;
  63. }
复制代码
3、在策略中调用方法:
  1. avgtruerange(sPeriod, sInst, num);
复制代码
就可以取的NUM周期的平均atr值了。

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   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

有待我继续优化与整理,暂时不要使用。
如何访问权限为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. }
  2. //***********************AVGtruerange相关公式计算
  3. double test::truerange(string period, string inst)
  4. {
  5.         double dPreClose = 0; //声明上一bar收盘价变量
  6.         double range = 0;
  7.         if (mapK[period][inst].size() < num) return 0; //如果数据不够就不计算

  8.         map<string, TKVALUE >::iterator it;//设计迭代器
  9.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  10.         {
  11.                 if (dPreClose != 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 range = max3(d, dHC, dLC);
  17.                 }
  18.                 dPreClose = it->second.dClose; //第一轮遍历获得第一根bar的收盘价
  19.         }
  20.                 return range;
  21. }

  22. double test::avgtruerange(string period, string inst, int num)
  23. {
  24.         double d = 0;
  25.         int n = 0;
  26.         map<string, TKVALUE >::iterator it;//设计迭代器
  27.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  28.         {
  29.                 d += truerange(sPeriod, sInst);
  30.                 n++;
  31.                 if (n >= num)break;
  32.         }
  33.         return d / n;
  34. }
复制代码
一个需要继续完善的atr计算公式。
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表