0


【预测模型】基于麻雀算法改进广义回归神经网络(GRNN)实现数据预测matlab代码

1 简介

为实现精准施肥"减施增效"的数字化农业施肥技术,本文基于并运用了麻雀搜索算法,对广义回归神经网络(GRNN)进行了结合与改进,并构建作物广义回归神经网络(GRNN)结合麻雀搜索算法的预测施肥量模型.通过采集得到的数据样本会被用来输入MATLAB进行仿真和实验验证.仿真和实验结果表明,基于麻雀搜索算法的GRNN神经网络模型比BP神经网络具有更少的输入参数,能更好地反映施肥量与诸多影响因素之间的关系,具有实用价值.且基于麻雀搜索算法改进的GRNN神经网络算法模型人为设定量更少,更为客观,预测值与实际值之间的误差更小,预测结果更加准确.

图片

图片

图片

图片

2 部分代码

  1. %_________________________________________________________________________%
  2. % 麻雀优化算法 %
  3. %_________________________________________________________________________%
  4. function [Best_pos,Best_score,curve]=SSA(pop,Max_iter,lb,ub,dim,fobj)
  5. ST = 0.6;%预警值
  6. PD = 0.7;%发现者的比列,剩下的是加入者
  7. SD = 0.1;%意识到有危险麻雀的比重
  8. PDNumber = round(pop*PD); %发现者数量
  9. SDNumber = round(pop*SD);%意识到有危险麻雀数量
  10. if(max(size(ub)) == 1)
  11. ub = ub.*ones(1,dim);
  12. lb = lb.*ones(1,dim);
  13. end
  14. %种群初始化
  15. X0=initialization(pop,dim,ub,lb);
  16. X = X0;
  17. %计算初始适应度值
  18. fitness = zeros(1,pop);
  19. for i = 1:pop
  20. fitness(i) = fobj(X(i,:));
  21. end
  22. [fitness, index]= sort(fitness);%排序
  23. BestF = fitness(1);
  24. WorstF = fitness(end);
  25. GBestF = fitness(1);%全局最优适应度值
  26. for i = 1:pop
  27. X(i,:) = X0(index(i),:);
  28. end
  29. curve=zeros(1,Max_iter);
  30. GBestX = X(1,:);%全局最优位置
  31. X_new = X;
  32. for i = 1: Max_iter
  33. BestF = fitness(1);
  34. WorstF = fitness(end);
  35. R2 = rand(1);
  36. for j = 1:PDNumber
  37. if(R2<ST)
  38. X_new(j,:) = X(j,:).*exp(-j/(rand(1)*Max_iter));
  39. else
  40. X_new(j,:) = X(j,:) + randn()*ones(1,dim);
  41. end
  42. end
  43. for j = PDNumber+1:pop
  44. % if(j>(pop/2))
  45. if(j>(pop - PDNumber)/2 + PDNumber)
  46. X_new(j,:)= randn().*exp((X(end,:) - X(j,:))/j^2);
  47. else
  48. %产生-11的随机数
  49. A = ones(1,dim);
  50. for a = 1:dim
  51. if(rand()>0.5)
  52. A(a) = -1;
  53. end
  54. end
  55. AA = A'*inv(A*A');
  56. X_new(j,:)= X(1,:) + abs(X(j,:) - X(1,:)).*AA';
  57. end
  58. end
  59. Temp = randperm(pop);
  60. SDchooseIndex = Temp(1:SDNumber);
  61. for j = 1:SDNumber
  62. if(fitness(SDchooseIndex(j))>BestF)
  63. X_new(SDchooseIndex(j),:) = X(1,:) + randn().*abs(X(SDchooseIndex(j),:) - X(1,:));
  64. elseif(fitness(SDchooseIndex(j))== BestF)
  65. K = 2*rand() -1;
  66. X_new(SDchooseIndex(j),:) = X(SDchooseIndex(j),:) + K.*(abs( X(SDchooseIndex(j),:) - X(end,:))./(fitness(SDchooseIndex(j)) - fitness(end) + 10^-8));
  67. end
  68. end
  69. %边界控制
  70. for j = 1:pop
  71. for a = 1: dim
  72. if(X_new(j,a)>ub(a))
  73. X_new(j,a) =ub(a);
  74. end
  75. if(X_new(j,a)<lb(a))
  76. X_new(j,a) =lb(a);
  77. end
  78. end
  79. end
  80. %更新位置
  81. for j=1:pop
  82. fitness_new(j) = fobj(X_new(j,:));
  83. end
  84. for j = 1:pop
  85. if(fitness_new(j) < GBestF)
  86. GBestF = fitness_new(j);
  87. GBestX = X_new(j,:);
  88. end
  89. end
  90. X = X_new;
  91. fitness = fitness_new;
  92. %排序更新
  93. [fitness, index]= sort(fitness);%排序
  94. BestF = fitness(1);
  95. WorstF = fitness(end);
  96. for j = 1:pop
  97. X(j,:) = X(index(j),:);
  98. end
  99. curve(i) = GBestF;
  100. end
  101. Best_pos =GBestX;
  102. Best_score = curve(end);
  103. end

3 仿真结果

4 参考文献

[1]倪贤达, 杨得航, 左桐,等. 基于遗传算法改进GRNN神经网络的施肥量预测研究[J]. 2020.

[2]印雷, 顾德, & 刘飞. (2021). 基于改进麻雀搜索算法优化的dv-hop定位算法. 传感技术学报, 34(5), 6.

部分理论引用网络文献,若有侵权联系博主删除。

图片


本文转载自: https://blog.csdn.net/qq_59747472/article/details/122159233
版权归原作者 Matlab科研工作室 所有, 如有侵权,请联系我们删除。

“【预测模型】基于麻雀算法改进广义回归神经网络(GRNN)实现数据预测matlab代码”的评论:

还没有评论