The problem is that i am getting negative values of kp and ki, how i can get value in specific range?

9 vues (au cours des 30 derniers jours)
function F = tracklsq(pid)
syms x;
limit_1 = 0;
limit_2 = 10;
Area = int(x,limit_1, limit_2);
Kp = pid(1);
Ki = pid(2);
z=Kp*0.1+Ki*0.1*Area; %objective function
sys_overshoot=z-1; % compute the overshoot
alpha=10;beta=10;
F=0.1*2*beta+sys_overshoot*alpha;
end
PSO code is attached

Réponses (1)

Walter Roberson
Walter Roberson le 10 Juil 2017
Your pso code has
current_position = 10*(rand(dim, n)-.5);
rand() is going to be in the range 0 to 1, so rand() - 0.5 is going to be in the range -0.5 to +0.5; 10 times that would be -5 to +5 .
If you do not want negative inputs, then do not subtract .5 in this statement.
  8 commentaires
Walter Roberson
Walter Roberson le 12 Juil 2017
? How do you get from those minimizations in the paper to your u expression ??
zain yousaf
zain yousaf le 12 Juil 2017
i am choosing some random values of error, in the case of I-Iref, i set that equal to 0.1,and interms of integration, i am setting some limits and using integrating function to integrate t, in my code area=t. i hope u get my point. in this paper there is no transfer function, so i am not sure that should i use transfer function or not.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Get Started with Optimization Toolbox dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by