Effacer les filtres
Effacer les filtres

Help With for loop with tranfer function and step

1 vue (au cours des 30 derniers jours)
Davide Cannavacciuolo
Davide Cannavacciuolo le 20 Nov 2023
Commenté : Sam Chak le 20 Nov 2023
s=tf('s');
G=1/(s^2+0.4*s+0.1);
K=[1 2 3 4 5 6];
figure
hold on
for i=1:1:length(K)
T=K(i)*G;
step(T)
S=stepinfo(T);
L=S.Peak(T)
end
I have this code but i get the error : "Unable to use a value of type tf as an index."
I want actually to make a vector containg all the values of the peak values and only then plot the peaks with the corresponding value of gain.
Thank you in advance

Réponse acceptée

Sam Chak
Sam Chak le 20 Nov 2023
You probably want to plot like this:
s = tf('s');
G = 1/(s^2 + 0.4*s + 0.1);
K = [1 2 3 4 5 6];
figure(1)
hold on
for i = 1:length(K)
T = K(i)*G;
step(T)
S = stepinfo(T);
L(i) = S.Peak;
end
grid on
hold off
figure(2)
plot(K, L, '-o'), grid on
xlabel('Gain'), ylabel('Peak')
  2 commentaires
Davide Cannavacciuolo
Davide Cannavacciuolo le 20 Nov 2023
Thank you so much!
Sam Chak
Sam Chak le 20 Nov 2023
Ciao @Davide Cannavacciuolo. You're welcome!

Connectez-vous pour commenter.

Plus de réponses (1)

Dyuman Joshi
Dyuman Joshi le 20 Nov 2023
Modifié(e) : Dyuman Joshi le 20 Nov 2023
There is no field in the struct 'S' with name 'T'. Thus you get the error in the line you defined 'S'.
I suspect that you want to get the 'Peak' value for each system -
s=tf('s');
G=1/(s^2+0.4*s+0.1);
K=[1 2 3 4 5 6];
%Preallocation
L = K.*0;
figure
hold on
for i=1:1:length(K)
T=K(i)*G;
step(T);
S=stepinfo(T);
L(i)=S.Peak;
end
L
L = 1×6
10.7689 21.5379 32.3068 43.0757 53.8447 64.6136

Catégories

En savoir plus sur Programming dans Help Center et File Exchange

Produits


Version

R2023b

Community Treasure Hunt

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

Start Hunting!

Translated by