matlab中ss函数_matlab ss函数 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-Nu矩阵

c 是Ny-by-Nx矩阵

d 是 Ny-by-Nu 矩阵

将d设为标量0,来将矩阵D设置为0,更多信息见设置为状态空间模型matlab(state-space models),

sys = ss(a,b,c,d,Ts) 创建离散时间模型

x(n+1)=Ax(n)+Bu(n)

y(n)=Cx(n)+Du(n)

采样时间单位Ts为S,设置Ts = -1 or Ts = []将不指定采样时间

sys = ss(d) 指定一个静态增益矩阵D 等同于表达式

sys = ss([],[],[],d)

sys =

ss(a,b,c,d,ltisys)创建了拥有来源于线性时不变模型ltisys的一般线性时不变属性的状态空间模型(包括了采样时间).

所有上述语法后面都可以跟随其属性名称 属性值

所有的属性对指定了模型的特殊的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

= minreal(ss(sys))

注意状态空间转换在单输入单输出(SIS0)的情况下并不唯一,在多输入输出(MIMO)中并不能保证状态空间的最小实现,更多信息,参照 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 texts. 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'},...

'inputname','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 transfer function

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(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-order system.

另Tf函数用来建立实部或复数传递函数模型或将状态方程、或零级增益模型转化成传递函数形式。

sys =

tf(num,den)命令可以建立一个传递函数,其中分子和分母分别为num和den。输出sys是储存传递函数数据的传递函数目标。

单输入单输出情况下,num和den是s的递减幂级数构成的实数或复数行向量。这两个向量并不要求维数相同。如h = tf([1

0],1)就明确定义了纯导数形式h(s)=s。

若要构建多输入多输出传递函数,要分别定义每一个单输入单输出系统的端口的分子与分母。这种情况下:Num和den是单元数组,其中行数等于输出数,列数等于输入数; 行向量num{i,j}和den{i,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的一般线性时不变属性的传递函数。有很多种方法可以创建线性时不变传递函数的数组。前面介绍的语法可以通过属性名,属性值来进行。

'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的有理表达式创建采样时间为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 = tf(num,den,'inputn','current','outputn',{'torque' 'ang.

velocity'},'variable','p')

从输入电流到输出扭矩的传递函数为(P+1)/(P^2+2P+2),到输出角速度的传递函数为1/P。在设置中设置'variable'属性为p会使得结果以p的表达式来显示。

算例2

用有理表达式来创建单输入单输出传递函数模型

s = tf('s'); H = s/(s^2 + 2*s +10); 这样会与h = tf([1 0],[1 2 10])得到相同的传递函数。

算例3 创建离散多输入多输出传递函数模型

分母相同d(z)=z+0.3,采样时间0.2s。

nums = {1 [1 0];[-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 s^2 + 4 s + 5

从输入2到输出的传递函数为 s^2 + 5 s + 8 s^2 + 4 s + 5

算例5

可以应用for循环来定义一个10*1的单输入单输出传递函数模型

s = tf('s')

H =

tf(zeros(1,1,10));

for

k=1:10,

H(:,:,k) =

k/(s^2+s+k);

end

此处率先为传递函数矩阵分配了一个空间。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值