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

matlab中的xcorr 自相关函数

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-9-9 15:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x
    xcorr(A)=3.0000 8.0000 14.0000 8.0000 3.0000
     比如,上面的矩阵,最后得到5个结果,其中第三个是自己和自己相乘,最后相加的结果,值最大1*1+2*2+3*3=14。而第二个和第四个分别是间隔正负1的结果也就是1*2+2*3=8,2*1+3*2=8。第1个和第五个分别是间隔正负2,也就是1*3=3,3*1=3。
1. 首先说说自相关和互相关的概念。- p( a. b1 k! l5 s2 {7 x& l
这个是信号分析里的概念,他们分别表示的是两个时间序列之间和同一个时间序列在任意两个不同时刻的取值之间的相关程度,即互相关函数是描述随机信号 x(t),y(t)在任意两个不同时刻t1,t2的取值之间的相关程度,自相关函数是描述随机信号x(t)在任意两个不同时刻t1,t2的取值之间的相关程度。
. g* p$ \/ s, L1 M9 Q- x自相关函数是描述随机信号X(t)在任意两个不同时刻t1,t2的取值之间的相关程度;互相关函数给出了在频域内两个信号是否相关的一个判断指标,把两测点之间信号的互谱与各自的自谱联系了起来。它能用来确定输出信号有多大程度来自输入信号,对修正测量中接入噪声源而产生的误差非常有效.* ]: c) E0 I; v
事实上,在图象处理中,自相关和互相关函数的定义如下:设原函数是f(t),则自相关函数定义为R(u)=f(t)*f(-t),其中*表示卷积;设两个函数分别是f(t)和g(t),则互相关函数定义为R(u)=f(t)*g(-t),它反映的是两个函数在不同的相对位置上互相匹配的程度。. n6 i3 ]2 r) e
那么,如何在matlab中实现这两个相关并用图像显示出来呢?! l/ i5 D3 w5 v' r- \
dt=.1;3 g7 y$ b! Q. @/ Q
t=[0:dt:100];
5 a" B$ [. ^- C& r0 r9 }: N5 n9 ]. D2 {x=cos(t);
' C% C) o6 X+ ?7 h2 o8 v7 Z[a,b]=xcorr(x,'unbiased');' g2 q$ Z( i" p- _
plot(b*dt,a)
5 j' h" y( g+ B# H$ g' c; S, Z上面代码是求自相关函数并作图,对于互相关函数,稍微修改一下就可以了,即把
, w, }" R8 L( x- j# q" ^[a,b]=xcorr(x,'unbiased');改为[a,b]=xcorr(x,y,'unbiased');便可。
: v0 ^/ O4 ~0 x2 e) A! N2. 实现过程:& Z+ w( [, r, T% X, s7 Q
      在Matalb中,求解xcorr的过程事实上是利用Fourier变换中的卷积定理进行的,即R(u)=ifft(fft(f)×fft(g)),其中×表示乘法,注:此公式仅表示形式计算,并非实际计算所用的公式。当然也可以直接采用卷积进行计算,但是结果会与xcorr的不同。事实上,两者既然有定理保证,那么结果一定是相同的,只是没有用对公式而已。下面是检验两者结果相同的代码:( d5 \. N: V5 p* h
dt=.1;
2 t) T+ @7 M2 L/ a! ct=[0:dt:100];' P; ~. ^0 J9 Z8 S& y- E( h5 h
x=3*sin(t);/ o/ ]! a, c' D) u
y=cos(3*t);
, R  |! `( J+ C5 o$ c3 ]4 F6 Q& gsubplot(3,1,1);
& X# P3 Q6 ~- U, r6 `plot(t,x);
- B& A3 q1 i6 Q- ^subplot(3,1,2);, t* p& G' l% A; A5 E, l
plot(t,y);
( I& u4 m0 v% B- m* ]! r# y# {[a,b]=xcorr(x,y);& e2 I& k- y, l; f  ]
subplot(3,1,3);9 i% x+ V* S& V5 f' y7 r# r, l
plot(b*dt,a);  M4 ?$ B" }6 U1 C- B
yy=cos(3*fliplr(t)); % or use: yy=fliplr(y);
- h  T( Z! J- s* ^3 @z=conv(x,yy);& ?& A3 k$ ~- J$ w* l7 K+ h, M
pause;
+ A* r4 l- _# d0 O0 @7 L, ssubplot(3,1,3);
+ J6 u  x1 N# }2 Gplot(b*dt,z,'r');( l% z# @, [3 t, [) s
即在xcorr中不使用scaling。; M$ |' W! X( ?* Q9 |% Q9 F
3. 其他相关问题:- D. s6 O* K& [4 j9 }* N
1) 相关程度与相关函数的取值有什么联系?3 ?( ?1 {4 S' k) B* g& r& t- h/ g
  相关系数只是一个比率,不是等单位量度,无什么单位名称,也不是相关的百分数,一般取小数点后两位来表示。相关系数的正负号只表示相关的方向,绝对值表示相关的程度。因为不是等单位的度量,因而不能说相关系数0.7是0.35两倍,只能说相关系数为0.7的二列变量相关程度比相关系数为0.35的二列变量相关程度更为密切和更高。也不能说相关系数从0.70到0.80与相关系数从0.30到0.40增加的程度一样大。& r! F: A5 s/ D9 M
对于相关系数的大小所表示的意义目前在统计学界尚不一致,但通常按下是这样认为的:
! _- ]1 `1 ^- _5 P, G- \相关系数          相关程度
, p, c; J: f/ c5 \) E) N0.00-±0.30       微相关
3 x$ i' _: E9 Q' p5 O8 {) [. E±0.30-±0.50   实相关# N* b! s0 \! d+ j* X
±0.50-±0.80  显著相关
6 g4 S' s) |5 A/ k2 V; n9 O±0.80-±1.00  高度相关, Q9 B( w  |/ P( U7 e3 I: d8 x4 k; R
matlab计算自相关函数autocorr和xcorr有什么不一样的?xcorr是没有将均值减掉做的相关,autocorr则是减掉了均值。

" w* P# g- |. V- c/ b

该用户从未签到

2#
发表于 2020-9-9 15:42 | 只看该作者
matlab中的xcorr 自相关函数
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-24 13:22 , Processed in 0.140625 second(s), 23 queries , Gzip On.

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

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

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