龙听期货论坛's Archiver

龙听 发表于 2024-11-18 10:42

鼎元C++量化程式码指标与函数模块系列之【averagetruerange、avgtruerange、ATR】

第一部分、头文件声明变量:[code]
double avgtruerange(string period, string inst, int num);//计算avgtruerange值
[/code]第二部分、源文件公式计算函数:[code]
double test::avgtruerage(string period, string inst, int num)
{
        double PreClose = 0; //设计一个局部变量存储上一日的收盘价
        double sumatr = 0;  //设计一个加总变量,用来存储和的值
        vector<double>vAtr; // 设计一个vector,存储tr值
        if (mapK[period][inst].size() < num) return 0;   //如果数据不够用就返回0;
        map<string, TKVALUE >::iterator it; //建立一个正迭代器
        for (it = mapK[period][inst].begin(); it != mapK[period][inst].end(); ++it) //建立for循环采集需要的要素数据
        {
                if (PreClose != 0)  //不是第一次循环
                {
                        double dHL = it->second.dHigh - it->second.dLow;  //当天最高价减当天最低价
                        double dHC = abs(it->second.dHigh - PreClose);  //当天最高价减当天收盘价
                        double dLC = abs(it->second.dLow - PreClose); //当天最低价减昨天收盘价
                        vAtr.push_back(max3(dHL, dHC, dLC));  //将上面三个数值中的最大值即tr值存储到vatr容器中
                }
                PreClose = it->second.dClose;  //每次处理完后将当天的收盘价赋值给preclose 供下次使用
        }
        for (int i = 1; i <= num; i++) //建立for循环采集num个周期的数据进行处理
        {
                sumatr += vAtr[vAtr.size() - i];  //将vatr中的数据从右至左顺序依次加总num个
        }
        return  sumatr / num;  // 将上面加总的数值除以num周期就获取了平均的atr值了。
}
[/code]第三部分、调用方法:[code]
RsqBar(sPeriod, sInst);
avgtruerange(sPeriod, sInst, length);
[/code]

龙听 发表于 2024-11-18 10:43

使用说明参考:[url]http://www.qhlt.cn/thread-159054-1-1.html[/url]

页: [1]