找回密码
 注册
关于网站域名变更的通知
查看: 685|回复: 1
打印 上一主题 下一主题

使用 MATLAB 求某输入的稳态响应

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-4-26 11:13 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
/ m0 g  ?0 t& b- V7 L# h' E, K
稳态响应是在本科,更确切地说是在考研时候经常接触的,例如电路基础、信号与系统中就常有稳态响应这个词。3 H, |  W; f- f+ o' S) C' |0 _
9 ^7 J' @$ d5 F& w! m/ B
今天在补习MATLAB数字信号处理时,突然碰到稳态响应,一脸懵逼,感觉并不理解什么是稳态响应了,也许之前也没有懂过吧。
& f# k! s8 e5 @
  `4 U5 f* G* k4 d. @% b百度百科对概念进行了解释:
( o+ Q  v2 `4 c
% k$ O1 W) |1 N  ]5 t0 M稳态响应是指当足够长的时间之后,系统对于固定的输入,有了一个较为稳定的输出。
" ]4 ]: a( R  j( c
+ B& ^- N# I4 q' x# t7 L在某一输入信号的作用后,时间趋于无穷大时系统的输出状态称为稳态。
' L% C3 ^6 j- g0 ^* H- U( _: q% b! o
下面就一起来体会这个稳态响应吧。
8 r  }1 ]( k% @% c# Q7 c
' O+ ?# c: G3 l9 o1 T* e3 e! ~3 A! {
LTI 系统对复指数信号的响应" K9 E7 {" g  ^, Q
好久之前写过的一篇上:线性时不变系统(LTI)对复指数信号的响应(数字信号处理的特征值与特征函数)/ O- k# i: f* y
4 ~  e6 {) ~$ }
就已经说明了线性时不变系统对于复指数信号的响应,简单地说,输入序列经过线性时不变系统之后的响应就是在该频率处的系统频率响应乘以该复指数信号。
( p! F( D9 ^/ ]" x8 q6 Z" O
8 c/ L) m* ?8 P8 O  a, `! i即,如果系统的频率响应为 经过系统的响应如下:
) _: D4 K' D& n& J1 I) N. n
! K" [) h. I  B$ U$ ?, q 3 C0 W8 f% k* r" c+ `
0 n! I6 i; }7 f5 q( b& `$ ?
对正弦序列的响应' t7 m  j/ i: ?2 w8 @' ^
设输入序列为
' B( K3 B8 p/ a  O
4 k+ K% b+ _/ a7 J' I" Q( w系统的频率响应为:
6 S  e7 p" o6 R* b+ t# k) `+ @/ E, F; U+ X/ O5 U2 E; F
正弦序列可以表示成复指数序列之和,这样就可以利用LTI系统对复指数序列的响应,求得LTI系统对正弦序列的响应。如下:
- c% a# A+ ]3 \/ k
" m- P. b# d* R ' ]; n4 J% K% A/ x% E' F+ `
, t" \" F7 Y& q+ R: W. Y, O2 C
这就得到了如下结论:
. W/ b( N& K, _+ |2 v
0 v! ~4 T& i/ ^, z5 `( ~0 uLTI系统对正弦序列的响应是相同频率w0的另一个正弦序列,其幅值被 所倍增,而相位则相移 ,即
' J2 X8 J6 k) n3 {( A0 `
+ n: a7 q1 d  @( a- k) B: K+ r' u' d9 d& N7 l

  u4 ]; q: f  f  s- Z7 T
- J8 \# L7 H6 s; U; n7 r4 r& T7 \! u5 k- f! o* J; O
这个响应称为稳态响应,用 表示。' Z. [  l- d1 b8 b$ a
( y# o$ S: d! p
案例1* a. `5 O6 {( d4 c4 g2 V9 d2 i
: S* u9 f( B# @- c
求由脉冲响应 所表征的系统频率响应 ,画出幅度和相位响应。5 u' C" F1 s9 ^0 a; k: h( I

0 V9 f! x* V4 X8 |题解:  d5 ?, {$ X# i& I+ x% H

+ t+ v# v% E: |$ H+ z, q; I很简单,根据DTFT的公式就可以直接求出该脉冲响应的离散时间傅里叶变换:
9 A4 B: b1 |4 l3 v+ m; p5 s& P4 Q4 z- S# X" ^

' i/ |/ v- u- {: ^- i5 @: S% R1 M  R8 {
MATLAB脚本如下:& A. k2 H: o0 E

1 `9 u' m6 B/ R0 e% m/ x+ Y" ?
  • clc
  • clear
  • close all
  • k = 0:500;
  • w = (pi/500)*k;
  • X = exp(j*w)./( exp(j*w) - 0.9*ones(1,501) );
  • magX = abs(X);
  • angX = angle(X);
  • realX = real(X);
  • imagX = imag(X);
  • subplot(2,1,1);
  • plot(w/pi,magX);
  • title('Magnitude Part');
  • xlabel('w/pi');ylabel('Magnitude');
  • grid
  • subplot(2,1,2);
  • plot(w/pi,angX);
  • title('Angle Part');
  • xlabel('w/pi');ylabel('Radians');
  • grid
    ! e) X% \2 U- i. w+ E4 I. R! U6 Q
   
/ q8 K, g1 S1 ^3 i2 J
% O9 @% g7 Y* Q: ~0 p. i & d% x: q7 ~, A
: n: {4 b; Y6 f0 I

. C& p  D6 ?0 ]% u' d; d% _系统的频率响应求出来了,那么现在的这个案例就是给定一个输入,求其稳态响应。6 E( G( H5 x3 e

  \, T: P$ G* M! [) v1 M8 e案例2
2 c  `: p- F, u+ Z! `: u$ |7 ?' E# F  S5 d
案例1的系统,输入是0.1u(n),求稳态响应
9 E/ u: c; S1 S$ m$ X! U/ f
" P0 @* ?$ r+ O题解:: b& d& x1 u2 D8 z. o' Z

7 ]% }3 R" }) U. E8 I7 z3 d/ |$ Y在稳态,输入是一常数序列(或者 的正弦序列),然后输出是:& {. b. f1 G7 |4 F$ y8 `  U

3 y. e" k6 t% {2 X  H - [& C* x) ]7 Z; @: N
% v0 Q% r+ X. U# ]3 b3 E

# V6 K# a0 g  Y$ C4 Y7 _5 l6 b( l# y
案例3: U6 L( v5 s2 D7 w; f0 j

- o3 A# B* C/ l一LTI系统由下面的差分方程表征:/ H: o! V/ C* Y4 r" F/ I

: `8 {6 d3 w) L. Z/ [; f) E8 n- Ey(n)=0.8y(n-1)+x(n)
* Z" f% |( l9 r, L
4 `! j3 C- v% @. j- z9 x5 ], X0 E1.求频率响应
: E: K+ P6 u& ~2 `  d" U& F# n+ @7 Q5 d; @
2.对输入 计算并画出稳态响应 ) J# i- x. n4 w3 N* s; z
# b8 h! S) J# |5 |$ N1 P6 e
题解:
6 @+ d9 G( s9 @9 b3 h
" c( i6 Y1 d3 K( P* u5 s1.由差分方程求解频率响应太好求了,分子分母系数都给出了,可以直接写出频率响应,如果在z变换中成为有理转移函数。0 l) |8 T. G# @1 S3 P/ u
4 Y9 x( `8 |$ v8 n# Z( P
这里直接给出频率响应:
$ ]: t' r, V/ t- X, N+ A. M; k8 L# A; ]$ k7 \
- s* ]$ b; V$ U$ A% d8 g. ?
, x# }- I% I5 k+ b& q/ c4 p
2.在稳态下,输入是 ,其频率为 ,系统的频率响应应该是:
  ~* ~; M& ?( G  E# @
# K. K) H/ `2 v! M+ z
& `0 z1 l0 r% n$ |9 b5 ?  M" O
9 b7 D: }3 C( C/ Y2 K, h5 E) L因此,
4 e8 Y( }2 x3 `: h" j6 C0 Q4 C% J
2 H! [. I/ U) a9 n也就是说,在输出端该正弦被放大了4.0928倍,移位了3.42个样本。# n4 k8 {6 w6 S- j# `+ {  }4 s
) g9 w# Z  U: c
下面用MATLAB脚本验证:
! ~3 z, [6 ]* x
3 m' o5 x0 X: e6 f# U, I+ O! c
  • clc
  • clear
  • close all
  • b = 1;
  • a = [1,-0.8];
  • n = [0:100];
  • x = cos(0.05*pi*n);
  • y = filter(b,a,x);
  • subplot(2,1,1)
  • stem(n,x);
  • title('Input sequence')
  • xlabel('n');ylabel('x(n)');
  • subplot(2,1,2)
  • stem(n,y);
  • title('Output sequence');
  • xlabel('n');ylabel('y(n)');
    % ?9 U- f* ~" Z$ k" Y( T, Y* G% L$ |
   
  R% f+ d8 @" X6 L& e4 ?' x& j: r$ m  Y& d2 C

- A. B. [/ R1 K# ]) {
3 `9 [9 V& D% l2 K: T
, f; r8 O1 S& ~% Y可见,幅度和相位都变化了。
5 o: [/ c+ J& Q! C4 r1 x, x3 d' E) O  Y! t. @" F: ?
最后,关于filter函数的介绍见:# ?" k4 N4 J) `; J) n

: `0 Y2 [# C5 J3 s% E0 t( J+ @3 [MATLAB之filter 函数介绍(一维数字滤波器)
. H# x" [( i$ z. P8 C2 o  c2 l0 X! Z& }  m# \$ V  E6 d: n

$ n! ]& R7 [2 @3 z2 [  [

该用户从未签到

2#
发表于 2021-4-26 13:11 | 只看该作者
使用 MATLAB 求某输入的稳态响应
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-10-30 13:59 , Processed in 0.171875 second(s), 27 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表