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

C++程序化/量化学习视频教程系列 第054节:鼎元C++量化之如何使用容器(vector)对bar数据进行中级处理【vector容器使用范例:正迭代计算简单均线average】

C++程序化/量化学习视频教程系列 第054节:鼎元C++量化之如何使用容器(vector)对bar数据进行中级处理【vector容器使用范例:正迭代计算简单均线average】

C++程序化/量化学习视频教程系列 第054节:鼎元C++量化之如何使用容器(vector)对bar数据进行中级处理【vector容器使用范例:正迭代计算简单均线average】



C++程序化学习视频教程系列安排如下:
第一楼:教学视频。一般控制在15分钟左右;
第二椄:视频课程中使用的程式源码。
第三楼:视频教学中需要用到的一些文档或资源。
第四楼:其它的一些边角料,特别是一些经典程序化策略的回测类的部分会放到下面楼层里面。

参与模式如下:
1、希望参与到编写策略与调试方面的工作通过上面的联系方式联系管理员咨询即可。记的加群,有问题第一时间交流,也可以在论坛指定版发贴交流,专用版地址:http://www.qhlt.cn/forum-244-1.html
2、有意申请试用及绑定期货账户跑实盘网友可以联系管理员,以及开通的方式。
3、基于C++策略交易软件具有:1、软件小(50兆不到);2、效率高(C++语言);3、功能精(专注于策略);4、对服务噐或电脑兼容性好(WIN系统)等优势,特别适合长期跑程序化的客户朋友,特别是有稳定交易模式客户更适合使用C++构建的交易系统。
4、最全的C++期货程序化(量化)教程、视频、源码、课件、资源汇总贴【C++期货程序化/量化研究必备资源贴!】:http://www.qhlt.cn/thread-160231-1-1.html
5、鼎元C++量化程式码技术指标源码C++版模板【建议在test.h和test.cpp中同步至最新,方便统一调用和使用,一次编辑多次使用!】:http://www.qhlt.cn/thread-160230-1-1.html
6、如何使用鼎元C++量化软件以及需要准备的些什么?[C++量化入门必读!]:http://www.qhlt.cn/thread-160415-1-1.html

联系方式:
C++微信群:  QQ群: 管理员微信:;管理员QQ:

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

test.h头文件中先声明vector变量:
  1.         vector<double>pc;//进行数组设计时统一的数组变量,方便以后使用中统一口径;
  2.         vector<double> re;
  3.         int r=0 ;
  4.         double d=0;
  5.         double e=0;
复制代码
test.cpp源文件中将收盘价存储 到上面声明的变量中
  1.       RsqBar(sPeriod, sInst);
  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.       }
复制代码
  1. //主程序中用VECTOR计算均线值
  2.         for (int i = 0; i < pc.size(); i++)
  3.         {
  4.                 if ( i < length) //如果bar的数目不够基本的周期,则返回加总除以bar数目代替
  5.                 {
  6.                         d = (d + pc[i]) / (i+1);
  7.                         re.push_back(d);
  8.                 }
  9.                 else //如何bar数目大于基本周期num个数据,则通过for循环向前加总num个数组除num周期得均线值
  10.                 {
  11.                         for (size_t j = 0; j < length; j++) //循环length次
  12.                         {
  13.                                 e = e + pc[i - j]; //从现有bar向左加总length个数据
  14.                         }
  15.                         d = e / length;
  16.                         re.push_back(d);
  17.                         e = 0;//将e重置成0方便下一个bar继续循环使用
  18.                 }
  19.         }
  20.       
  21.         InsertLog("正迭代之均线值引用公式计算: " + to_string(re1[re.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

在主程序中设计在日志区输出:
  1.         for (size_t k = 0; k < length; k++)
  2.         {
  3.                 InsertLog("从最新bar向左第 " + to_string(k) + " 个bar收盘价为: " + to_string(pc[pc.size() - 1 - k]))
  4.         }
  5.         InsertLog("正迭代均线值公式计算: " + to_string(re[re.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

视频中主程序计算策略程式码部分:
  1. //调用bar数据,要包括品种合约,运行周期
  2.         RsqBar(sPeriod, sInst);
  3.         //迭代
  4.         map<string, TKVALUE>::iterator it;//正向迭代
  5.         for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); it++)
  6.         {
  7.                 pc.push_back(it->second.dClose); //将收盘价存入PC容器(按正序排列)
  8.         }
  9.        
  10.         //声明几个需要用到的中间变量
  11.         vector<double>re;
  12.         double d = 0;
  13.         double e = 0;

  14.         //在主程序中用vector计算平均值(average)
  15.         for (size_t i = 0; i < pc.size(); i++) //建立for循环,处理数据
  16.         {
  17.                 if (i < length) //如果bar的收盘价价pc里面的数据不到指定的周期数量,比方说length周期均值,但是数据数量只有length-1个
  18.                 {
  19.                         d = (d + pc[i]) / (i + 1);//加总每一个pc的元素的价格,并除以现有的pc收盘价的个数代替length周期均值
  20.                         re.push_back(d);//将计算出的均值替代赋与re容器,排列顺序与pc容器一致
  21.                 }
  22.                 else //如果pc数据大于或等于length个时,就可以按正常方法计算均值了
  23.                 {
  24.                         for (size_t j = 0; j < length; j++) //再套一个for循环,换一个名称j
  25.                         {
  26.                                 e = e + pc[i - j]; //现在外面大循环是第i次,然后用一个for循环从右向左依次加总length个数值,
  27.                         }
  28.                         d = e / length; //将上面的加总除以length周期数,即可得第i个pc数据与之前的length-1个数据的均值了。
  29.                         re.push_back(d);//将均值存储入re容器中
  30.                         e = 0;//将e重置成0方便下次循环i+1继续循环使用
  31.                 }
  32.         }
  33.         //在主程序中设计日志输出
  34.         for (size_t k = 0; k < length; k++)
  35.         {
  36.                 InsertLog("从最新bar向左第 " + to_string(k) + " 个bar收盘价为: " + to_string(pc[pc.size() - 1 - k])); //打印输出length周期个pc的收盘价数据至日志面板
  37.         }
  38.         InsertLog("正迭代均值公式计算: " + to_string(length) + "周期个pc收盘价均值为: " + to_string(re[re.size() - 1])); //将re容器中最新的length周期个pc收盘价的均值输出到面板
复制代码
pc的vectro声明已经在test.h头文件中声明,所以在主程序中就不再声明了。
如何访问权限为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

返回列表