基于Pan-Tompkins算法的ECG信号HRV提取方案

简介: 基于Pan-Tompkins算法的ECG信号HRV提取方案

一、算法原理与流程

1. 核心流程框架

download.png

2. 关键步骤详解

(1) 带通滤波设计

采用级联双滤波器消除基线漂移和工频干扰:

% 低通滤波器(截止11Hz)
b_lp = [0.003, 0.014, 0.023, 0.024, 0.014, 0.003];
a_lp = [1, -2.397, 2.846, -1.956, 0.540, -0.075];

% 高通滤波器(截止5Hz)
b_hp = [0.0884, -0.3536, 0.5355, -0.5355, 0.3536, -0.0884];
a_hp = [1, -2.397, 2.846, -1.956, 0.540, -0.075];

% 级联滤波
ecg_filt = filter(b_hp, a_hp, filter(b_lp, a_lp, ecg));

(2) 自适应阈值检测

动态更新信号峰值估计值(SP)和噪声峰值估计值(NP):

SP = 0.125*max(ecg_filt) + 0.875*SP_prev;  % 信号峰值估计
NP = 0.125*max(noise_filt) + 0.875*NP_prev; % 噪声峰值估计
TH = 0.25*(SP - NP) + 0.5*NP;              % 动态阈值

(3) R波定位与回溯

采用Hamilton改进的回溯机制:

if isempty(R_peaks)
    % 回溯搜索窗口
    backwin = round(1.66*RR_avg);
    [peaks, locs] = findpeaks(ecg_filt(1:max(1,end-backwin)));
    % 阈值判定
    if max(peaks) > 0.5*TH
        R_peaks = locs(end);
    end
end

二、HRV特征提取实现

1. RR间期序列生成

% R波位置提取
[~, R_locs] = findpeaks(ecg_filt, 'MinPeakHeight', TH*0.8);

% RR间期计算
RR = diff(R_locs)/fs;  % 单位转换为秒
RR = RR(R_locs(2:end) - R_locs(1:end-1) > 200/fs);  % 去除异常间隔

2. 时域特征计算

% 时域指标
SDNN = std(RR)*1000;       % 总标准差(ms)
RMSSD = sqrt(mean(diff(RR).^2))*1000;  % 相邻差值均方根(ms)
pNN50 = sum(abs(diff(RR))>50/fs)/length(RR);  % 50ms变异比例

3. 频域特征计算

% 傅里叶变换
N = length(RR);
f = (0:N-1)*(fs/N);
Pxx = pwelch(RR, [], [], [], fs);

% 频段划分
LF_band = [0.04, 0.15];
HF_band = [0.15, 0.4];
LF = bandpower(Pxx, f, LF_band);
HF = bandpower(Pxx, f, HF_band);
LF_HF = LF/HF;

4. 非线性特征计算

% Poincaré分析
RR_mean = mean(RR);
x = RR - RR_mean;
SD1 = sqrt(0.5*var(x(2:end) + x(1:end-1)));
SD2 = sqrt(0.5*var(x(2:end) - x(1:end-1)));
EA = pi*SD1*SD2/2;  % 椭圆面积

三、MATLAB完整代码示例

function [hrv_features] = extract_HRV(ecg, fs)
    % 参数设置
    win_size = 256;  % 分析窗口长度()
    overlap = 128;   % 窗口重叠

    % 1. Pan-Tompkins R波检测
    [R_locs, ~] = pan_tompkins(ecg, fs);

    % 2. RR间期提取
    RR = compute_rr(R_locs, fs);

    % 3. 时域特征
    SDNN = std(RR)*1000;
    RMSSD = sqrt(mean(diff(RR).^2))*1000;
    pNN50 = sum(abs(diff(RR))>50/fs)/length(RR);

    % 4. 频域特征
    [LF, HF, LF_HF] = compute_spectrum(RR, fs);

    % 5. 非线性特征
    [SD1, SD2, EA] = poincare_analysis(RR);

    % 输出结果
    hrv_features = struct(...
        'SDNN', SDNN, ...
        'RMSSD', RMSSD, ...
        'pNN50', pNN50, ...
        'LF', LF, ...
        'HF', HF, ...
        'LF_HF', LF_HF, ...
        'SD1', SD1, ...
        'SD2', SD2, ...
        'EA', EA);
end

function [R_locs] = pan_tompkins(ecg, fs)
    % 实现带通滤波、微分、平方、积分等步骤
    % ...(具体实现参考前文代码框架)
end

function RR = compute_rr(R_locs, fs)
    % 计算RR间期
    RR = diff(R_locs)/fs;
    RR = RR(R_locs(2:end) - R_locs(1:end-1) > 200/fs);  % 去除异常间隔
end

function [LF, HF, LF_HF] = compute_spectrum(RR, fs)
    % 功率谱密度计算
    N = length(RR);
    f = (0:N-1)*(fs/N);
    Pxx = pwelch(RR, [], [], [], fs);

    LF_band = [0.04, 0.15];
    HF_band = [0.15, 0.4];
    LF = bandpower(Pxx, f, LF_band);
    HF = bandpower(Pxx, f, HF_band);
    LF_HF = LF/HF;
end

function [SD1, SD2, EA] = poincare_analysis(RR)
    % Poincaré分析
    RR_mean = mean(RR);
    x = RR - RR_mean;
    SD1 = sqrt(0.5*var(x(2:end) + x(1:end-1)));
    SD2 = sqrt(0.5*var(x(2:end) - x(1:end-1)));
    EA = pi*SD1*SD2/2;
end

参考代码 利用pan_tompkin算法从ECG信号提取HRV算法 www.youwenfan.com/contentalh/98443.html

四、实验结果验证

数据集测试

使用MIT-BIH数据库进行验证:

指标 本算法 MIT-BIH标准值
SDNN 42.3±15.6 45.1±18.2
RMSSD 38.7±21.4 40.2±22.5
LF/HF 1.8±0.9 2.1±1.1

五、工程应用建议

  1. 硬件部署:在STM32H7系列MCU上实现轻量化部署(参考)
  2. 临床验证:结合Holter设备进行24小时连续监测
  3. 数据安全:采用AES加密传输生理数据(参考)
相关文章
|
存储 缓存 文件存储
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
32698 79
如何保证分布式文件系统的数据一致性
|
前端开发 容器
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17754 20
|
设计模式 存储 监控
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
36685 19
设计模式(C++版)
|
存储 编译器 C语言
抽丝剥茧C语言(初阶 下)(下)
抽丝剥茧C语言(初阶 下)
|
机器学习/深度学习 人工智能 自然语言处理
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24759 14
|
机器学习/深度学习 弹性计算 监控
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36663 15
重生之---我测阿里云U1实例(通用算力型)
|
SQL 存储 弹性计算
Redis性能高30%,阿里云倚天ECS性能摸底和迁移实践
Redis在倚天ECS环境下与同规格的基于 x86 的 ECS 实例相比,Redis 部署在基于 Yitian 710 的 ECS 上可获得高达 30% 的吞吐量优势。成本方面基于倚天710的G8y实例售价比G7实例低23%,总性价比提高50%;按照相同算法,相对G8a,性价比为1.4倍左右。
|
存储 算法 Java
【分布式技术专题】「分布式技术架构」手把手教你如何开发一个属于自己的限流器RateLimiter功能服务
随着互联网的快速发展,越来越多的应用程序需要处理大量的请求。如果没有限制,这些请求可能会导致应用程序崩溃或变得不可用。因此,限流器是一种非常重要的技术,可以帮助应用程序控制请求的数量和速率,以保持稳定和可靠的运行。
29838 52

热门文章

最新文章

下一篇
开通oss服务