nyquist(G,w) (54) 该命令将画出下列开环系统传递函数的奈氏曲线: G(s)?num(s)
den(s)如果用户给出频率向量w,则w包含了要分析的以弧度/秒表示的诸频率点。在这些频率点上,将对系统的频率响应进行计算,若没有指定的w向量,则该函数自动选择频率向量进行计算。
对于式43和45用户不必给定频率向量,系统会自动选择频率向量进行计算。式44和46需要用户给出率向量w。w包含了用户要分析的以弧度/秒表示的诸频率点,MATLAB会自动计算这些点的频率响应。
当命令中包含了左端的返回变量时,即:
[re,im,w]=nyquist(G) (55) 或
[re,im,w]=nyquist(G,w) (56) 函数运行后不在屏幕上产生图形,而是将计算结果返回到矩阵re、im和w中。矩阵re和im分别表示频率响应的实部和虚部,它们都是由向量w中指定的频率点计算得到的。
在运行结果中,w数列的每一个值分别对应re、im数列的每一个值。 例20 考虑二阶典型环节: G(s)?1
s2?0.8s?1试利用MATLAB画出奈氏图。
利用下面的命令,可以得出系统的奈氏图,如图19所示。 >> num=[0,0,1];
den=[1,0.8,1]; nyquist(num,den) % 设置坐标显示范围 v=[-2,2,-2,2]; axis(v) grid
- 26 -
title(′Nyquist Plot of G(s)=1/(s^2+0.8s+1) ′)
图19 二阶环节奈氏图
(3)用MATLAB作伯德图
控制系统工具箱里提供的bode()函数可以直接求取、绘制给定线性系统的伯德图。 当命令不包含左端返回变量时,函数运行后会在屏幕上直接画出伯德图。如果命令表达式的左端含有返回变量,bode()函数计算出的幅值和相角将返回到相应的矩阵中,这时屏幕上不显示频率响应图。命令的调用格式为:
[mag,phase,w]=bode(num,den) (57) [mag,phase,w]=bode(num,den,w) (58) 或
[mag,phase,w]=bode(G) (59) [mag,phase,w]=bode(G,w) (60) 矩阵mag、phase包含系统频率响应的幅值和相角,这些幅值和相角是在用户指定的频率点上计算得到的。用户如果不指定频率w,MATLAB会自动产生w向量,并根据w向量上各点计算幅值和相角。这时的相角是以度来表示的,幅值为增益值,在画伯德图时要转换成分贝值,因为分贝是作幅频图时常用单位。可以由以下命令把幅值转变成分贝:
magdb=20﹡log10(mag) (61)
绘图时的横坐标是以对数分度的。为了指定频率的范围,可采用以下命令格式: logspace(d1,d2) (62) 或
logspace(d1,d2,n) (63)
公式(62)是在指定频率范围内按对数距离分成50等分的,即在两个十进制数?1?10和
2d1?2?10d之间产生一个由50个点组成的分量,向量中的点数50是一个默认值。例如
要在?1?0.1弧度/秒与?2?100弧度/秒之间的频区画伯德图,则输入命令时,
- 27 -
返回到工作d1?log10(?1),d2?log10(?2)在此频区自动按对数距离等分成50个频率点,空间中,即
w=logspace(-1,2)
要对计算点数进行人工设定,则采用公式(63)。例如,要在?1?1与?2?1000之间产生100个对数等分点,可输入以下命令:
w=logspace(0,3,100)
在画伯德图时,利用以上各式产生的频率向量w,可以很方便地画出希望频率的伯德图。
由于伯德图是半对数坐标图且幅频图和相频图要同时在一个绘图窗口中绘制,因此,要用到半对数坐标绘图函数和子图命令。
(1) 对数坐标绘图函数
利用工作空间中的向量x,y绘图,要调用plot函数,若要绘制对数或半对数坐标图,只需要用相应函数名取代plot即可,其余参数应用与plot完全一致。命令公式有:
semilogx(x,y,s) (64)
上式表示只对x轴进行对数变换,y轴仍为线性坐标。
semilogy(x,y,s) (65)
上式是y轴取对数变换的半对数坐标图。
Loglog(x,y,s) (66)
上式是全对数坐标图,即x轴和y 轴均取对数变换。 (2) 子图命令
MATLAB允许将一个图形窗口分成多个子窗口,分别显示多个图形,这就要用到subplot()函数,其调用格式为:
subplot(m,n,k)
该函数将把一个图形窗口分割成m×n个子绘图区域,m为行数,n为列数,用户可以通过参数k调用各子绘图区域进行操作,子图区域编号为按行从左至右编号。对一个子图进行的图形设置不会影响到其它子图,而且允许各子图具有不同的坐标系。例如,subplot(4,3,6)则表示将窗口分割成4×3个部分。在第6部分上绘制图形。 MATLAB最多允许9×9的分割。
例21 给定单位负反馈系统的开环传递函数为:
G(s)?10(s?1)
s(s?7)试画出伯德图。
利用以下MATLAB程序,可以直接在屏幕上绘出伯德图如图20。 >> num=10*[1,1]; den=[1,7,0]; bode(num,den) grid
title(′Bode Diagram of G(s)=10*(s+1)/[s(s+7)] ′) 该程序绘图时的频率范围是自动确定的,从0.01弧度/秒到30弧度/秒,且幅值取分贝值,?轴取对数,图形分成2个子图,均是自动完成的。
- 28 -
图20 自动产生频率点画出的伯德图
如果希望显示的频率范围窄一点,则程序修改为: >> num=10*[1,1]; den=[1,7,0];
w=logspace(-1,2,50); % 从0.1至100,取50个点。 [mag, phase, w]=bode(num, den, w);
magdB=20*log10(mag) % 增益值转化为分贝值。
% 第一个图画伯德图幅频部分。 subplot(2,1,1);
semilogx(w,magdB, ′-r′) % 用红线画 grid
title(′Bode Diagram of G(s)= 10*(s+1)/[s(s+7)] ′) xlabel(1Frequency(rad/s)1) ylabel(1Gain(dB)1)
% 第二个图画伯德图相频部分。 subplot(2,1,2);
semilogx(w,phase, 1-r1); grid
xlabel(1Frequency(rad/s)1) ylabel(′Phase(deg) ′)
- 29 -
修改程序后画出的伯德图如21所示。
图21 用户指定的频率点画出的伯德图
4. 用MATLEB求取稳定裕量
同前面介绍的求时域响应性能指标类似,由MATLAB里bode()函数绘制的伯德图也可以采用游动鼠标法求取系统的幅值裕量和相位裕量。例如,我们可以在图20的幅频曲线上按住鼠标左键游动鼠标,找出纵坐标(Magnitude)趋近于零的点,从提示框图中读出其频率约为7.25dB。然后在相频曲线上用同样的方法找到横坐标(Frequence)最接近7.25dB的点,可读出其相角为-53.9度,由此可得,此系统的相角裕量为126.1度。幅值裕量的计算
方法与此类似。
此外,控制系统工具箱中提供了margin()函数来求取给定线性系统幅值裕量和相位裕量,该函数可以由下面格式来调用:
[Gm, Pm, Wcg, Wcp]=margin(G); (67)
可以看出,幅值裕量与相位裕量可以由LTI对象G求出,返回的变量对(Gm, Wcg)为幅值裕量的值与相应的相角穿越频率,而(Pm, Wcp)则为相位裕量的值与相应的幅值穿越频率。若得出的裕量为无穷大,则其值为Inf,这时相应的频率值为NaN(表示非数值),Inf和NaN均为MATLAB软件保留的常数。
如果已知系统的频率响应数据,我们还可以由下面的格式调用此函数。
[Gm, Pm, Wcg, Wcp]=margin(mag, phase, w);
其中(mag, phase, w)分别为频率响应的幅值、相位与频率向量。
例22 已知三阶系统开环传递函数为:
G(s)?7 322(s?2s?3s?2)利用下面的MATLAB程序,画出系统的奈氏图,求出相应的幅值裕量和相位裕量,并求出闭环单位阶跃响应曲线。
- 30 -