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

鼎元C++期货量化/程序化教程【加权移动平均线(Weighted Moving Average,WMA)的计算方法及调用方法】

鼎元C++期货量化/程序化教程【加权移动平均线(Weighted Moving Average,WMA)的计算方法及调用方法】

一、头文件声明变量
  1. double waverage(string period, string inst, int num);//计算Weighted Moving Average,加权移动平均线
复制代码
二、源文件计算公式:
  1. //计算Weighted Moving Average,加权移动平均线开始
  2. double test::waverage(string period, string inst, int num)
  3. {
  4.         double sumwma = 0;
  5.         int i = 0;
  6.         if (mapK[period][inst].size() < num) return 0; //bar数量不足时返回0
  7.         map<string, TKVALUE>::reverse_iterator it; //逆迭代器,从最新数据开始
  8.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
  9.         {
  10.                         sumwma += (num - i) * it->second.dClose; // 计算 num*close + (num-1)*close[1] + ... + 1*close[num-1]的总和
  11.                         i++;
  12.                         if (i >= num) break;//循环num轮后退出(注意循环是从0开始的到num-1,自动+1至num时就满足跳出条件了)
  13.         }
  14.         double d = (num + 1) * num * 0.5; //计算num从1到num的总和
  15.         return sumwma / d;
  16. }
复制代码
三、调用方法:
  1. wma = waverage(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. //计算Weighted Moving Average,加权移动平均线
  2. double test::waverage(string period, string inst, int num)
  3. {
  4.      double wema = 0;
  5.         int sumclose = 0;
  6.         int sumi = 0;
  7.         int key = 0;
  8.         vector<double>vwema;
  9.         if (mapK[period][inst].size() < num) return 0;   //如果数据不够用就返回0;
  10.         map<string, TKVALUE >::reverse_iterator it;//建立逆向迭代器
  11.         for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it) //从右向左开始
  12.         {
  13.                 vwema.push_back(it->second.dClose); //将收盘价装入容器,因为是逆序,所以在VECTOR里面越新的收盘价最靠左。
  14.                 key++; //计数器自动加1
  15.                 if (key >=num)break;//因为是从0开始的,所以到num-1时就已经获取num个数据,所以返回就行了
  16.         }
  17.         for (int i = 0; i < num; i++) //建立 for循环,用来加总收盘价和I
  18.         {
  19.                 sumclose += vwema[i] * (num - i); //将容器里面元素按此规律加总 vwema[0]*num + vwema[1]*(num-1) + ...+vwema[num-1]*1
  20.                 sumi += i; //加总i
  21.         }
  22.         return wema = sumclose /(sumi+num); //因为i是从0开始的,所以加总 1 + 2 + ... + num = sumi + num最后一项
  23. }
复制代码
如何访问权限为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

上面两个核心框架从简洁程度上建议大家使用第一个,不过第二个也是很不错滴的。
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表