4

我有两个信号,我们称它们为“a”和“b”。但是,它们都是几乎相同的信号(从相同的输入记录并包含相同的信息),因为我在两个不同的“b”处记录了它们,它们的时间偏移量未知。显然,每个都有随机噪声。

目前,我正在使用互相关来计算时间偏移,但是,我仍然得到不正确的结果。

这是我用来计算时移的代码:

function [ diff ] = FindDiff( signal1, signal2 )
%FINDDIFF Finds the difference between two signals of equal frequency 
%after an appropritate time shift is applied
%   Calculates the time shift between two signals of equal frequency 
%   using cross correlation, shifts the second signal and subtracts the
%   shifted signal from the first signal. This difference is returned.
length = size(signal1);

if (length ~= size(signal2))
    error('Vectors must be equal size');
end

t = 1:length;
tx = (-length+1):length;
x = xcorr(signal1,signal2);
[mx,ix] = max(x);
lag = abs(tx(ix));
shifted_signal2 = timeshift(signal2,lag);
diff = signal1 - shifted_signal2;

end

function [ shifted ] = timeshift( input_signal, shift_amount )
input_size = size(input_signal);
shifted = (1:input_size)';
for i = 1:input_size
    if i <= shift_amount
        shifted(i) = 0;
    else
        shifted(i) = input_signal(i-shift_amount);
    end
end

end

plot(FindDiff(a,b));

然而,函数的结果是周期波,而不是随机噪声,因此滞后必须仍然关闭。我会发布该情节的图片,但 imgur 目前不合作。

除了互相关之外,有没有更准确的方法来计算滞后,或者有没有办法改善互相关的结果?

4

4 回答 4

7

互相关通常是确定两个信号之间时间延迟的最简单方法。峰值位置表示两个信号最相似的时间偏移量。

%// Normalize signals to zero mean and unit variance
s1 = (signal1 - mean(signal1)) / std(signal1);
s2 = (signal2 - mean(signal2)) / std(signal2);

%// Compute time lag between signals
c = xcorr(s1, s2);                       %// Cross correlation
lag = mod(find(c == max(c)), length(s2)) %// Find the position of the peak

请注意,必须首先将两个信号归一化到相同的能级,这样结果才不会有偏差。

顺便说一句,不要diff用作变量的名称。MATLAB 中已经有一个同名的内置函数

于 2013-03-12T22:52:28.460 回答
3

现在Matlab中有两个函数:

一个叫finddelay

我相信另一个叫做alignsignals可以做你想做的事。

于 2015-11-30T04:45:12.587 回答
1

corr 在向量之间找到一个点积(v1, v2)。如果它对您的信号效果不佳,我会尝试最小化差异平方和(即abs(v1 - v2))。

 signal = sin(1:100);
 signal1 = [zeros(1, 10) signal];
 signal2 = [signal zeros(1, 10)];

 for i = 1:length(signal1)
     signal1shifted = [signal1 zeros(1, i)];
     signal2shifted = [zeros(1, i) signal2];
     d2(i) = sum((signal1shifted - signal2shifted).^2);
 end

 [fval lag2] = min(d2);

 lag2

它在计算上比使用 FFT 可以加速的交叉计算更差。据我所知,你不能用欧几里德距离做到这一点。

UPD。删除了关于与周期信号互相关的错误想法

于 2013-03-12T22:05:57.913 回答
0

您可以尝试在频域进行匹配过滤

function [corr_output] = pc_corr_processor (target_signal, ref_signal)
L = length(ref_signal);
N = length(target_signal);

matched_filter = flipud(ref_signal')';
matched_filter_Res = fft(matched_filter,N);
corr_fft = matched_filter_Res.*fft(target_signal);
corr_out = abs(ifft(corr_fft));

上面 corr_out 的匹配滤波器最大索引的峰值应该为您提供滞后量。

于 2013-03-13T07:16:22.270 回答