Particle Swarm Optimization info

6 次查看(过去 30 天)
I am trying to find the values of 19 free variables from my data, using the psw optimization algorithm. I got interest in seeing the evolution of the 19 variables together with the minimization of the objective function, over the iterations. I then want to compare this againnst the genetic algorithm.
with the genetic algorithm I am able to to so, and get information (see code below), but with the psw I am no cabable of doing it. With the ga, I call this function from gaoptimset('PlotFcns',{@gaplotbestf, @gapop_func},...
Can you help me with this? Thank you a lot
function [state,options,optchanged] = gapop_func(options,state,flag)
persistent best r history_min history_max %h1
optchanged = false;
switch flag
case 'init'
best = state.Population;
assignin('base','gapopbestx',best);
case 'iter'
ibest = state.Best(end);
ibest = find(state.Score == ibest,1,'last');
bestx = state.Population(ibest,:);
best = [best; bestx];
assignin('base','gapop_max_best',history_max);
case 'done'
assignin('base','gapopbestx',best);
end

采纳的回答

Alan Weiss
Alan Weiss 2018-12-28
The syntaxes for output functions differ between ga and particleswarm. For an example of a particleswarm output function, see this example. For the correct way to set options for particleswarm, see the same example (you must use optimoptions to set options).
Alan Weiss
MATLAB mathematical toolbox documentation
  5 个评论
Marco Marchese
Marco Marchese 2019-1-7
Thank you for the suggestion. The issue is that my function is quite complex and the computational time is very extended, thus I do not see much difference between G.A., PSO, Patternsearch. I have a non-smooth, non-linear function with a set of unknown values that i need to fit from experimental data.
Marco Marchese
Marco Marchese 2019-1-28
Apparently both patternsearch and PSO work out fine.
Is there a way I can extract confidence intervals from here? I would want to avoid to pass through nlingit,lsqcurvefit or lsqnonlin.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Solver Outputs and Iterative Display 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by