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

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

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

第一部分:头文件声明变量
  1. private:
  2.         //软件界面策略参数设置相关的变量设计(开始)*******************************
  3.          vector<double>highp, lowp;
  4.          int length;  //length:均线类的参数周期统一使用变量,方便后面使用中统一口径;
  5.         //软件界面策略参数设置相关的变量设计(结束)*******************************
复制代码
第二部分:源文件主程序码:
  1. //调用bar数据,要包括品种合约,运行周期
  2.         RsqBar(sPeriod, sInst);
  3.         
  4.         //装收盘价装后容器变量PC中
  5.         map<string, TKVALUE>::iterator it;//迭代
  6.         for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); it++) //遍历所有K线
  7.         {
  8.                 highp.push_back(it->second.dHigh);//将最高价存储到highp容器中,按正序排序
  9.                 lowp.push_back(it->second.dLow);  //将最低价存储到lowp容器中,按正序排序
  10.         }

  11.         vector<double> highestp,lowestp;
  12.         for (size_t i = 0; i < highp.size(); i++)
  13.         {
  14.                 if (i == 0) //如何循环是第一次则将上面highp[0]和lowp[0]值赋给highestp[0]和lowestp[0]
  15.                 {
  16.                         highestp.push_back(highp[i]);
  17.                         lowestp.push_back(lowp[i]);
  18.                 }
  19.                 else if(i < length) //如果循环是大于0而又小于length设置的周期时
  20.                 {
  21.             highestp.push_back(max2(highestp[i - 1], highp[i]));//依次将highestp前一个值与highp当根bar值比较,将最大的者存储入highestp[i]中
  22.                         lowestp.push_back(min2(lowestp[i - 1], lowp[i])); //取最小值类似
  23.                 }
  24.                 else
  25.                 {
  26.                         double d =-9999;//声明一个用来存储length周期内最大值的变量
  27.                         double e = 9999;
  28.                         for (size_t j = 0; j < length; j++) //若是容器中数量大于等于length个时
  29.                         {
  30.                                 d = max2(d, highp[i - j]);//采取从右往左循环将d值与highp[i-j]进行比较,取最大值赋给最新的d
  31.                                 e = min2(e, lowp[i - j]);
  32.                         }
  33.                         highestp.push_back(d);// 将length周期内highp最大值赋给lowestp
  34.                         lowestp.push_back(e); //将length周期内lowp最小值赋给lowestp;
  35.                 }
  36.         }
  37.         InsertLog("周期 " + to_string(length) + " 内最大值为: " + to_string(highestp[highestp.size()-1])); //将length周期内最高值输出
  38.         InsertLog("周期 " + to_string(length) + " 内最小值为: " + to_string(lowestp[lowestp.size() - 1])); //将length周期内最低值输出
  39.         InsertLog("用调用计算的最高价: " + to_string(highest(sPeriod,sInst,length)));
  40.         InsertLog("用调用计算的最低价: " + to_string(lowest(sPeriod, sInst, 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

  1. highest(sPeriod,sInst,length)
  2. lowest(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

返回列表