-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathrdist.m
60 lines (56 loc) · 1.91 KB
/
rdist.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
function [r,lags]=rdist(a,b,lags)
% [r,lags]=RDIST(a,b,lags)
%
% Lagged relative root-mean-squared difference between two vectors,
% e.g. time series, i.e. the "difference" version of the
% "multiplicative" signal similarity measure XCORR, i.e. the rms of
% the difference between two vectors normalized by the rms of the
% first one, in the area of overlap. One could think of normalizing
% using either the first or the second signal, or in terms of the
% square root of the products of the rms of both, but only normalizing
% by the first input is supported here. Note that the signals are NOT
% demeaned, if you want that, that is your job, as it's a choice with
% consequences.
%
% INPUT:
%
% a,b Two equal-length vectors (shortest will be zero-padded)
% lags The lags at which the measure is to be computed (defaulted)
%
% OUTPUT:
%
% r The root-mean-squared difference between the timeseries
% shifted to the lags in question, normalized by the
% root-mean-squared value of the FIRST input time series in
% the area of overlap
% lags The lags at which the measure was computed [defaulted]
%
% SEE ALSO: XCORR and OST, and XDIST
%
% Last modified by fjsimons-at-alum.mit.edu, 03/16/2023
% Only vectors, same length or zero-pad
a=a(:);
b=b(:);
if length(a)<length(b)
a=[a ; zeros(length(b)-length(a),1)];
else
b=[b ; zeros(length(a)-length(b),1)];
end
% Now they are the same
M=length(a);
% Defaults like in XCORR
maxlag=M-1;
defval('lags',-maxlag:maxlag);
% Initialize output
r=nan(length(lags),1);
% Do the computation, "for" loop might be slower but vectorization costs memory
i=0;
for l=lags
i=i+1;
% The index into b of the interval of overlap
blap=1-l*[l<0]:M-l*[l>0];
% The index into a of the interval of overlap
alap=1+l*[l>0]:M+l*[l<0];
% The a-normalized rmse where e=a-b;
r(i)=sqrt(sum([b(blap)-a(alap)].^2)/sum(a(alap).^2));
end