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

鼎元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

上面的计算总是有些出入,所以这里我重新设计了一下,对比一下东财的数据,还是基本不错的。
如何访问权限为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.         vector<double>EMAvectorCaL(vector<double>pc, int num);//EMA容器计算形式
  2.         vector<double>MACDcalculate(vector<double>pc, int shortPeriod, int longPeriod);//计算MACD
复制代码
  1.         vector<double>pc,diff, dea, macd;
复制代码
第二部分:源文件公式函数部分
  1. ////////////////////////////////////////////////////////////////////////////////////////////////////////////MACD公式计算
  2. vector<double>test::EMAvectorCaL(vector<double>pc, int num)//EMA容器计算形式
  3. {
  4.         vector<double> ema(pc.size());
  5.         double multiplier = 2.0/(num+1);
  6.         ema[0] = pc[0]; // 初始化第一值为价格的第一个值
  7.         for (int i = 1; i < pc.size(); i++) {
  8.                 ema[i] = (pc[i] - ema[i-1]) * multiplier + ema[i-1];
  9.         }
  10.         return ema;
  11. }
  12. vector<double>test::MACDcalculate(vector<double>pc, int shortPeriod, int longPeriod)
  13. {
  14.         // 计算快线和慢线的 EMA
  15.         vector<double> shortEMA = EMAvectorCaL(pc, shortPeriod);
  16.         vector<double> longEMA = EMAvectorCaL(pc, longPeriod);

  17.         // 计算 DIFF
  18.         vector<double> diff(pc.size());
  19.         for (int i = 0; i < pc.size(); i++)
  20.         {
  21.                 diff[i] = shortEMA[i] - longEMA[i];
  22.         }
  23.         return diff;
  24. }
  25. ////////////////////////////////////////////////////////////////////////////////////////////////////////////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);
  6.         }
  7.        
  8.         // MACD 参数
  9.         int shortPeriod = 12; // 快速 EMA 周期
  10.         int longPeriod = 26;  // 慢速 EMA 周期
  11.         int signalPeriod = 9; // 信号线 EMA 周期
  12.         // 计算并输出diff
  13.         diff = MACDcalculate(pc, shortPeriod, longPeriod);
  14.         dea  = EMAvectorCaL(diff, signalPeriod);
  15.         //计算 MACD 柱状图
  16.         vector<double> macd(pc.size());
  17.         for (size_t i = 0; i < pc.size(); i++)
  18.         {
  19.                 macd[i] = 2 * (diff[i] - dea[i]); // 通常将 MACD 值乘以 2
  20.         }
  21.         InsertLog("最新diff " + to_string(diff[diff.size() - 1]) + "最新dea " + to_string(dea[dea.size() - 1]) + "最新MACD " + to_string(macd[macd.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

返回列表