如何用matlab實現自相關和互相關

2021-05-18 13:09:58 字數 5349 閱讀 9351

1樓:匿名使用者

1. 首先說說自相關和互相關的概念。

這個是訊號分析裡的概念,他們分別表示的是兩個時間序列之間和同一個時間序列在任意兩個不同時刻的取值之間的相關程度,即互相關函式是描述隨機訊號

x(t),y(t)在任意兩個不同時刻t1,t2的取值之間的相關程度,自相關函式是描述隨機訊號x(t)在任意兩個不同時刻t1,t2的取值之間的相關

程度。自相關函式是描述隨機訊號x(t)在任意兩個不同時刻t1,t2的取值之間的相關程度;互相關函式給出了在頻域內兩個訊號是否相關的一個判斷指標,把兩測點之間訊號的互譜與各自的自譜聯絡了起來。它能用來確定輸出訊號有多大程度來自輸入訊號,對修正測量中接入噪聲源而產生的誤差非常有效.

事實上,在圖象處理中,自相關和互相關函式的定義如下:設原函式是f(t),則自相關函式定義為r(u)=f(t)*f(-t),其中*表示卷積;設兩個

函式分別是f(t)和g(t),則互相關函式定義為r(u)=f(t)*g(-t),它反映的是兩個函式在不同的相對位置上互相匹配的程度。

那麼,如何在matlab中實現這兩個相關並用影象顯示出來呢?

dt=.1;

t=[0:dt:100];

x=cos(t);

[a,b]=xcorr(x,'unbiased');

plot(b*dt,a)

上面**是求自相關函式並作圖,對於互相關函式,稍微修改一下就可以了,即把[a,b]=xcorr(x,'unbiased');改為[a,b]=xcorr(x,y,'unbiased');便可。

2. 實現過程:

在matalb中,求解xcorr的過程事實上是利用fourier變換中的卷積定理進行的,即r(u)=ifft(fft(f)×fft(g)),其中

×表示乘法,注:此公式僅表示形式計算,並非實際計算所用的公式。當然也可以直接採用卷積進行計算,但是結果會與xcorr的不同。事實上,兩者既然有定

理保證,那麼結果一定是相同的,只是沒有用對公式而已。下面是檢驗兩者結果相同的**:

dt=.1;

t=[0:dt:100];

x=3*sin(t);

y=cos(3*t);

subplot(3,1,1);

plot(t,x);

subplot(3,1,2);

plot(t,y);

[a,b]=xcorr(x,y);

subplot(3,1,3);

plot(b*dt,a);

yy=cos(3*fliplr(t)); % or use: yy=fliplr(y);

z=conv(x,yy);

pause;

subplot(3,1,3);

plot(b*dt,z,'r');

即在xcorr中不使用scaling。

3. 其他相關問題:

(1)相關程度與相關函式的取值有什麼聯絡?

相關係數只是一個比率,不是等單位量度,無什麼單位名稱,也不是相關的百分數,一般取小數點後兩位來表示。相關係數的正負號只表示相關的方向,絕對值表示相關的程度。因為不是等單位的度量,因而不能說相關係數0.

7是0.35兩倍,只能說相關係數為0.7的二列變數相關程度比相關係數為0.

35的二列變數相關程度更為密切和更高。也不能說相關係數從0.70到0.

80與相關係數從0.30到0.40增加的程度一樣大。

對於相關係數的大小所表示的意義目前在統計學界尚不一致,但通常是這樣認為的:

相關係數 相關程度

0.00-±0.30 微相關

±0.30-±0.50 實相關

±0.50-±0.80 顯著相關

±0.80-±1.00 高度相關

(2)matlab計算自相關函式autocorr和xcorr有什麼不一樣的?

分別用這兩個函式對同一個序列計算,為什麼結果不太一樣?因為xcorr是沒有將均值減掉做的相關,autocorr則是減掉了均值的。而且,用離散訊號做自相關時,訊號擷取長度(取樣點n)不一樣,自相關函式就不一樣。

(3)xcorr是計算互相關函式,帶有一個option的引數:

a=xcorr(x,y,'option')

option=baised時,是計算互相關函式的有偏估計;

option=unbaised時,是計算互相關函式的無偏估計;

option=coeff時,是計算歸一化的互相關函式,即為互相關係數,在-1至1之間;

option=none,是預設的情況。

所以想要計算互相關係數,可用'coeff'引數。

用這個xcorr函式作離散互相關運算時要注意,當x, y是不等長向量時,短的向量會自動填0與長的對齊,運算結果是行向量還是列向量就與x一樣。

互相關運算計算的是x,y兩組隨機資料的相關程度,使用引數coeff時,結果就是互相關係數,在-1至1之間,否則結果不一定在這範圍,有可能很大也有可能很小,這視乎x, y資料的大小,所以一般要計算兩組資料的相關程度,一般選擇coeff引數,對結果進行歸一化。

所謂歸一化簡單理解就是將資料系列縮放到-1到1範圍,正式的就是一種簡化計算的方式,即將有量綱的表示式,經過變換,化為無量綱的表示式,成為純量。變換式為x=(x實測--xmin)/(xmax-xmin)。

一般來說選擇歸一化進行互相關運算後,得到結果絕對值越大,兩組資料相關程度就越高。

2樓:匿名使用者

求自相關函式並作圖dt=.1;t=[0:dt:

100];x=cos(t);[a,b]=xcorr(x,'unbiased');plot(b*dt,a)詳情檢視xcorr的matlab幫助~~~

matlab如何實現自相關函式

3樓:匿名使用者

自相關函式是描述隨機訊號x(t)在任意兩個不同時刻t1,t2的取值之間的相關程度.設原函式是f(t),則自相關函式定義為r(u)=f(t)*f(-t),其中*表示卷積.

給個例子:

dt=.1;

t=[0:dt:100];

x=cos(t);

[a,b]=xcorr(x,'unbiased');

plot(b*dt,a)

上面**是求自相關函式並作圖,

matlab中檢視幫助時,

help xcorr 解釋其意思是:

c(m) = e[a(n+m)*conj(b(n))] = e[a(n)*conj(b(n-m))];

但是,在呼叫xcorr函式求自相關時,有 scaleopt引數

r=xcorr(s,scaleopt)

scaleopt有

'biased' - scales the raw cross-correlation by 1/m.

'unbiased' - scales the raw correlation by 1/(m-abs(lags)).

'coeff' - normalizes the sequence so that the auto-correlations

at zero lag are identically 1.0.

'none' - no scaling (this is the default).

注意觀察下面的測試:

s = [1 2 3]

r = xcorr(s);

r =3.0000 8.0000 14.0000 8.0000 3.0000

當用r=xcorr(s,'unbiased')時就能得到

r =3.0000 4.0000 4.6667 4.0000 3.0000

4樓:鄒汀蘭猶辰

-noscaling

(this

isthe

default).0000

當用r=xcorr(s;coeff'unbiased')時就能得到r=3.0,';

但是,有

scaleopt引數

r=xcorr(s;

[a,help

xcorr

解釋其意思是:

dt=,b]=xcorr(x;m.000014;plot(b*dt,其中*表示卷積.設原函式是f(t).

'unbiased'.0000

3,matlab中檢視幫助時;unbiased':dt;

x=cos(t).1自相關函式是描述隨機訊號x(t)在任意兩個不同時刻t1.0000

3,在呼叫xcorr函式求自相關時,':100];none'.

注意觀察下面的測試;

t=[0,scaleopt)

scaleopt有

'.6667

4.00004;-

scales

theraw

correlation

by1/biased'.'-

normalizes

thesequence

sothat

theauto-correlations

atzero

lagare

identically

1.0000

4:c(m)

=e[a(n+m)*conj(b(n))]=e[a(n)*conj(b(n-m))];),a)上面**是求自相關函式並作圖.0000

8,t2的取值之間的相關程度.

給個例子;r=

3;-scales

theraw

cross-correlation

by1/.

'(m-abs(lags)):s=

[123]r

=xcorr(s).0000

8,則自相關函式定義為r(u)=f(t)*f(-t)

如何用matlab 實現自相關和互相關?

5樓:茂爾答題

一、如何實現:

求自相關函式:

1、dt=.1;

2、t=[0:dt:100];

3、x=cos(t);

4、[a,b]=xcorr(x,'unbiased');

5、plot(b*dt,a)

互相關函式:

1、dt=.1;

2、t=[0:dt:100];

3、x=cos(t);

4、[a,b]=xcorr(x,y,'unbiased');

相關係數只是一

版個比率,不是權

等單位量度,無什麼單位名稱,也不是相關的百分數,一般取小數點後兩位來表示。

相關係數的正負號只表示相關的方向,絕對值表示相關的程度。因為不是等單位的度量,因而不能說相關係數0.7是0.

35兩倍,只能說相關係數為0.7的二列變數相關程度比相關係數為0.35的二列變數相關程度更為密切和更高。

也不能說相關係數從0.70到0.80與相關係數從0.

30到0.40增加的程度一樣大。

關於自相關和偏自相關截尾的判定,關於自相關和偏自相關截尾的判定

沒有源資料的相關情況如何比較?單從這個圖上看,我只能得出acf一階截尾,q 1。對於arma p,q 模型,可以利用其樣本的自相關函式 和樣本偏自相關函式 的截尾性判定模型的階數。具體方法如下 i 對於每一個q,計算 m取 eviews關於時間序列模型,arma中,自相關和偏自相關的圖,應該如何判斷...

請問各路大神,如何用matlab實現libsvm資料格式與矩陣的轉換

data textread 檔名 f f f f f 試試看看.svmtransform.m function b svmtransform a m,n size a b for i 1 m temp1 a i,temp2 for j 1 length temp1 temp2 temp2 num2s...

如何用spss做自相關性分析,用spss做兩個變數相關性分析時,存在強自相關怎麼辦

執行工具欄 分析a 相關 c 雙變數 b 程式,開啟 雙變數相關 對話視窗 如果您是希望進行偏相關分析,請用滑鼠選擇偏相關 r 最常用到的是雙變數相關分析和偏相關分析,偏相關分析控制了其他變數對該變數的影響,只研究某一變數對這一變數的影響。選擇你所要研究的變數,以及分析方法,spss提供了三種相關係...