算法原理(2):样本熵(SampEn)- t# N% l& j* w) @4 e/ q
本文主要介绍样本熵的物理意义、算法以及Matlab里代码实现。/ d ?5 D9 ?) n( N8 f
4 ~, W J8 g- b* M* B+ h1.物理意义6 ]# `, j5 o" [% @2 e) F
样本熵(Sample Entropy,SampEn)与近似熵的物理意义相似(近似熵参见博客【近似熵理论相关知识与代码实现】),都是通过度量信号中产生新模式的概率大小来衡量时间序列复杂性,新模式产生的概率越大,序列的复杂性就越大。 . M; S! X5 X' F! {; ^
与近似熵相比,样本熵具有两个优势:样本熵的计算不依赖数据长度;样本熵具有更好的一致性,即参数m和r的变化对样本熵的影响程度是相同的。 4 P7 h& g& f0 V# w
样本熵的值越低,序列自我相似性就越高;样本熵的值越大,样本序列就越复杂。目前样本熵在评估生理时间序列(EEG,sEMG等)的复杂性和诊断病理状态等方面均有应用。
5 [# G* }5 J y3 L k
, l7 K; D, u- n( [" W, m2.计算方法. ^ ]. v3 g- r2 b1 u' N% u( `0 T
样本熵的计算方法如下:
) X. H+ K* z" y/ ~+ R; J9 N7 U![]()
4 g! w. v L2 d8 \! s5 B. E! k; L$ i
3.代码实现 在Matlab里实现样本熵函数,计算一段时间序列的样本熵值,代码如下:
) N# H/ D$ d5 n" c
# [6 f e* C9 ~* N
5 k: g( g( g/ ` o
|