C++程序化/量化学习视频教程系列 第035节:鼎元C++量化指标封装之“返回指标平均数组形式(Vector,EMA)”【指数移动平均线(EMA)的数组形式均线计算方法及调用方法】【C++量化指标公式开发系列】
C++程序化/量化学习视频教程系列 第035节:鼎元C++量化指标封装之“返回指标平均数组形式(Vector,EMA)”【指数移动平均线(EMA)的数组形式均线计算方法及调用方法】【C++量化指标公式开发系列】[mp4]http://mp4.qhlt.club/Cpp-Video/035.mp4[/mp4]
C++程序化学习视频教程系列安排如下:
第一楼:教学视频。一般控制在15分钟左右;
第二椄:视频课程中使用的程式源码。
第三楼:视频教学中需要用到的一些文档或资源。
第四楼:其它的一些边角料,特别是一些经典程序化策略的回测类的部分会放到下面楼层里面。
参与模式如下:
1、希望参与到编写策略与调试方面的工作通过上面的联系方式联系管理员咨询即可。记的加群,有问题第一时间交流,也可以在论坛指定版发贴交流,专用版地址:[url=http://www.qhlt.cn/forum-244-1.html]http://www.qhlt.cn/forum-244-1.html[/url];
2、有意申请试用及绑定期货账户跑实盘网友可以联系管理员,以及开通的方式。
3、基于C++策略交易软件具有:1、软件小(50兆不到);2、效率高(C++语言);3、功能精(专注于策略);4、对服务噐或电脑兼容性好(WIN系统)等优势,特别适合长期跑程序化的客户朋友,特别是有稳定交易模式客户更适合使用C++构建的交易系统。
4、最全的C++期货程序化(量化)教程、视频、源码、课件、资源汇总贴【C++期货程序化/量化研究必备资源贴!】:[url=http://www.qhlt.cn/thread-160231-1-1.html]http://www.qhlt.cn/thread-160231-1-1.html[/url];
5、鼎元C++量化程式码技术指标源码C++版模板【建议在test.h和test.cpp中同步至最新,方便统一调用和使用,一次编辑多次使用!】:[url=http://www.qhlt.cn/thread-160230-1-1.html]http://www.qhlt.cn/thread-160230-1-1.html[/url];
6、如何使用鼎元C++量化软件以及需要准备的些什么?[C++量化入门必读!]:[url=http://www.qhlt.cn/thread-160415-1-1.html]http://www.qhlt.cn/thread-160415-1-1.html[/url];
联系方式:
C++微信群:[img=180,180]http://p.algo2.net/2024/0922/23852f86ccf81.png[/img] QQ群:[img=140,180]http://p.algo2.net/2024/0115/3c6af4df957c3.jpg[/img] 管理员微信:[img]http://www.qhlt.cn/link/wx.png[/img];管理员QQ:[img]http://www.qhlt.cn/link/q.png[/img] 一、头文件声明数组[code]
vector<double>ema(vector<double> pc, int num); //ema计算公式(返回数组);
[/code]二、源文件公式源码区编写ema核心计算公式[code]
//ema1计算公式开始(返回数组)
/*
从map<string,mapK>制式数据中分离需要处理的数据,然后通过这此的ema方式取得这些数据的ema平均,返回值仍然是数组vector
*/
vector<double> test::ema(vector<double> pc, int num)
{
vector<double> ema;
double emavector = 0;
int i = 0;
for (int it = 0; it < pc.size(); ++it)
{
if (i < num)
{
emavector = (emavector + pc[it]) / (i + 1);
i++;
ema.push_back(emavector);
}
else
{
emavector = (2 * pc[it] + (num - 1) * emavector) / (num + 1);
ema.push_back(emavector);
}
}
return ema;
}
[/code]三、源文件中建立数组数据[code]
RsqBar(sPeriod, sInst);
map<string, TKVALUE >::iterator it;
for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); ++it)
{
pc.push_back(it->second.dClose);
}
[/code]四、如何使用:[code]
emashort = ema(pc, 12);
emalong = ema(pc, 26);
InsertLog("ema1均线值为: " + to_string(emashort[emashort.size()-1]));
InsertLog( "dea均线值为: " + to_string(emalong[emalong.size()-1]));
[/code] 使用说明:[url]http://www.qhlt.cn/thread-161126-1-1.html[/url]
页:
[1]