串联滞后-超前校正及matlab代码实现

syms b_1;
K = 100; 
s = tf('s'); 
G0 = K/(s*(s/10+1)*(s/60+1)); % 原系统
gamma = 60; %期望相角裕度
% h = 10; %期望幅值裕度
wc = 10; % 期望截止频率,将该处设为校正点
lb = 0.1; 
ub = 1000; %3个10倍频程
[mag,phase,w]=bode(G0);
gamma0_wc=180+spline(w,phase,wc);
phim = gamma - gamma0_wc + 6;  %设置校正装置最大相角
a = (1+sind(phim))/(1-sind(phim)); % 求解超前校正参数a
T=1/(wc*sqrt(a));
Gclead=tf([a*T,1],[T,1]);
Glead = Gclead*G0; % 超前校正后系统传函
[mag_c,phase_c,w_c]=bode(Glead);
mag_wm=20*log10(spline(w_c,mag_c,wc));% 超前校正后系统wc处幅值
solve(-20*log10(b_1)==mag_wm,b_1);% 利用校正点处20lgb的对称性求解b
b=double(ans); %利用double将原本ans为syms类型转化为数值型
T=1/(0.1*wc*b);
Gclag=tf([b*T,1],[T,1]);
Gc = Gclag*Gclead; % 滞后超前校正函数
G = Gc*G0; % 校正后系统
bode(G0,Gc,G,{lb,ub});
grid on

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想想叫啥名

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值