What do I do wrong when using the stepplot command?
6 ビュー (過去 30 日間)
古いコメントを表示
I have defined a first order system
and a PI controller
as follows:
data:image/s3,"s3://crabby-images/56327/56327b16474e1dacbdae3c22438b93e6825a541e" alt=""
data:image/s3,"s3://crabby-images/47863/4786373212cc722cd5ebb63c2a9a3bea826c5839" alt=""
data:image/s3,"s3://crabby-images/efdbc/efdbc8d8e391feb9ee967c7aa3771e6f4f8c1535" alt=""
data:image/s3,"s3://crabby-images/77e06/77e06bfd835f23c44ba7359358f49d591ac96c22" alt=""
In matlab code
tau = 0.1;
G_plant = tf(1,[tau 1]);
alpha = -0.1;
Gc = tf([1 alpha],[1 0]);
The controller should also have a gain value and I'm varying it from 0 to 10. My expectation is that, because of the PI-controller, the step response goes to 1 eventually for all gain values I choose. It does so, for gain values up to 8, but for a gain value of 9, I observe something strange. Could you help me explaining this phenomenon?
My code to draw the step responses for the PI-controlled system is
G_openloop = Gc*G_plant;
T = feedback(9*G_openloop,1)
stepplot(T);
Even if I compute the DC gain, it goes to 1, but the stepplot doesn't.
data:image/s3,"s3://crabby-images/9574a/9574a99c5243f04dd2eb518abb6d08422b06d7da" alt=""
data:image/s3,"s3://crabby-images/14617/1461792450dfb80ea46972457ea8a39f00110acf" alt=""
For the green line (K = 9) a strange bending of the curve occurs around time 2 seconds and the green line never goes to its steady state of 1.
0 件のコメント
採用された回答
Pratyush Roy
2022 年 1 月 11 日
Hi Nico,
Although it might seem like the step response for gain values do not approach the steady state value of 1, this might be because it reaches steady state at a later stage due to the value of K chosen. To observe that, we can change the tFinal input argument for the stepplot command final time for step response computation to be a very high value, say 100.
Here is a script that illustrates how to change the tFinal value:
tau = 0.1;
G_plant = tf(1,[tau 1]);
alpha = 0.2;
Gc = tf([1 alpha],[1 0]);
K = 5:0.4:9;
for i=1:length(K)
G_openloop = Gc*G_plant;
T = feedback(K(i)*G_openloop,1);
hold on
stepplot(T,100);
end
hold off
Hope this helps!
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Matrix Indexing についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!