www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 消費電子 > 消費電子
[導讀]Matlab可以說是一個非常有用且功能齊全的工具,在通信、自控、金融等方面有廣泛的應用。本文討論使用Matlab對信號進行頻域分析的方法。說到頻域,不可避免的會提到傅里葉變

Matlab可以說是一個非常有用且功能齊全的工具,在通信、自控、金融等方面有廣泛的應用。

本文討論使用Matlab對信號進行頻域分析的方法。

說到頻域,不可避免的會提到傅里葉變換,傅里葉變換提供了一個將信號從時域轉(zhuǎn)變到頻域的方法。之所以要有信號的頻域分析,是因為很多信號在時域不明顯的特征可以在頻域下得到很好的展現(xiàn),可以更加容易的進行分析和處理。

FFT

Matlab提供的傅里葉變換的函數(shù)是FFT,中文名叫做快速傅里葉變換??焖俑道锶~變換的提出是偉大的,使得處理器處理數(shù)字信號的能力大大提升,也使我們生活向數(shù)字化邁了一大步。

接下來就談談如何使用這個函數(shù)。

fft使用很簡單,但是一般信號都有x和y兩個向量,而fft只會處理y向量,所以想讓頻域分析變得有意義,那么就需要用戶自己處理x向量

一個簡單的例子

從一個簡單正弦信號開始吧,正弦信號定義為:

 

 

我們現(xiàn)在通過以下代碼在Matlab中畫出這個正弦曲線

fo = 4; %frequency of the sine wave

Fs = 100; %sampling rate

Ts = 1/Fs; %sampling time interval

t = 0:Ts:1-Ts; %sampling period

n = length(t); %number of samples

y = 2*sin(2*pi*fo*t); %the sine curve

%plot the cosine curve in the time domain

sinePlot = figure;

plot(t,y)

xlabel('time (seconds)')

ylabel('y(t)')

title('Sample Sine Wave')

grid

這就是我們得到的:

 

 

當我們對這條曲線fft時,我們希望在頻域得到以下頻譜(基于傅里葉變換理論,我們希望看見一個幅值為1的峰值在-4Hz處,另一個在+4Hz處)

 

 

使用FFT命令

我們知道目標是什么了,那么現(xiàn)在使用Matlab的內(nèi)建的FFT函數(shù)來重新生成頻譜

%plot the frequency spectrum using the MATLAB fft command

matlabFFT = figure; %create a new figure

YfreqDomain = fft(y); %take the fft of our sin wave, y(t)

stem(abs(YfreqDomain)); %use abs command to get the magnitude

%similary, we would use angle command to get the phase plot!

%we'll discuss phase in another post though!

xlabel('Sample Number')

ylabel('Amplitude')

title('Using the Matlab fft command')

grid

axis([0,100,0,120])

效果如下:

 

 

但是注意一下,這并不是我們真正想要的,有一些信息是缺失的

x軸本來應該給我們提供頻率信息,但是你能讀出頻率嗎?

幅度都是100

沒有讓頻譜中心為

為FFT定義一個函數(shù)來獲取雙邊頻譜

以下代碼可以簡化獲取雙邊頻譜的過程,復制并保存到你的.m文件中

function [X,freq]=centeredFFT(x,Fs)

%this is a custom function that helps in plotting the two-sided spectrum

%x is the signal that is to be transformed

%Fs is the sampling rate

N=length(x);

%this part of the code generates that frequency axis

if mod(N,2)==0

k=-N/2:N/2-1; % N even

else

k=-(N-1)/2:(N-1)/2; % N odd

end

T=N/Fs;

freq=k/T; %the frequency axis

%takes the fft of the signal, and adjusts the amplitude accordingly

X=fft(x)/N; % normalize the data

X=fftshift(X); %shifts the fft data so that it is centered

這個函數(shù)輸出正確的頻域范圍和變換后的信號,它需要輸入需要變換的信號和采樣率。

接下來使用前文的正弦信號做一個簡單的示例,注意你的示例.m文件要和centeredFFT.m文件在一個目錄下

[YfreqDomain,frequencyRange] = centeredFFT(y,Fs);

centeredFFT = figure;

%remember to take the abs of YfreqDomain to get the magnitude!

stem(frequencyRange,abs(YfreqDomain));

xlabel('Freq (Hz)')

ylabel('Amplitude')

title('Using the centeredFFT function')

grid

axis([-6,6,0,1.5])

效果如下:

 

 

這張圖就滿足了我們的需求,我們得到了在+4和-4處的峰值,而且幅值為1.

為FFT定義一個函數(shù)來獲取右邊頻譜

從上圖可以看出,F(xiàn)FT變換得到的頻譜是左右對稱的,因此,我們只需要其中一邊就能獲得信號的所有信息,我們一般保留正頻率一側(cè)。

以下的函數(shù)對上面的自定義函數(shù)做了一些修改,讓它可以幫助我們只畫出信號的正頻率一側(cè)

function [X,freq]=positiveFFT(x,Fs)

N=length(x); %get the number of points

k=0:N-1; %create a vector from 0 to N-1

T=N/Fs; %get the frequency interval

freq=k/T; %create the frequency range

X=fft(x)/N; % normalize the data

%only want the first half of the FFT, since it is redundant

cutOff = ceil(N/2);

%take only the first half of the spectrum

X = X(1:cutOff);

freq = freq(1:cutOff);

和前面一樣,使用正弦信號做一個示例,下面是示例代碼

[YfreqDomain,frequencyRange] = positiveFFT(y,Fs);

positiveFFT = figure;

stem(frequencyRange,abs(YfreqDomain));

set(positiveFFT,'Position',[500,500,500,300])

xlabel('Freq (Hz)')

ylabel('Amplitude')

title('Using the positiveFFT function')

grid

axis([0,20,0,1.5])

效果如下:

 

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉