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

鼎元C++量化程式码指标与函数模块系列之【KDJ指标计算方法及调用方法】返回数组形式

鼎元C++量化程式码指标与函数模块系列之【KDJ指标计算方法及调用方法】返回数组形式

1、源文件主程式模块源码
  1.         //主程序区计算KDJ
  2.         vector<double>highs, lows, highesthigh, lowestlow; //声明四个变量容器,分别存储当根bar的最高价、最低价及period周期的最高价和最低价
  3.         int period = 9;//声明整数变量KDJ的周期9
  4.         vector<double>RSV;//声明未成熟随机值
  5.         vector<double> K, D, J;//声明KDJ的三个容器变量
  6.         RsqBar(sPeriod, sInst);//调用数据
  7.     //将bar数据的收盘价close,最高价,最低价分别存入pc,highs,lows三个容器变量
  8.         map<string, TKVALUE >::iterator it;
  9.         for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); ++it)
  10.         {
  11.                 highs.push_back(it->second.dHigh);//将每日的high存入highs容器
  12.                 lows.push_back(it->second.dLow);//将每日的low存入lows容器
  13.                 highesthigh.push_back(highestseries(highs, period));//将上方的highs,lows容器变量的period周期最高,低值存入highesthigh和lowestlow两个容器变量
  14.                 lowestlow.push_back(lowestseries(lows, period));
  15.                 RSV.push_back(100 * (it->second.dClose - lowestseries(lows, period)) / (highestseries(highs, period) - lowestseries(lows, period)));//计算RSV公式
  16.         }
  17.         K = smaseries(RSV,3,1);
  18.         D = smaseries(K,3,1);
  19.         for (size_t i = 0; i < K.size(); i++)
  20.         {
  21.                 J.push_back(3*K[i] - 2*D[i]);//计算J值
  22.         }

  23. 调用方法:

  24. [code]
  25.         //输出KDJ的三个变量数值至日志面板
  26.         InsertLog("最新Kvalue " + to_string(K[K.size() - 1]) + "最新Dvalue " + to_string(D[D.size() - 1]) + "最新Jvalue " + to_string(J[J.size() - 1]));
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   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

新增一字板时的RSV分母为零时的尴尬:
  1.         //主程序区计算KDJ
  2.         vector<double>highs, lows, highesthigh, lowestlow; //声明四个变量容器,分别存储当根bar的最高价、最低价及period周期的最高价和最低价
  3.         int period = 9;//声明整数变量KDJ的周期9
  4.         vector<double>RSV;//声明未成熟随机值
  5.         vector<double> K, D, J;//声明KDJ的三个容器变量
  6.         RsqBar(sPeriod, sInst);//调用数据
  7.     //将bar数据的收盘价close,最高价,最低价分别存入pc,highs,lows三个容器变量
  8.         map<string, TKVALUE >::iterator it;
  9.         for (it = mapK[sPeriod][sInst].begin(); it != mapK[sPeriod][sInst].end(); ++it)
  10.         {
  11.                 highs.push_back(it->second.dHigh);//将每日的high存入highs容器
  12.                 lows.push_back(it->second.dLow);//将每日的low存入lows容器
  13.                 highesthigh.push_back(highestseries(highs, period));//将上方的highs,lows容器变量的period周期最高,低值存入highesthigh和lowestlow两个容器变量
  14.                 lowestlow.push_back(lowestseries(lows, period));
  15.                 if (highestseries(highs, period) - lowestseries(lows, period) == 0)
  16.                    {
  17.                         RSV.push_back(int(50));
  18.                    }
  19.                    else
  20.                    {
  21.                         RSV.push_back(100 * (it->second.dClose - lowestseries(lows, period)) / (highestseries(highs, period) - lowestseries(lows, period)));//计算RSV公式
  22.                     }
  23.         }
  24.         K = smaseries(RSV,3,1);
  25.         D = smaseries(K,3,1);
  26.         for (size_t i = 0; i < K.size(); i++)
  27.         {
  28.                 J.push_back(3*K[i] - 2*D[i]);//计算J值
  29.         }
  30.         //输出KDJ的三个变量数值至日志面板
  31.         InsertLog("最新Kvalue " + to_string(K[K.size() - 1]) + "最新Dvalue " + to_string(D[D.size() - 1]) + "最新Jvalue " + to_string(J[J.size() - 1]));
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表