一般二阶系统和带零点的二阶系统分析

matlab代码

% 信号处理

% 系统分析
close all;
clear all;


%二阶系统
% wn:无阻尼固有频率 rad/s
% zeta:阻尼系数

wn = 200;

zeta = 0.707;

num1=[wn^2];
num2 = [2*zeta*wn,wn^2];
den = [1,2*zeta*wn,wn^2];

sys1 = tf(num1,den);
%一般二阶系统

sys2 = tf(num2,den);
%带零点的二阶系统

rs1 = step(sys1);
rs2 = step(sys2);

dt = 0.001;
t = 0:dt:0.05;
si = ones(length(t),1);
rs3 = lsim(sys1,si,t,0);
rs4 = lsim(sys2,si,t,0);


figure
subplot(221)
plot(rs1,'--b');
hold on
plot(rs2,'-g');
legend('nor','zpn'); %normal, zero plus normal
title('step阶跃响应');

subplot(222)
plot(rs3,'--b');
hold on
plot(rs4,'-g');
legend('nor','zpn');
title('lsim阶跃响应')
tau = 2*zeta/wn;

x1 = tau*(rs3-[0;rs3(1:end-1)])/dt;
x2 = rs3;
xt = x1+x2;
% figure

subplot(223);
plot(rs4,'--b');
hold on
plot(xt,'-g');
legend('zpn','czpn');
title('组合角度对比')
subplot(224);
plot(rs3,'--b');
hold on
plot(x1,'g');
legend('nor','dnor');
title('微分结果')

figure

subplot(211)
[z,p] = tf2zp(num1,den);
zplane(z,p);
title('nor零极点图');

subplot(212)
[z,p] = tf2zp(num2,den);
zplane(z,p);
title('zpn零极点图');

%%
%计算幅频相频响应
w = logspace(-4,4,400);
% w = linspace(-2pi,2pi,512);
h1 = freqs(num1,den,w); %函数中的w对应单位rad/s
% h1 = freqz(num1,den);
h2 = freqs(num2,den,w);
figure

subplot(221)
% plot(abs(h1));
loglog(w,abs(h1));
title('nor amplitude response')
ylabel('amp');
xlabel('w');
grid on

subplot(223)
semilogx(w,angle(h1));
title('nor phase response')
ylabel('pha');
xlabel('w');
grid on

subplot(222)
% plot(abs(h2));
loglog(w,abs(h2));
title('zpn amplitude response')
ylabel('amp');
xlabel('w');
grid on

subplot(224)
% plot(angle(h2));
semilogx(w,angle(h2));
title('zpn phase response')
ylabel('pha');
xlabel('w');
grid on

dmag = abs(h2)./abs(h1);
figure
% subplot(211)
plot(w,dmag,'g');
xlabel('w');
ylabel('abs(h2)/abs(h1) = \tau w')
title('时域微分在频域效果--等价于线性加权,加权系数为w')

disp(['计算出来的\tau等于' num2str((dmag(end)-dmag(1))/(w(end)-w(1)))]);
disp(['实际的\tau值等于' num2str(2*zeta/wn)]);

% subplot(212)
% semilogx(w,dmag);

% 其实真的可以用bode图还绘制,比较方便
figure
bode(sys1);
hold on
bode(sys2);
legend('show');

% figure
% w = logspace(-1,4,100);
% [mag1,phase1,wout1] =bode(sys1,w);
% [mag2,phase2,wout2] =bode(sys2,w);
%
% dmag = mag2(1,1,:)-mag1(1,1,:);
% plot(w,dmag(1,1,:),'b');
% hold on
% dmagdb = 20*log10(dmag);
% plot(w,dmagdb,'g');

% you can convert the magnitude from absolute units to decibels using:
% magdb = 20*log10(mag)

% c2d

% figure
% pzmap(sys1);
% figure
% pzmap(sys2);

%%
%*******************************************************************
% tf默认的a,b里面的顺序和filter,zplane,impz里面的不同
% 连续域即s域一般是从高到底,离散域是从低到高,变量是z^(-1),因此写的a,b不同
% 连续域的冲激响应用impulse,离散域用impz
% step,dstep
% 连续域的响应可以用lsim,离散域用dlsim,
% freqs,freqz

%%
%************************************************************

%二阶系统时域分析的单位阶跃、单位脉冲、单位斜坡响应
% syms s zeta
% zeta = 0.707; num = [16]; den =[1 8zeta 16];
% p = roots(den);
% sys = tf(num,den);
% t=0:0.01:3;
% figure(1)
% impulse(sys,t);grid
% xlabel('t');ylabel('c(t)');title('impulse response');
% figure(2)
% step(sys,t);grid
% xlabel('t');ylabel('c(t)');title('step response');
% figure(3)
% u=t;
% lsim(sys,u,t,0);grid
% xlabel('t');ylabel('c(t)');title('ramp response');
%
% % 一阶系统时域分析
% syms s t
% num = [1];den=[5,1];
% sys = tf(num,den);
% C = ilaplace((1/(5
s+1))(1/s),s,t)
%
%
% % feedback
% %
% % dcgain()
%
% %conv函数用来求解多项式的乘积
% %例如(s+1)
(s^2+3s+1)
% % 利用conv([1 1][1 3 1])
% % 可得为[1 4 4 1],即s3+4s2+4s+1
%
% % lsim
%
% % initial(sys,x0)
% % sys = ss(A,B,C,D)
%
% % spline
% % zpk(z,p,k)
%

% freqz
% impz(b,a) %计算单位脉冲响应
% impz(b,a,n)
% filter(b,a,x);
% filtic
% zplane
% pzmap(sys)
% grpdelay

1.jpg
2.jpg
3.jpg
4.jpg

5.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,347评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,435评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,509评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,611评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,837评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,987评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,730评论 0 267
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,194评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,525评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,664评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,334评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,944评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,764评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,997评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,389评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,554评论 2 349

推荐阅读更多精彩内容

  • ——作者 舞动人生 下雨 风雨无阻 我一路高歌 小朋友一路奔跑 一路大笑 小朋友 10公里想停 我们坚定走 小朋友...
    创造全新幸福生活阅读 172评论 0 0
  • 今天正好是写日记100天了,100天算是一个小整数吧,一个人照顾两个调皮大魔王,没想到自己能坚持下来,应了...
    邓启旭邓君浩妈妈阅读 203评论 0 2
  • 早上出门的时候看到楼道里多出了这个牌匾,突然觉得很温馨。 是啊,即使有一千个想哭的理由,也要学会微笑。 一路顺风。
    走走看看想想写写阅读 193评论 0 0