matlab ss函数 tf函数.docx

上传人:小飞机 文档编号:3061552 上传时间:2023-03-10 格式:DOCX 页数:7 大小:39.55KB
返回 下载 相关 举报
matlab ss函数 tf函数.docx_第1页
第1页 / 共7页
matlab ss函数 tf函数.docx_第2页
第2页 / 共7页
matlab ss函数 tf函数.docx_第3页
第3页 / 共7页
matlab ss函数 tf函数.docx_第4页
第4页 / 共7页
matlab ss函数 tf函数.docx_第5页
第5页 / 共7页
亲,该文档总共7页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《matlab ss函数 tf函数.docx》由会员分享,可在线阅读,更多相关《matlab ss函数 tf函数.docx(7页珍藏版)》请在三一办公上搜索。

1、matlab ss函数 tf函数matlabss函数tf函数 ss指定状态空间模型或者将线性时不变系统转成状态空间语法 ss sys = ss(a,b,c,d) sys = ss(a,b,c,d,Ts) sys = ss(d) sys = ss(a,b,c,d,ltisys) sys_ss = ss(sys) 说明 ss用来创建实数或复数的状态空间模型,或者将传递函数和零极点增益模型转为状态空间模型 创建状态空间模型 sys = ss(a,b,c,d) 创建连续的状态空间模型 x=Ax+Bu y=Cx+Du 这个模型具有Nx个状态,Ny个输出,Nu个输入 a是Nx*Nx的矩阵 b是Nx-by-

2、Nu矩阵 c 是Ny-by-Nx矩阵 d 是Ny-by-Nu 矩阵 将d设为标量0,来将矩阵D设置为0,更多信息见设置为状态空间模型matlab, sys = ss(a,b,c,d,Ts) 创建离散时间模型 x=Ax+Bu y=Cx+Du 采样时间单位Ts为S,设置Ts = -1 or Ts = 将不指定采样时间 sys = ss(d) 指定一个静态增益矩阵D 等同于表达式 sys = ss(,d) sys = ss(a,b,c,d,ltisys)创建了拥有来源于线性时不变模型ltisys的一般线性时不变属性的状态空间模型(包括了采样时间). 所有上述语法后面都可以跟随其属性名称属性值 所有的

3、属性对指定了模型的特殊的LTI性质,例如在模型中输入的名称或者一些注释,更多细节见例1.表达式如下: sys = ss(a,b,c,d,Property1,Value1,.,PropertyN,ValueN) 等同于sys = ss(a,b,c,d) set(sys,Property1,Value1,.,PropertyN,ValueN) 转换为状态空间模型 sys_ss = ss(sys) 将任意的TF or ZPK 模型系统转换为状态空间模型,输出_ss is 等同于状态空间模型(SS object). sys_ss = ss(sys,minimal)为状态空间的最小实现等同于sys_ss

4、 = minreal(ss(sys) 注意状态空间转换在单输入单输出的情况下并不唯一,在多输入输出中并不能保证状态空间的最小实现,更多信息,参照 Caution About Model Conversions. 算法 对于 TF to SS 模型转换, ss(sys_tf) 返回一个修改后的可控规范化的形式,此算法类似于 tf2ss,但是可以进一步重新调节状态向量以压缩矩阵A数值,并改进后来的数值计算。 对于 ZPK to SS 模型转换ss(sys_zpk) uses direct form II structures, as defined in signal processing tex

5、ts. See Discrete-Time Signal Processing by Oppenheim and Schafer for details. For example, in the following code, A and sys.a differ by 对角线状态转换: n=1 1; d=1 1 10; A,B,C,D=tf2ss(n,d); sys=ss(tf(n,d); A A = -1 -10 1 0 sys.a ans = -1 -5 2 0 例子 例一 命令sys = ss(A,B,C,D,0.05,statename,position velocity,. inp

6、utname,force,. notes,Created 10/15/07) 用A,B,C,D 和采样时间0.05 s创建离散的时间模型,This model has two states labeled position and velocity, and one input labeled force ( A,B,C,D维数与一致数值的状态和输入一致). Finally, a note is attached with the date of creation of the model. Example 2 Compute a state-space realization of the

7、transfer function matlabss函数tf函数 by typing H = tf(1 1,1 3 3 2) ; tf(1 0 3,1 1 1); sys = ss(H); size(sys) State-space model with 2 outputs, 1 input, and 5 states. The number of states is equal to the cumulative order of the SISO entries of H(s). To obtain a minimal realization of H(s), type sys = ss(

8、H,min); size(sys) State-space model with 2 outputs, 1 input, and 3 states. The resulting state-space model has order of three, which is the minimum number of states needed to represent H(s). You can see this number of states by factoring H(s) as the product of a first-order system with a second-orde

9、r system. matlabss函数tf函数 另Tf函数用来建立实部或复数传递函数模型或将状态方程、或零级增益模型转化成传递函数形式。 sys = tf(num,den)命令可以建立一个传递函数,其中分子和分母分别为num和den。输出sys是储存传递函数数据的传递函数目标。 单输入单输出情况下,num和den是s的递减幂级数构成的实数或复数行向量。这两个向量并不要求维数相同。如h = tf(1 0,1)就明确定义了纯导数形式h(s)=s。 若要构建多输入多输出传递函数,要分别定义每一个单输入单输出系统的端口的分子与分母。这种情况下:Num和den是单元数组,其中行数等于输出数,列数等于输

10、入数; 行向量numi,j和deni,j定义了从输入j到输出i的传递函数的分子与分母。如果此多输入多输出系统的传递函数中所有的单输入单输出端口有相同的分母,可以设置den为代表这个通用分母的行向量。 sys = tf(num,den,Ts)可以创建一个采样时间为Ts的离散时间传递函数。设置Ts = -1 or Ts = 将不指定采样时间。有关num和den的设置与连续系统一样。 sys = tf(M)可以创建一个静态增益M。 sys = tf(num,den,ltisys)创建一个拥有来源于线性时不变模型ltisys的一般线性时不变属性的传递函数。有很多种方法可以创建线性时不变传递函数的数组。

11、前面介绍的语法可以通过属性名,属性值来进行。 Property,Value每一对上述定义都明确指定模型的一个线性时不变属性,如输入名或传递函数变量。 sys = tf(num,den,Property1,Value1,.,PropertyN,ValueN)是下述语句的简写形式 sys = tf(num,den) set(sys,Property1,Value1,.,PropertyN,ValueN) 作为s或z的有理表达式的传递函数可以应用实数或复数有理表达式来创建一个传递函数模型。 s = tf(s)用拉普拉斯算符s的有理表达式来创建传递函数; z = tf(z,Ts)用离散时间变量z的有理

12、表达式创建采样时间为Ts的传递函数模型。 一旦你定义了s或z变量,就可以直接将传递函数模型定义为上述变量的有理表达式。 如何转化为传递函数 tfsys = tf(sys)可以将任意一个SS模型或ZPK线性时不变模型转化成传递函数的形式。输出tfsys便是sys的传递函数。缺省状态下tf用0作为分子来转化一个状态空间模型到一个传递函数形式。 tfsys = tf(sys,inv)用反演公式来得到分子。这种算法较快,但是在s=0的高阶模型中精度较差。 算例1 创建一两输出单输入传递函数 其中输入为电流,输出为扭矩和角速度。 num = 1 1 ; 1 den = 1 2 2 ; 1 0 H = t

13、f(num,den,inputn,current,outputn,torque ang. velocity,variable,p) 从输入电流到输出扭矩的传递函数为(P+1)/(P2+2P+2),到输出角速度的传递函数为1/P。在设置中设置variable属性为p会使得结果以p的表达式来显示。 算例2 用有理表达式来创建单输入单输出传递函数模型 s = tf(s); H = s/(s2 + 2*s +10); 这样会与h = tf(1 0,1 2 10)得到相同的传递函数。 算例3 创建离散多输入多输出传递函数模型 分母相同d(z)=z+0.3,采样时间0.2s。 nums = 1 1 0;-

14、1 2 3 Ts = 0.2 H = tf(nums,1 0.3,Ts) % 注意此处行向量代表分母d(z) 算例4 计算下列状态空间模型的传递函数 sys = ss(-2 -1;1 -2,1 1;2 -1,1 0,0 1) tf(sys) 从输入1到输出的传递函数为 s s2 + 4 s + 5 从输入2到输出的传递函数为 s2 + 5 s + 8 s2 + 4 s + 5 算例5 可以应用for循环来定义一个10*1的单输入单输出传递函数模型 s = tf(s) H = tf(zeros(1,1,10); for k=1:10, H(:,:,k) = k/(s2+s+k); end 此处率先为传递函数矩阵分配了一个空间。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号