基于matlab的控制系统仿真题,基于Matlab的控制系统仿真实例

该博客详细介绍了如何使用Matlab的ControlSystemToolbox进行控制系统仿真。首先,建立了弹簧阻尼器系统的传递函数和状态空间模型,接着展示了系统的冲激响应、阶跃响应及自定义输入响应的计算。然后,利用留数定理探讨了系统的特性,并进行了频域仿真,包括幅值曲线和相角曲线的绘制。最后,通过奈奎斯特图进一步分析了系统的稳定性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以弹簧自身质量不可忽略的阻尼器系统为例,通过Matlab的Control System Toolbox讲解控制系统的仿真,设弹簧控制系统的框图如下:

0818b9ca8b590ca3270a3433284dd417.png

取m=1,k=1,c=2。

1、建立传递函数:

m=1;k=1;c=2;

G1=tf(1,[1,0]);

H=tf(k,[m,c]);

ph=feedback(G1,H);

G2=tf(1,[m,c]);

syst=G2*ph;%传递函数

[A,B,C,D]=ssdata(syst);

syss=ss(A,B,C,D);%或syss=ss(syst) %状态空间表达式

syszp=zpk(syst);%零-极-增益模型

0818b9ca8b590ca3270a3433284dd417.png

2、系统响应

t=0:.2:15;

y=impulse(syss,t);%冲激响应

figure(1)

plot(t,y,'r'),grid

0818b9ca8b590ca3270a3433284dd417.png

y=step(syss,t);%阶跃响应

figure(2)

plot(t,y,'r'),grid

0818b9ca8b590ca3270a3433284dd417.png

t=0:0.01:5;%自定义输入响应

u=sin(t);

lsim(syss,u,t)

%系统对由u和t描述的自定义输入信号的响应。对MIMO系统,u是一个矩阵,第i行是输人信号在T(i)时刻的值

0818b9ca8b590ca3270a3433284dd417.png

3、留数定理

disp('Residue Form')

[num,den]=tfdata(syst);

num=num{1};den=den{1};%将元胞数组转化成向量

[r,p,k]=residue(num,den)

disp('hit any key to continue'),pause4、频域仿真

w=logspace(-2,2,100);%定义频率的对数区间

[re,im]=nyquist(syss,w);%state space形式,w可省略

re1=re(:);im1=im(:);

g=re1+i*im1;

mag=20*log10(abs(g));%幅值

phase=angle(g)*180/pi;%相角

semilogx(w,mag,'b') %%幅值曲线

0818b9ca8b590ca3270a3433284dd417.png

semilogx(w,phase,'b'),grid %相角曲线

0818b9ca8b590ca3270a3433284dd417.png

nyquist(systf),grid %绘制奈奎斯特图,或者用plot(re1,im1)

0818b9ca8b590ca3270a3433284dd417.png

暂时到这吧,日后有需要再更新。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值