C++程序化/量化学习视频教程系列 第029节:鼎元C++量化之封装第三个指标之“真实波动幅度均值(averagetruerange、avgtruerange、ATR)”指标(求N周期真实波动幅度均值avgtruerange(N),方便在策略中调用)及C++量化开发中的注意事项【C++量化指标公式开发系列】
- UID
- 2
- 积分
- 2892617
- 威望
- 1396340 布
- 龙e币
- 1496277 刀
- 在线时间
- 13326 小时
- 注册时间
- 2009-12-3
- 最后登录
- 2024-12-25
|
C++程序化/量化学习视频教程系列 第029节:鼎元C++量化之封装第三个指标之“真实波动幅度均值(averagetruerange、avgtruerange、ATR)”指标(求N周期真实波动幅度均值avgtruerange(N),方便在策略中调用)及C++量化开发中的注意事项【C++量化指标公式开发系列】
论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
|
|
|
|
|
|
- UID
- 2
- 积分
- 2892617
- 威望
- 1396340 布
- 龙e币
- 1496277 刀
- 在线时间
- 13326 小时
- 注册时间
- 2009-12-3
- 最后登录
- 2024-12-25
|
第一部分、头文件声明变量:- double avgtruerange(string period, string inst, int num);//计算avgtruerange值
复制代码 第二部分、源文件公式计算函数:- 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值了。
- }
复制代码 第三部分、调用方法:- RsqBar(sPeriod, sInst);
- avgtruerange(sPeriod, sInst, length);
复制代码 |
|
|
|
|
|
|