当前位置:   article > 正文

灰色方程预测模型MATLAB代码_matlap求紧临均值代码

matlap求紧临均值代码

关联篇:Excle中 GM(1,1) 灰色方程模型预测人口

  1. clc;clear;
  2. %建立符号变量a(发展系数)和b(灰作用量)
  3. syms a b;
  4. c = [a b]';
  5. A=[22542,22978,24223,25278,26261,26894,27395,27747,28171,28652,28836,29077,28560];
  6. %级比检验
  7. n = length(A);
  8. min=exp(-2/(n+1));
  9. max=exp(2/(n+1));
  10. for i=2:n
  11. ans(i)=A(i-1)/A(i);
  12. end
  13. ans(1)=[];
  14. for i=1:(n-1)
  15. if ans(i)<max&ans(i)>min
  16. else
  17. fprintf('第%d个级比不在标准区间内',i)
  18. disp(' ');
  19. end
  20. end
  21. %对原始数列 A 做累加得到数列 B
  22. B = cumsum(A);
  23. %对数列 B 做紧邻均值生成
  24. for i = 2:n
  25. C(i) = (B(i) + B(i - 1))/2;
  26. end
  27. C(1) = [];
  28. %构造数据矩阵
  29. B = [-C;ones(1,n-1)];
  30. Y = A; Y(1) = []; Y = Y';
  31. %使用最小二乘法计算参数 a(发展系数)和b(灰作用量)
  32. c = inv(B*B')*B*Y;
  33. c = c';
  34. a = c(1);
  35. b = c(2);
  36. %预测后续数据
  37. F = []; F(1) = A(1);
  38. for i = 2:(n+16)
  39. F(i) = (A(1)-b/a)/exp(a*(i-1))+ b/a;
  40. end
  41. %对数列 F 累减还原,得到预测出的数据
  42. G = []; G(1) = A(1);
  43. for i = 2:(n+16)
  44. G(i) = F(i) - F(i-1); %得到预测出来的数据
  45. end
  46. %模型检验
  47. H = G(1:n);
  48. %计算残差序列
  49. epsilon = A - H;
  50. %法一:相对残差Q检验
  51. %计算相对误差序列
  52. delta = abs(epsilon./A);
  53. %计算相对误差平均值Q
  54. disp('相对残差Q检验:')
  55. Q = mean(delta)
  56. %法二:方差比C检验
  57. disp('方差比C检验:')
  58. C = std(epsilon, 1)/std(A, 1)
  59. %法三:小误差概率P检验
  60. S1 = std(A, 1);
  61. tmp = find(abs(epsilon - mean(epsilon))< 0.6745 * S1);
  62. disp('小误差概率P检验:')
  63. P = length(tmp)/n

不要问我,不会调参,问就是二两醋 

图片

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/70099
推荐阅读
相关标签
  

闽ICP备14008679号