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

第十部分 数组高级运算函数(高等数学与统计)【参数数组为正序,返回数组也为正序,适合做中间变量计算用】

第十部分 数组高级运算函数(高等数学与统计)【参数数组为正序,返回数组也为正序,适合做中间变量计算用】

头文件声明变量:
  1.         //第十部分 数组高级运算函数(高等数学与统计)
  2.         vector<double>SeriesSine(vector<double> pc); //数组元素进行正弦转化
  3.         vector<double>SeriesPearsoncorrelationcoefficient(vector<double> pc1, vector<double>pc2, int num); //皮尔逊相关系数计算公式
复制代码

论坛官方微信、群(期货热点、量化探讨、开户与绑定实盘)
 
期货论坛 - 版权/免责声明   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. //第十部分 数组高级运算函数(高等数学与统计)【参数数组为正序,返回数组也为正序】
  2. //皮尔逊相关系数计算公式【参数数组为正序,返回数组也为正序】
  3. vector<double> test::SeriesPearsoncorrelationcoefficient(vector<double> pc1, vector<double> pc2, int num)
  4. {
  5.         //皮尔逊相关系数(Pearson correlation coefficient)设计
  6.         //声明两个vector变量存入X,Y两组数据
  7.         vector<double>X, Y;//两个容器变量存入相对应数据元素
  8.         vector<double>avgX, avgY;//X,Y的平均值
  9.         vector<double>covXY;//X,Y的协方差(covariance)
  10.         vector<double>stdX, stdY;//X,Y标准差
  11.         vector<double>Rxy;//相关系数

  12.         //采集X数据元素
  13.         X = pc1;

  14.         //采集Y数据元素(Y与X数据不同品种合约,但是相同周期)
  15.         Y = pc2;

  16.         //求length周期X,Y的平均值
  17.         avgX = SeriesAverage(X, num);//调用数组计算公式计算
  18.         avgY = SeriesAverage(Y, num);//计算Y在length周期的平均数

  19.         vector<double>x_avgx, y_avgy, covxy;
  20.         x_avgx = SeriesMinus(X, avgX);//计算X[i] - avgX[i]
  21.         y_avgy = SeriesMinus(Y, avgY);//计算Y[i] - avgY[i]
  22.         covxy = SeriesTimes(x_avgx, y_avgy);//计算(x-avgx)*(y-avgy)
  23.         covXY = SeriesSummation(covxy, num);//sumcovxy

  24.         //计算X,Y各自的方差
  25.         vector<double>x_avgxpow, y_avgypow;
  26.         vector<double>sum_x_avgx, sum_y_avgy;
  27.         vector<double>std_x_avgx, std_y_avgy, std_xy;
  28.         x_avgxpow = SeriesPowerN(x_avgx, 2);//(X[i] - avgX)^2
  29.         y_avgypow = SeriesPowerN(y_avgy, 2);//(Y[i] - avgY)^2
  30.         sum_x_avgx = SeriesSummation(x_avgxpow, num);
  31.         sum_y_avgy = SeriesSummation(y_avgypow, num);
  32.         std_x_avgx = Seriessquareroot(sum_x_avgx);
  33.         std_y_avgy = Seriessquareroot(sum_y_avgy);
  34.         std_xy = SeriesTimes(std_x_avgx, std_y_avgy);
  35.         //计算相关性
  36.         Rxy = SeriesDivide(covXY, std_xy);//计算相关性
  37.         return Rxy;
  38. }
  39. //Vector正弦值数组计算【参数数组为正序,返回数组也为正序】
  40. vector<double> test::SeriesSine(vector<double> pc)
  41. {
  42.         vector<double>newvector;//声明新变量容器
  43.         for (size_t i = 0; i < pc.size(); i++)
  44.         {
  45.                 newvector.push_back(sin(pc[i]));//sin(x)
  46.         }
  47.         return newvector;
  48. }
  49. //第十部分 数组高级运算函数(高等数学与统计)【参数数组为正序,返回数组也为正序】
复制代码
如何访问权限为100/255贴子:/thread-37840-1-1.html;注册后仍无法回复:/thread-23-1-1.html;微信/QQ群:/thread-262-1-1.html;网盘链接失效解决办法:/thread-93307-1-1.html

TOP

返回列表