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

鼎元C++期货量化/程序化教程【平滑异同移动平均线(Moving Average Convergence Divergence,MACD)计算方法及调用方法】

鼎元C++期货量化/程序化教程【平滑异同移动平均线(Moving Average Convergence Divergence,MACD)计算方法及调用方法】

鼎元C++期货量化/程序化教程【平滑异同移动平均线(Moving Average Convergence Divergence,MACD)计算方法及调用方法】

1、头文件变量声明:

  1.         vector<double>pc;//priceclose,pc简称
  2.         vector<double>emashort,emalong,diff,dea;
  3.         double macd;//获取macd值,柱状图线数值
复制代码
2、源文件加入数组vector返回 ema均线数据程式码模块:
  1. //ema计算公式开始(返回数组)
  2. /*
  3. 从map<string,mapK>制式数据中分离需要处理的数据,然后通过这此的ema方式取得这些数据的ema平均,返回值仍然是数组vector
  4. */
  5. vector<double> test::ema(vector<double> pc, int num)
  6. {
  7.         vector<double> ema;
  8.         double emavector = 0;
  9.         int i = 0;

  10.         for (int it = 0; it < pc.size(); ++it)
  11.         {
  12.                 if (i < num)
  13.                 {
  14.                         emavector = (emavector + pc[it]) / (i + 1);
  15.                         i++;
  16.                         ema.push_back(emavector);
  17.                 }
  18.                 else
  19.                 {
  20.                         emavector = (2 * pc[it] + (num - 1) * emavector) / (num + 1);
  21.                         ema.push_back(emavector);
  22.                 }
  23.         }
  24.         return ema;
  25. }
复制代码
3、源文件加入MACD程式码模块:
  1. RsqBar(sPeriod, sInst);
  2.         map<string,TKVALUE>::iterator it;
  3.         for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); it++)
  4.         {
  5.                 pc.push_back(it->second.dClose); //将收盘价放入pc容器vector
  6.         }
  7.         emashort = ema(pc,12);
  8.         emalong = ema(pc,26);

  9.         for (int i = 0; i < emalong.size(); i++)
  10.         {
  11.                 diff.push_back(emashort[i] - emalong[i]); //DIFF - DEA
  12.         }
  13.         dea = ema(diff,9); //dea = xaverage(diff,9)
  14.         macd = (diff[diff.size()-1] - dea[dea.size()-1])*2; //获取MACD柱数值
复制代码
3、调用方法:
  1.         InsertLog("diff值为: " + to_string(diff[diff.size() - 1]));
  2.         InsertLog("dea均线值为: " + to_string(dea[dea.size() - 1]));
  3.         InsertLog("MACD值为: " + to_string(macd));
复制代码
类似这样。

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

返回列表