matlab延迟传函,[MATLAB使用练习] [教材:自动控制原理-裴润] 2.5 MATLAB用于处理系统数学模型...

MATLAB程序设计语言是一种高性能的数值计算软件。经过十几年的发展,MATLAB已经成为适合多学科,功能齐全的大型科学计算软件。目前MATLAB已经成为线性代数、自动控制理论、数理统计和数字信号处理分析、动态系统仿真等课程的基本数学工具。它的TOOLBOX工具箱与SIMUINK仿真工具,为控制系统的计算与仿真提供了一个强有力的工具,使控制系统的计算与仿真的传统方法发生了革命性的变化。MATLAB已经成为国际控制领域最流行的计算与仿真软件。

2.5.1 拉氏变换与拉氏反变换

求拉氏变换可用函数   laplace(ft,t,s)

例2.5.1 求

01b9492bfd9b6ab947079b21dd971052.png 的拉氏变换

解  0c59b1ab8ad4b8da46a02b9ee195bf13.png程序运行如下:

>> syms s t;

>> ft = t^2+2*t+2;

>> FS = laplace(ft,t,s)

FS =

(2*(s + 1))/s^2 + 2/s^3

其中 syms 是符号变量设置函数,其使用的格式为 syms arg1 arg2 ...;

求拉氏反变换可用函数 ilaplace(Fs,s,t)

例 2.5.2 求 2432a0860e0a347bf570a73e1c0e71c1.png 的拉式反变换

解  a968c58c6578fe6ea3945a095d070d98.png   程序运行如下:

>> syms s t

>> Fs = (s+6)/((s^2+4*s+3)*(s+2));

>> ft = ilaplace(Fs,s,t)

ft =

(5*exp(-t))/2 - 4*exp(-2*t) + (3*exp(-3*t))/2

2.5.2 多项式运算

在MATLAB中采用行向量表示多项式,行向量内的各元素是按降幂次排列的多项式系数。

多项式

0f5f74b10dbc4c270e087ba45eb3149d.png 的系数行向量为 

7eb6db69f6b7c81cbc945754c4a17e4b.png

求多项式的根可以用 roots(p)函数

例 2.5.3 求多项式

c00d377dc3192cb1def32b8ac9431735.png 的根

程序运行如下:

>> P = [1 2 3 4 5];

>> r = roots(P)

r =

-1.2878 + 0.8579i

-1.2878 - 0.8579i

0.2878 + 1.4161i

0.2878 - 1.4161i

由已知多项式的根求多项式可用函数 poly(r)

例2.5.4 已知多项式的根分别为 -1,-5,-8,试求对应的多项式

所求多项式为

2062d56ba07ebf31ec3bf506643a477c.png , 可进一步用 roots(p) 函数来验证结果,程序运行如下:

>> PL = poly([-1 -5 -8])

PL =

1 14 53 40

>> roots(PL)

ans =

-8.0000

-5.0000

-1.0000

2.5.3 微分方程求解

求解微分方程可采用指令 s=dslove('a_1','a_2', …,‘a_n’). 其中,输入变量包括三部分内容:微分方程、初始条件、指定的独立变量。其中微分方程必不可少,其余内容看情况给。默认的独立变量是 ‘t’ ,也可用别的变量代替 ‘t’,把它放在输入变量最后即可。字母 ‘D’ 代表微分算子,即

eb02341385afec42d69157cf4b3b2576.png ,字母‘D’ 后面的数字表示微分的阶次,如 D2 代表  

014940a9a39b29a970131c1e34754e25.png,微分算子后的字母代表被微分的变量,如 D3y 代表 y(t) 的三阶微分。初始条件可按如下形式给出:‘y(a) = b’ 或 'Dy(a) = b'. 若初始条件未给定,则结果含积分常数 C1.

例 2.5.5 解微分方程 37da89e7fe464f69e756b90754ba0aac.png   ,初始条件  

c5dd27f80f130d95c80291bae0ac0e77.png

解 程序运行如下:

>> y = dsolve('3*D2y + 3*Dy + 2*y = 1','y(0)=0','Dy(0)=0')

y =

1/2 - (15^(1/2)*exp(-t/2)*sin((15^(1/2)*t)/6))/10 - (exp(-t/2)*cos((15^(1/2)*t)/6))/2

2.5.4 传递函数及形式转换的建立

传递函数两种常用的表达形式是有理分式形式和零极点形式。

有理分式形式的一般表达式为

9e51c5d02708600d0cceb6c75f24ab49.png

零极点形式的一般表达式为

d2026a26b1bdec72135a70de83d20489.png    ,

8b149daad034068ff575216e56f2fbbb.png  传递函数的零点;

979bf55a2445e1a34e1992a61b48b79e.png   传递函数的极点;

k 零极点形式传递函数的系数。

建立有理分式形式的传递函数时,需先将传递函数分子、分母多项式的系数写成两个行向量,然后用tf()函数给出,格式为

3d55320de4c57533b843d9f636ce2db5.png

348539ac57803085a86a09b284fa8469.png

g = tf(num , den)

将传函从 有理形式 转换为 零极点形式,可用函数 zpk(g).

例 2.5.6 在MATLAB中表示多项式形式的传函 012866877e9a2553b946cc7cbc07dbb0.png  ,并将其转换为零极点形式

解 程序运行如下:

>> num =[1 3];

>> den = [1 0 2 1];

>> g = tf(num , den)

g =

s + 3

-------------

s^3 + 2 s + 1

Continuous-time transfer function.

>> zpk(g)

ans =

(s+3)

----------------------------------

(s+0.4534) (s^2 - 0.4534s + 2.206)

Continuous-time zero/pole/gain model.

若要建立零极点形式的传函可使用函数 zpk(),这时要结果传函的零点、极点 分别写成两个向量,给出传函的增益,格式为

1666e23feb7555e9ed82646c5ca29076.png

ffc18a6c773159caa98bbab0110cfdfc.png

k = 增益值

g = zpk(z,p,k)

若想将传函由  零极点形式 转换为 多项式形式,可用函数 tf(),格式为 tf(g)

例 2.5.7 在MATLAB中表示零极点形式的传函 7bc67c8153261aa55c600de76a1f19c3.png,并将其转换成 多项式形式的传函

解 程序运行如下:

>> z = [-2];

>> p = [0 -1 -3];

>> k = 10;

>> g = zpk(z,p,k)

g =

10 (s+2)

-------------

s (s+1) (s+3)

Continuous-time zero/pole/gain model.

>> tf(g)

ans =

10 s + 20

-----------------

s^3 + 4 s^2 + 3 s

Continuous-time transfer function.

注意:稳定系统的极点都有负实部。若有复数的零极点,则应有共轭的零极点同时输入。输入虚部时, j 或 i 是MATLAB中约定的虚数单位符号,应与系数用 “ * ” 相乘,若传函无零点,则用 z = [ ]输入空向量。

例 2.5.8 传函极点为

342200e122bc2d501050807c680cf2a7.png 没有零点,增益为100,试建立零极点形式及多项式形式的传函。

解 程序运行如下:

>> z =[];

>> p = [-5 -2+j*2 -2-j*2];

>> k=100;

>> g = zpk(z,p,k)

g =

100

--------------------

(s+5) (s^2 + 4s + 8)

Continuous-time zero/pole/gain model.

>> tf(g)

ans =

100

-----------------------

s^3 + 9 s^2 + 28 s + 40

Continuous-time transfer function.

传函有纯时间延迟环节

ec0899926521efeb67383203636ad7de.png,建立传函时 延迟时间赋给 变量dt,使用 tf() 函数时还要用 ‘inputdelay’说明。

例 2.5.9 已知系统传函为 356c87a7435f42ac95339d8a5d26a0ee.png ,在MATLAB中建立传函。

解  程序运行如下:

>> num = [1 1];

>> den = [1 4 2 6];

>> dt = 2;

>> g = tf(num,den,'inputdelay',dt)

g =

s + 1

exp(-2*s) * ---------------------

s^3 + 4 s^2 + 2 s + 6

Continuous-time transfer function.

>> zpk(g)

ans =

(s+1)

exp(-2*s) * ---------------------------------

(s+3.883) (s^2 + 0.1171s + 1.545)

Continuous-time zero/pole/gain model.

2.5.5 部分分式展开

控制系统中的传函是 s 有理分式

cffd5f58a7d0a246d49243f7c623381b.png      N(s),D(s) 为传函的分子(母)多项式。

MATLAB中分别用行向量 num , den 表示其系数,即:

63348e9d2db03d7df7b8b3fad2898382.png

310094ca9075c112bb9413077f70be67.png

命令     [r,p,k] = residue(num,den)  可求出传函 部分分式展开式 的留数、极点、余项

部分分式展开式 如下:

9dce63528b754e8a1c6737bd7a6e6a86.png,其中

9b6078879e58629e0502b9bc3e91e309.png 极点;

a97c8d4bb2702d2fc326edb20fba18f1.png 部分分式展开式的留数;

3d4389adf61808f9e09587dd5bea556a.png 余项。

例 2.5.10 系统传函 aeb237f18f43f32dc77a302d709e32b7.png , 试展开为部分分式。

解     a79402080bfb129607e74c87f1df3ce5.png    ,  程序运行如下:

>> num = [2 5 3 6];

>> den = [1 6 11 6];

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

r =

-6.0000

-4.0000

3.0000

p =

-3.0000

-2.0000

-1.0000

k =

2

例 2.5.11 系统传函为 40fb63907b766daa7f9a8ccfdb463ed8.png  , 将其展开成部分分式形式。

解 先将分母展开成降幂形式,  1b70d210f32089dfc0f69b4baeb8f8ea.png   , 程序运行如下:

>> num = [1 2 3];

>> den = [1 3 3 1];

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

r =

1.0000

0.0000

2.0000

p =

-1.0000

-1.0000

-1.0000

k =

[]

2.5.6 串联、并联、反馈结构的化简

1.串联结构的化简

series()函数

例 2.5.12两个环节5b2cf3c21a3b9a1ac1356cb1ae632c89.png  串联,求等效传函 G(s).

解 程序运行如下,函数 printsys(num,den) 用于打印传函

>> num1 = [1 1];

>> den1 = [1 2];

>> num2 = [10];

>> den2 = [1 0];

>> [num,den] = series(num1,den1,num2,den2)

num =

0 10 10

den =

1 2 0

>> printsys(num,den)

num/den =

10 s + 10

---------

s^2 + 2 s

2.并联结构的化简

Parallel()函数

例 2.5.13 两环节并联,其中 132877e8608bc83f1dd564e6d7da207b.png  求等效传函G(s)。

解 程序运行如下:

>> num1 = [1 2];

>> den1 = [0 1];

>> num2 = [0 5];

>> den2 = [1 0];

>> [num den] = parallel(num1,den1,num2,den2)

num =

1 2 5

den =

0 1 0

>> printsys(num,den)

num/den =

s^2 + 2 s + 5

-------------

s

3.反馈结构的化简

前向通道传函 8c4b85a994c84c9067f555c6c82ff501.png 反馈通道传函 47156e843b560f2ada2f65fe07bfa739.png

等效闭环传函

be81dc3790cd8295466f68bc02df318a.gif

函数feedback(sys1,sys2,sign)可用来化简反馈结构,参数sign表示反馈量在相加点的符号,默认为负反馈。

例 2.5.14 反馈结构中,bd1b24db90901dc9c5b74ea20496ae4b.png  相加点处符号为负(负反馈),求等效闭环传函。

解 程序运行如下:

>> num1 = [1];

>> den1 = [500 0 0];

>> num2 = [1 1];

>> den2 = [1 2];

>> [num den] = feedback(num1,den1,num2,den2)

num =

0 0 1 2

den =

500 1000 1 1

>> printsys(num,den)

num/den =

s + 2

---------------------------

500 s^3 + 1000 s^2 + s + 1

第二章仿真练习先做到这里~

^_^//

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值