龙听期货论坛's Archiver

龙听 发表于 2024-12-12 10:30

鼎元C++量化程式码指标与函数模块系列之【加权移动平均线(Weighted Moving Average,WMA)的计算方法及调用方法】

一、头文件声明变量[code]
double waverage(string period, string inst, int num);//计算Weighted Moving Average,加权移动平均线
[/code]二、源文件计算公式:[code]
//计算Weighted Moving Average,加权移动平均线开始
double test::waverage(string period, string inst, int num)
{
        double sumwma = 0;
        int i = 0;
        if (mapK[period][inst].size() < num) return 0; //bar数量不足时返回0
        map<string, TKVALUE>::reverse_iterator it; //逆迭代器,从最新数据开始
        for (it = mapK[period][inst].rbegin(); it != mapK[period][inst].rend(); ++it)
        {
                        sumwma += (num - i) * it->second.dClose; // 计算 num*close + (num-1)*close[1] + ... + 1*close[num-1]的总和
                        i++;
                        if (i >= num) break;//循环num轮后退出(注意循环是从0开始的到num-1,自动+1至num时就满足跳出条件了)
        }
        double d = (num + 1) * num * 0.5; //计算num从1到num的总和
        return sumwma / d;
}
[/code]三、调用方法:[code]
wma = waverage(sPeriod, sInst, length);
[/code]

龙听 发表于 2024-12-17 08:36

计算原理参考:[url]http://www.qhlt.cn/thread-160556-1-1.html[/url];

页: [1]