我有几个时间序列,即我在15分钟内测量了几个信号。每秒对每个信号进行几次采样,但不同信号的时间戳不相等。假设我们从时间0开始。例如,信号1具有以下(时间戳,值):
0.1s: 954
0.2s: 1000
0.24s: 1090
0.3s: 855
0.45s: 600
...
信号二具有以下(时间戳,值):
0.05s: 900
0.13s: 960
0.2s: 1000
0.29s: 850
0.33s 800
...
我现在如何计算这些时间序列的值的相关性,例如: python还是Matlab?如果值总是在相同的时间戳,我可以只计算各个值之间的相关性,但遗憾的是这些值不在同一个时间戳上。
答案 0 :(得分:3)
假设您在时间点s1
处有一个数组t1
中包含值的信号,并且信号s2
在时间点t2
处进行评估。使用Python中的NumPy:
t
选择一组通用时间点。您可以选择t1
或t2
,或使用np.linspace
计算考虑的时间范围内的线性空间。在任何情况下,我都要确保t
的最小值和最大值都在t1
和t2
的范围内,以避免外推。s1interp
和s2interp
的插值。这可以使用np.interp
来完成,它计算线性插值。如果您需要更复杂的插值方法,可以查看SciPy interp1d
。s1interp
和s2interp
之间的相关性。这是通过np.corrcoef
完成的。答案 1 :(得分:2)
您可以在其中一个数据集上进行一些简单的插值(参见interp1
for MATLAB),以便它们共享采样率,如果这是您唯一的问题......
X =[0.1 954
0.2 1000
0.24 1090
0.3 855
0.45 600];
Y =[0.05 900
0.13 960
0.2 1000
0.29 850
0.33 800];
t = Y(:,1); % get time samples from Y
% Interpolate (linearly, with extrapolation) X2 values onto time samples t
X2 = [t, interp1(X(:,1), X(:,2), t, 'linear', 'extrap')];
>> X2 = [0.05 931
0.13 967.8
0.2 1000
0.29 894.1667
0.33 804];
现在他们有相同的样本点,你可以做你喜欢的事。