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

鼎元C++期货量化/程序化教程如何使用容器(vector)对bar数据进行高级处理【vector容器使用范例:正迭代计算xaverage/ema值】

鼎元C++期货量化/程序化教程如何使用容器(vector)对bar数据进行高级处理【vector容器使用范例:正迭代计算xaverage/ema值】

我将在这个主题中通过两个方式来计算xaverage/ema的值。分别是公式调用计算方式和主程序计算方式,计算出来的都是数组的形式,不过要到具体的值也很方便。现在 开始。

1、主程序计算xaverage/ema方法

头文件声明变量:
  1.         vector<double>pc;//进行数组设计时统一的数组变量,方便以后使用中统一口径;
  2.         vector<double> re;
  3.         double d=0;
复制代码
主程序计算xaverage/ema公式算法:
  1. //将收盘价装入容器变量PC中
  2.         map<string, TKVALUE>::iterator it;//迭代
  3.     for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); it++) //遍历所有K线
  4.      {
  5.                 pc.push_back(it->second.dClose);//将收盘价存储到pc容器中,按正序排序
  6.       }
  7.         
  8.         //主程序中用VECTOR计算xaverage/ema值
  9.         for (int i = 0; i < pc.size(); i++)
  10.         {
  11.                 if (i < length) //如果bar的数目不够基本的周期,则返回加总除以bar数目+1代替
  12.                 {
  13.                         d = (d + pc[i])/(i+1);
  14.                         re.push_back(d);
  15.                 }
  16.                 else //如果bar数目大于或等于基本周期length个数据时
  17.                 {
  18.                         d = (2 * pc[i] + (length-1) * d)/(length+1); //[ema计算方法:ema = a*close + (1-a)*ema[1],a一般为2/(n+1)]
  19.                         re.push_back(d);
  20.                 }
  21.         }
  22.     InsertLog("正迭代之加权均线值主程序算法: " + to_string(re[re.size() - 1])); //将新变量最新值输出到日志
复制代码
解析:

1、在头文件声明变量
2、在主程序调用数据。先将收盘价装入PC容器。然后开始算法计算

   1、若是bar数据少于设置的周期length数目时,计算方法是所有收盘价加总,然后除以bar数目+1;
   2、若是bar数据多于设置的周期length数目时,计算方法是新ema值 = 2*收盘价 + (length-1)*ema前值 这两项的和再除以length+1 后就获得ema最新bar的xaverage/ema值。

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

2、调用函数计算xaverage/ema方法

1、将收盘价存储到PC容器变量中
  1.         //调用bar数据,要包括品种合约,运行周期
  2.         RsqBar(sPeriod, sInst);
  3.         //装收盘价装后容器变量PC中
  4.         map<string, TKVALUE>::iterator it;//迭代
  5.     for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); it++) //遍历所有K线
  6.      {
  7.                 pc.push_back(it->second.dClose);//将收盘价存储到pc容器中,按正序排序
  8.       }
复制代码
2、建立ema调用函数算法

头文件声明变量:
  1.         vector<double>emaarray(vector<double> pc, int num); //ema计算公式(返回数组);
复制代码
公式区调用函数算法:
  1. //ema计算公式开始(返回数组)
  2. vector<double> test::emaarray(vector<double> pc, int num)
  3. {
  4.         vector<double> r;
  5.         double d = 0;

  6.         for (int i = 0; i < pc.size(); i++)
  7.         {
  8.                 if (i < num)
  9.                 {
  10.                         d = (d + pc[i])/(i+1);
  11.                         r.push_back(d);
  12.                 }
  13.                 else
  14.                 {
  15.                         d = (2*pc[i]+(num-1)*d)/(num+1);
  16.                         r.push_back(d);
  17.                 }
  18.         }
  19.         return r;
  20. }
复制代码
3、调用办法:
  1. vector
  2.         <double>emavalue;
  3.         emavalue = emaarray(pc, length);
  4.         
  5.         InsertLog("正迭代之ema均线值引用算法: " + to_string(emavalue[emavalue.size() - 1])); //将新变量最新值输出到日志
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

3、函数调用数值法。非2中的数组式函数法。
  1. //ema计算公式开始
  2. double test::ema(string period, string inst, int num)
  3. {
  4.         double d = 0;
  5.         int r = 0;
  6.         map<string, TKVALUE >::iterator it;
  7.         for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it)
  8.         {
  9.                 if (r < num)//当数据不够num个bar时用总和/(bar个数加1)
  10.                 {
  11.                         d=(d+it->second.dClose)/(r+1);
  12.                         r++;
  13.                 }
  14.                 else //当bar的总个数大于num个周期时,ema = a*close + (1-a)*ema[1],a一般为2/(num+1)
  15.                 {
  16.                         d=(2*it->second.dClose+(num-1)*d)/(num+1);
  17.                 }
  18.         }
  19.         return d;
  20. }
复制代码
调用办法:
  1.         InsertLog("逆迭代之ema均线值引用算法: " + to_string(ema(sPeriod, sInst, length))); //将新变量最新值输出到日志
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表