信号特征之相空间重构(Python、C++、MATLAB实现)
后台-插件-广告管理-内容页头部广告(手机) |
相空间重构
1 特征描述
相空间重构的基本思想为:系统中任意变量的变化过程由与之相互作用的分量共同决定,其发展过程也隐含着其他变量的变化规律,故可从变量的变化过程中构建和恢复整个系统的变化规律。针对序列 x 1 , x 2 , ⋯ , x N x_1,x_2,\cdots,x_N x1,x2,⋯,xN,通过坐标延迟重构法,可以将序列映射到一个 d d d维的相空间中,重构后的轨迹矩阵如下。
X = [ x 1 x 1 + τ ⋯ x 1 + ( d − 1 ) τ x 2 x 2 + τ ⋯ x 2 + ( d − 1 ) τ ⋮ ⋮ ⋮ x P x P + τ ⋯ x P + ( d − 1 ) τ ] X= \begin{bmatrix} x_1 & x_{1+\tau} & \cdots & x_{1+(d-1)\tau} \\ x_2 & x_{2+\tau} & \cdots & x_{2+(d-1)\tau} \\ \vdots & \vdots & & \vdots \\ x_P & x_{P+\tau} & \cdots & x_{P+(d-1)\tau} \end{bmatrix} X= x1x2⋮xPx1+τx2+τ⋮xP+τ⋯⋯⋯x1+(d−1)τx2+(d−1)τ⋮xP+(d−1)τ
上式中, τ \tau τ为时间延迟参数; d d d为嵌入维数,每一行可视为相空间中的一个相点的坐标;重构的相空间轨迹由 P P P个相点组成。 P P P的大小取决于 d d d和 τ \tau τ, P = N − ( d − 1 ) τ P=N-(d-1)\tau P=N−(d−1)τ。
相空间重构的核心问题在于如何选择合适的时间延迟参数 τ \tau τ和嵌入维数 d d d。 τ \tau τ太小会使相点分布过于密集,太大则过于分散; d d d过大会增大计算量,过小则难以显示隐藏特征。
一般嵌入维数 d d d可根据具体课题选定,例如使用二维轨迹图来提取特征进行研究,则直接选择 d d d为 2 2 2。而时间延迟参数 τ \tau τ可以使用自相关函数进行计算,当自相关函数值达到第一次极小值或近似为零时,此时的 τ \tau τ比较合适。若有多个信号序列,为简化计算,可取所有序列的合适 τ \tau τ值的平均值作为设定的时间延迟参数 τ \tau τ。定义自相关函数如下。
C ( τ ) = ∑ i = 1 n − τ ( x i − x ‾ ) ( x i + τ − x ‾ ) ∑ i = 1 n − τ ( x i − x ‾ ) 2 C(\tau)=\frac{\sum\limits_{i=1}^{n-\tau}(x_i-\overline{x})(x_{i+\tau}-\overline{x})}{\sum\limits_{i=1}^{n-\tau}(x_i-\overline{x})^2} C(τ)=i=1∑n−τ(xi−x)2i=1∑n−τ(xi−x)(xi+τ−x)
其中, x ‾ \overline{x} x为时间序列的均值。
2 数据来源
提供一串信号的数据:
这组数据存在三个频率分量,分别为100Hz,200Hz和300Hz, 用MATLAB生成。
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
3 函数的Python代码
3.1 Python库要求
import numpy as np- 1
3.2 PhaseSpaceReconstruction(inputS, dd, tt)相空间重构函数
其中,inputS为输入的信号序列,dd为嵌入维度,tt为延迟参数。当tt为-1时,相空间重构函数会按照自相关函数计算合适的延迟参数,若tt为任意正整数,则相空间重构函数会根据用户输入的延迟参数进行相空间重构。函数的返回值matrixX为numpy类型的轨迹矩阵,每一行是一个相空间中的相点。
def PhaseSpaceReconstruction(inputS, dd, tt): data = [] for i in inputS: data.append(float(i)) length = len(data) xave = np.mean(data) Cup, Cdown, Clast = 0x3f3f3f3f, 1, 0 besttau = 0 # 计算合适的tau if tt == -1: for tau in range(1, length): Clast = (Cup / Cdown) Cup, Cdown = 0, 0 for i in range(0, length - tau): Cup = Cup + (data[i] - xave) * (data[i + tau] - xave) Cdown = Cdown + (data[i] - xave) * (data[i] - xave) if (Cup / Cdown) > Clast: besttau = tau - 1 break else: besttau = tt P = length - besttau * (dd - 1) maxdata, mindata = max(data), min(data) # 归一化 for i in range(0, length): data[i] = (data[i] - mindata) / (maxdata - mindata) matrixX = np.zeros((P, dd)) for i in range(0, P): for j in range(0, dd): matrixX[i, j] = data[i + besttau * j] return matrixX- 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
3.3 相空间重构函数PhaseSpaceReconstruction(inputS, dd, tt)验证
dd = 2 inputS = input().split() matrixX = PhaseSpaceReconstruction(inputS, dd, 10) for i in range(0, matrixX.shape[1]): for j in matrixX[:,i]: print("{} ".format(j), end='') print() print()- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
4 函数的C++代码
4.1 C++库要求
#include- 1
- 2
- 3
- 4
4.2 void PhaseSpaceReconstruction(vector sequenceX, vector> &matrixX, int d, int tau)相空间重构函数
其中,sequenceX为输入的信号序列,d为嵌入维度,tau为延迟参数。当tau为-1时,相空间重构函数会按照自相关函数计算合适的延迟参数,若tau为任意正整数,则相空间重构函数会根据用户输入的延迟参数进行相空间重构。matrixX为vector
- 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
4.3 相空间重构函数void PhaseSpaceReconstruction(vector sequenceX, vector> &matrixX, int d, int tau)验证
int main() {
vector- 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
5 函数的MATLAB代码
5.1 PhaseSpaceReconstruction相空间重构函数
其中,result为输入的信号序列,d为嵌入维度,tau为延迟参数。当tau为-1时,相空间重构函数会按照自相关函数计算合适的延迟参数,若tau为任意正整数,则相空间重构函数会根据用户输入的延迟参数进行相空间重构。函数的返回值matrixX为相空间重构的轨迹矩阵,每一行是一个相空间中的相点。
function matrixX = PhaseSpaceReconstruction(result, d, tau) % 相空间重构 % % matrixX为输出相点矩阵 % result为信号序列 % d为嵌入维数 % tau为时间延迟参数 % tau为-1时由程序计算合适的tau Cup = 1061109567; Cdown = 1; Clast = 0; len = length(result); xave = mean(result); if tau == -1 for tau = 1 : (len - 1) Clast = Cup / Cdown; Cup = 0; Cdown = 0; for i = 1 : (len - tau) Cup = Cup + (result(i) - xave) * (result(i + tau) - xave); Cdown = Cdown + (result(i) - xave) * (result(i) - xave); end if (Cup / Cdown) > Clast tau = tau - 1; break end end end maxR = max(result); minR = min(result); resultONE = (result - minR) / (maxR - minR); P = len - tau * (d - 1); matrixX = zeros(P, d); for i = 1 : P for j = 1 : d matrixX(i, j) = resultONE(i + tau * (j - 1)); end end end- 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
5.2 相空间重构函数PhaseSpaceReconstruction验证
result = \\* 输入样本数据 *\\; matrixX = PhaseSpaceReconstruction(result, 2, 10); plot(matrixX(:, 1), matrixX(:, 2))- 1
- 2
- 3
6 结果
6.1 Python绘制的相空间重构图像
6.2 C++绘制的相空间重构图像
6.3 MATLAB绘制的相空间重构图像
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。
在线投稿:投稿 站长QQ:1888636
后台-插件-广告管理-内容页尾部广告(手机) |