网站大量收购独家精品文档,联系QQ:2885784924

如何使用matlab进行频域分析.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何使用matlab进行频域分析 Matlab可以说是一个非常有用且功能齐全的工具,在通信、自控、金融等方面有广泛的应用。 本文讨论使用Matlab对信号进行频域分析的方法。 说到频域,不可避免的会提到傅里叶变换,傅里叶变换提供了一个将信号从时域转变到频域的方法。之所以要有信号的频域分析,是因为很多信号在时域不明显的特征可以在频域下得到很好的展现,可以更加容易的进行分析和处理。 FFT Matlab提供的傅里叶变换的函数是FFT,中文名叫做快速傅里叶变换。快速傅里叶变换的提出是伟大的,使得处理器处理数字信号的能力大大提升,也使我们生活向数字化迈了一大步。 接下来就谈谈如何使用这个函数。 fft使用很简单,但是一般信号都有x和y两个向量,而fft只会处理y向量,所以想让频域分析变得有意义,那么就需要用户自己处理x向量 一个简单的例子 从一个简单正弦信号开始吧,正弦信号定义为: y(t)=2sin?(2πf0t) 我们现在通过以下代码在Matlab中画出这个正弦曲线 1? fo = 4;?? %frequency of the sine wave 2? Fs = 100; %sampling rate 3? Ts = 1/Fs; %sampling time interval 4? t = 0:Ts:1-Ts; %sampling period 5? n = length(t); %number of samples 6? y = 2*sin(2*pi*fo*t); %the sine curve 7 8? %plot the cosine curve in the time domain 9? sinePlot = figure; 10? plot(t,y) 11? xlabel(time (seconds)) 12? ylabel(y(t)) 13? title(Sample Sine Wave) 14? grid 这就是我们得到的: 当我们对这条曲线fft时,我们希望在频域得到以下频谱(基于傅里叶变换理论,我们希望看见一个幅值为1的峰值在-4Hz处,另一个在+4Hz处) 使用FFT命令 我们知道目标是什么了,那么现在使用Matlab的内建的FFT函数来重新生成频谱 1? %plot the frequency spectrum using the MATLAB fft command 2? matlabFFT = figure;? %create a new figure 3? YfreqDomain = fft(y); %take the fft of our sin wave, y(t) 4 5? stem(abs(YfreqDomain));? %use abs command to get the magnitude 6? %similary, we would use angle command to get the phase plot! 7? %well discuss phase in another post though! 8 9? xlabel(Sample Number) 10? ylabel(Amplitude) 11? title(Using the Matlab fft command) 12? grid 13? axis([0,100,0,120]) 效果如下: 但是注意一下,这并不是我们真正想要的,有一些信息是缺失的 · x轴本来应该给我们提供频率信息,但是你能读出频率吗? · 幅度都是100 · 没有让频谱中心为0 为FFT定义一个函数来获取双边频谱 以下代码可以简化获取双边频谱的过程,复制并保存到你的.m文件中 1? function [X,freq]=centeredFFT(x,Fs) 2? %this is a custom function that helps in plotting the two-sided spectrum 3? %x is the signal that is to be transformed 4? %Fs is the sampling rate 5 6? N=length(x); 7 8? %this part of the code generates that frequency axis 9? if mod(N,2)==0 10??? k=-N/2:N/2-1; % N even 11? else 12??? k=-(N-1)/2:(N-1)/2; % N odd 13? end 14? T=N/Fs; 15? freq=k/T;? %the frequency axis 16 17? %takes the fft of the sign

文档评论(0)

Jane9872 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档