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

Stochastic指标(KDJ)指标c++语言写法

Stochastic指标(KDJ)指标c++语言写法

下面是一个简单的C++实现 kdj 函数的示例。KDJ 指标是基于随机指标(Stochastic)的一种扩展,通常用于技术分析。它由 K、D 和 J 三个值组成。以下是一个基础实现:
本帖隐藏的内容需要回复才可以浏览

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

另一个版本计算方式:
  1. #include <iostream>
  2. #include <vector>
  3. #include <algorithm> // For std::min_element and std::max_element

  4. using namespace std;

  5. // 计算最低价和最高价的范围
  6. void calculateHighLow(const vector<double>& highs, const vector<double>& lows, int period, vector<double>& highest, vector<double>& lowest) {
  7.     for (size_t i = 0; i < highs.size(); ++i) {
  8.         if (i < period - 1) {
  9.             highest.push_back(0);
  10.             lowest.push_back(0);
  11.         } else {
  12.             double maxHigh = *max_element(highs.begin() + i - period + 1, highs.begin() + i + 1);
  13.             double minLow = *min_element(lows.begin() + i - period + 1, lows.begin() + i + 1);
  14.             highest.push_back(maxHigh);
  15.             lowest.push_back(minLow);
  16.         }
  17.     }
  18. }

  19. // 计算 KDJ 指标
  20. void calculateKDJ(const vector<double>& closes, const vector<double>& highs, const vector<double>& lows, int period, double smoothingFactor) {
  21.     vector<double> highest, lowest, rsv, kValues, dValues, jValues;

  22.     // 计算最高价和最低价
  23.     calculateHighLow(highs, lows, period, highest, lowest);

  24.     // 计算 RSV
  25.     for (size_t i = 0; i < closes.size(); ++i) {
  26.         if (i < period - 1) {
  27.             rsv.push_back(0);
  28.         } else {
  29.             double range = highest[i] - lowest[i];
  30.             rsv.push_back(range == 0 ? 0 : (closes[i] - lowest[i]) / range * 100);
  31.         }
  32.     }

  33.     // 初始化 K 和 D 值
  34.     kValues.push_back(50); // 通常初始值设置为 50
  35.     dValues.push_back(50);

  36.     // 迭代计算 K 和 D 值
  37.     for (size_t i = 1; i < rsv.size(); ++i) {
  38.         double k = smoothingFactor * rsv[i] + (1 - smoothingFactor) * kValues.back();
  39.         double d = smoothingFactor * k + (1 - smoothingFactor) * dValues.back();
  40.         kValues.push_back(k);
  41.         dValues.push_back(d);
  42.     }

  43.     // 计算 J 值
  44.     for (size_t i = 0; i < kValues.size(); ++i) {
  45.         double j = 3 * kValues[i] - 2 * dValues[i];
  46.         jValues.push_back(j);
  47.     }

  48.     // 输出结果
  49.     cout << "Index\tClose\tK\tD\tJ" << endl;
  50.     for (size_t i = 0; i < closes.size(); ++i) {
  51.         cout << i << "\t" << closes[i] << "\t" << kValues[i] << "\t" << dValues[i] << "\t" << jValues[i] << endl;
  52.     }
  53. }

  54. int main() {
  55.     // 示例数据
  56.     vector<double> closes = {1.0, 1.1, 1.2, 1.1, 1.0, 1.3, 1.4, 1.5, 1.6, 1.7};
  57.     vector<double> highs = {1.1, 1.2, 1.3, 1.2, 1.1, 1.4, 1.5, 1.6, 1.7, 1.8};
  58.     vector<double> lows = {0.9, 1.0, 1.1, 1.0, 0.9, 1.2, 1.3, 1.4, 1.5, 1.6};

  59.     // 参数
  60.     int period = 9;            // 计算周期
  61.     double smoothingFactor = 1.0 / 3.0; // 平滑系数 (通常为 1/3)

  62.     // 计算 KDJ
  63.     calculateKDJ(closes, highs, lows, period, smoothingFactor);

  64.     return 0;
  65. }
复制代码
代码说明

    calculateHighLow 函数:
        用于计算每个点在周期内的最高价和最低价。

    calculateKDJ 函数:
        按公式计算 RSV、K、D 和 J 值。
        平滑因子默认使用 1/3。

    数据说明:
        closes 是收盘价序列。
        highs 和 lows 分别是最高价和最低价序列。

    输出结果:
        每一行输出对应的收盘价、K 值、D 值和 J 值。

注意事项

    数据量较小时(如不足一个周期),KDJ 值可能无法有效计算。
    smoothingFactor 可根据需求调整平滑程度(通常为 1/3 或 1/2)。

你可以根据实际需求修改输入数据和参数配置以适应不同场景。
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表