EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
Matlab可以说是一个非常有用且功能齐全的工具,在通信、自控、金融等方面有广泛的应用。 本文讨论使用Matlab对信号进行频域分析的方法。 说到频域,不可避免的会提到傅里叶变换,傅里叶变换提供了一个将信号从时域转变到频域的方法。之所以要有信号的频域分析,是因为很多信号在时域不明显的特征可以在频域下得到很好的展现,可以更加容易的进行分析和处理。 FFT' ~: j9 `$ E: u4 f b# f3 r
Matlab提供的傅里叶变换的函数是FFT,中文名叫做快速傅里叶变换。快速傅里叶变换的提出是伟大的,使得处理器处理数字信号的能力大大提升,也使我们生活向数字化迈了一大步。 接下来就谈谈如何使用这个函数。 fft使用很简单,但是一般信号都有x和y两个向量,而fft只会处理y向量,所以想让频域分析变得有意义,那么就需要用户自己处理x向量 一个简单的例子 从一个简单正弦信号开始吧,正弦信号定义为: 我们现在通过以下代码在Matlab中画出这个正弦曲线 fo = 4; %frequency of the sine wave
$ l: o8 K5 E6 i# r& Z: c& q" t) Y: UFs = 100; %sampling rate8 T* y" {8 S* S Y
Ts = 1/Fs; %sampling time interval
+ ^# Q* k' _9 j1 H" St = 0:Ts:1-Ts; %sampling period
/ ~; E0 X& L# A7 k! k$ Hn = length(t); %number of samples
3 [8 Q: V- K. J# X, [y = 2*sin(2*pi*fo*t); %the sine curve
" A7 S% X# A9 b. v* T
8 ^; M- _" f3 ?3 i* d! g4 F%plot the cosine curve in the time domain3 R+ t0 r" s2 u3 F9 _) p! g0 n
sinePlot = figure;* K# D% c- m3 c4 \7 W! `
plot(t,y)& J( B( {/ m! Z0 K: o; |: Y! l
xlabel('time (seconds)')" [. H' b' I; B; r# X
ylabel('y(t)')* R; E: G* r R1 |
title('Sample Sine Wave') Y) b+ P0 M1 e
grid 这就是我们得到的: : ~) z/ u4 d3 v
2 w( s! S2 o8 y9 H: l7 m. z0 ?4 ^ |