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

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

能成功计算出KDJ的程式 码
  1. #include <iostream>
  2. #include <vector>
  3. #include <deque> // 用于双端队列维护滑动窗口

  4. // 股票数据结构
  5. struct StockData {
  6.     double closePrice; // 收盘价
  7.     double highPrice;  // 最高价
  8.     double lowPrice;   // 最低价
  9. };

  10. // 计算 KDJ 指标
  11. void calculateKDJ(const std::vector<StockData>& stockData, int period,
  12.                   std::vector<double>& K, std::vector<double>& D, std::vector<double>& J) {
  13.     if (stockData.size() < period) {
  14.         std::cerr << "数据不足以计算 KDJ!" << std::endl;
  15.         return;
  16.     }

  17.     std::deque<int> highDeque; // 双端队列维护最高价索引
  18.     std::deque<int> lowDeque;  // 双端队列维护最低价索引

  19.     double k = 50.0, d = 50.0; // 初始 K 和 D 值

  20.     for (size_t i = 0; i < stockData.size(); ++i) {
  21.         // 移除滑动窗口外的元素
  22.         if (!highDeque.empty() && highDeque.front() < static_cast<int>(i) - period + 1) {
  23.             highDeque.pop_front();
  24.         }
  25.         if (!lowDeque.empty() && lowDeque.front() < static_cast<int>(i) - period + 1) {
  26.             lowDeque.pop_front();
  27.         }

  28.         // 更新双端队列中的最大值和最小值
  29.         while (!highDeque.empty() && stockData[highDeque.back()].highPrice <= stockData[i].highPrice) {
  30.             highDeque.pop_back();
  31.         }
  32.         highDeque.push_back(static_cast<int>(i));

  33.         while (!lowDeque.empty() && stockData[lowDeque.back()].lowPrice >= stockData[i].lowPrice) {
  34.             lowDeque.pop_back();
  35.         }
  36.         lowDeque.push_back(static_cast<int>(i));

  37.         // 计算 RSV
  38.         if (i >= period - 1) {
  39.             double highestHigh = stockData[highDeque.front()].highPrice;
  40.             double lowestLow = stockData[lowDeque.front()].lowPrice;
  41.             double rsv = 0.0;

  42.             if (highestHigh != lowestLow) {
  43.                 rsv = (stockData[i].closePrice - lowestLow) / (highestHigh - lowestLow) * 100.0;
  44.             }

  45.             // 更新 K 和 D
  46.             k = 2.0 / 3.0 * k + 1.0 / 3.0 * rsv;
  47.             d = 2.0 / 3.0 * d + 1.0 / 3.0 * k;

  48.             // 计算 J
  49.             double j = 3.0 * k - 2.0 * d;

  50.             // 保存结果
  51.             K.push_back(k);
  52.             D.push_back(d);
  53.             J.push_back(j);
  54.         } else {
  55.             // 数据不足时填充默认值
  56.             K.push_back(k);
  57.             D.push_back(d);
  58.             J.push_back(3.0 * k - 2.0 * d);
  59.         }
  60.     }
  61. }

  62. int main() {
  63.     // 示例股票数据
  64.     std::vector<StockData> stockData = {
  65.         {10, 15, 8}, {11, 16, 9}, {12, 17, 10}, {13, 18, 11},
  66.         {14, 19, 12}, {15, 20, 13}, {16, 21, 14}, {17, 22, 15},
  67.         {18, 23, 16}, {19, 24, 17}
  68.     };

  69.     int period = 5; // 计算周期
  70.     std::vector<double> K, D, J;

  71.     // 计算 KDJ
  72.     calculateKDJ(stockData, period, K, D, J);

  73.     // 输出结果
  74.     std::cout << "K值: ";
  75.     for (const auto& k : K) std::cout << k << " ";
  76.     std::cout << "\nD值: ";
  77.     for (const auto& d : D) std::cout << d << " ";
  78.     std::cout << "\nJ值: ";
  79.     for (const auto& j : J) std::cout << j << " ";
  80.     std::cout << std::endl;

  81.     return 0;
  82. }
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表