Python生理信号分析库neurokit2

2024-03-03 15:59

本文主要是介绍Python生理信号分析库neurokit2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

NeuroKit2是一个开源的、社区驱动的、以用户为中心的Python库,可用于多种生理信号的分析处理(例如ECG、PPG、EDA、EMG、RSP),还包括用于特定处理步骤(如频率)的工具提取和过滤方法,并在易用性和参数微调之间进行权衡。其目标是提高神经生理学研究的透明度和再现性,并促进探索和创新,它的设计理念以用户体验和对新手和高级用户的可用性为中心。


1 安装

从PyPI安装NeuroKit2代码如下:

pip install neurokit2

或conda-forge

conda install -c conda-forge neurokit2

2 读入数据

import neurokit2 as nk
# 下载样例
data = nk.data("bio_eventrelated_100hz")
# 数据预处理 (滤波, 查找峰值,等.)
processed_data, info = nk.bio_process(ecg=data["ECG"], rsp=data["RSP"], eda=data["EDA"],sampling_rate=100)
# 计算相关特征
results = nk.bio_analyze(processed_data, sampling_rate=100)

3 设计原理

NeuroKit2的目标是让初学者能够快速访问的同时,也为有经验的用户提供最大水平的自主设计控制。这是通过允许初始用户使用一些函数实现复杂的处理管道来实现的,同时仍然为有经验的用户提供对参数的微调控制。具体来说,这种权衡是由一个由三层组织的API结构来实现的。

3.1 基础层:基础信号预处理的函数

基础信号处理的函数包括滤波、重采样、插值、峰值检测等。这些函数是与具体的生理信号数据类型无关,并且包括可调参数(例如,可以通过设置参数来改变滤波方法)。这些函数大多是基于scipy实现的算法(Virtanen等人,2020),包括signal_filter(), signal_interpolate(), signal_resample(), signal_detrend()和 signal_findpeaks().

3.2 中间层:生理信号的预处理

中间层的函数基于基础信号处理函数对不同生理模态的生理信号进行分析(如ECG、RSP、EDA、EMG、PPG)。这些函数执行特定模态的生理信号的处理步骤,如清洗、峰值检测、分类或频率计算。重要的是,对于每种类型的信号,同一处理目的都使用统一的函数名(以生理信号类型_函数名()的形式),使不同模态生理信号处理分析的实现更加直观和一致。例如, * clean(), * findpeaks(),  process(), * plot()。

例如,rsp_clean()函数使用signal_filter()和signal_detrend(),它们具有不同的默认参数,可以通过一个“method”参数进行切换。例如,设置method=“khodadad2018”将使用khododadad等人(2018)中使用的数据清理流程。但是,如果用户想要构建自己的自定义清理管道,他们可以使用清理函数作为模板,并在基础信号处理操作中根据自己的需求调整参数。

3.3 高级层:用于处理和分析的顶层函数

中间层的函数被组装在顶层的函数中,这是为新手用户提供快速使用的函数。例如,ecg process()函数内部组装了中层函数,Ecg_clean(), ecg_peaks(), ecg_quality(), ecg_delineate(),和ecg_phase(),如图1所示。可以使用method参数选择不同的处理管道/方法。在处理管道之间的轻松切换允许对不同方法进行比较,并简化了可重复研究中的一些关键步骤,如数据准备和质量控制的验证(Quintanaetal.,2016)。最后,该包提供一个简便的函数(例如bio_process),能够同时组合处理多种类型的信号(例如bio_process(ecg=心电数据,eda=皮电数据))。

NeuroKit2软件包架构的说明(以心电信号处理为例)

4 数据分析

在本节中,我们将展示两类范式的数据分析示例来说明最常见的用例。第一个例子是一个与时间间隔相关的范式,其中在一定时间间隔内的生理活动特征(不一定与一个特定的和突发的事件有关)被提取出来。第二个例子展示了一个与事件相关的范式,其中人们的兴趣在于与特定事件相关的短期生理变化。

4.1 时间间隔相关的范式(Interval-related paradigm

使用的数据集是参与者在休息(闭着眼睛坐着)5分钟的生理活动,三个通道(ECG、PPG和RSP)的采样频率为100Hz。

import neurokit2 as nk
# 数据加载
data = nk.data("bio_resting_5min_100hz")
# 数据处理
df,info = nk.bio_process(ecg=data["ECG"],rsp=data["RSP"], sampling_rate=100)
# 特征提取
results = nk.bio_analyze(df,sampling_rate=100)
# 结果显示
results[["ECG_Rate_Mean","HRV_RMSSD","RSP_Rate_Mean","RSA_P2T_Mean"]]

分析结果: 

 

4.2 事件相关的范式(Event-related Paradigm

这个示例数据集包含了一个参与者的ECG、RSP和EDA信号,他得到了四种情绪图像(来自NAPS数据库;Marchewka等人,2014),这些信号时长为2.5分钟(150秒),记录的频率为100Hz,有4个通道,包括3个生理信号信号和1个对应于标记事件(photosensor)通道(当刺激出现在屏幕上时,信号强度下降)。

import neurokit2 as nk
# 数据加载
data = nk.data("bio_eventrelated_100hz")
# 数据预处理
df,info= nk.bio_process(ecg=data["ECG"],rsp=data["RSP"], eda=data["EDA"], sampling_rate=100)# 查找事件
conditions =["Negative","Neutral","Neutral","Negative"]
events = nk.events_find(event_channel=data["Photosensor"],threshold_keep='below',event_conditions=conditions)
# 数据分段
epochs = nk.epochs_create(data=df,events=events,sampling_rate=100, epochs_start=-0.1, epochs_end=4)
# 抽取事件相关的特征
results = nk.bio_analyze(epochs,sampling_rate=100)
# 结果显示
results[["Condition","ECG_Rate_Mean","RSP_Rate_Mean","EDA_Peak_Amplitude"]]

分析结果:

5 总结  

NeuroKit2为神经生理数据处理提供免费的、以用户为中心的、全面的解决方案,主要关注的生理信号包括ECG(测量心脏活动)、PPG(血流的光学测量)、RSP(呼吸)、EDA(皮肤电活动测量)、EMG(测量肌肉活动)和EOG(测量眼球运动)。参考文档链接:     

         GitHub源代码:https://github.com/neuropsychology/NeuroKit

         API文档:https://neurokit2.readthedocs.io/

注:数据加载过程出现urllib.error.URLError参考

 urlopen error [WinError 10054] 远程主机强迫关闭了一个现有的连接 | 码农家园 (codenong.com)

这篇关于Python生理信号分析库neurokit2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/770134

相关文章

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Python与DeepSeek的深度融合实战

《Python与DeepSeek的深度融合实战》Python作为最受欢迎的编程语言之一,以其简洁易读的语法、丰富的库和广泛的应用场景,成为了无数开发者的首选,而DeepSeek,作为人工智能领域的新星... 目录一、python与DeepSeek的结合优势二、模型训练1. 数据准备2. 模型架构与参数设置3

Python进行PDF文件拆分的示例详解

《Python进行PDF文件拆分的示例详解》在日常生活中,我们常常会遇到大型的PDF文件,难以发送,将PDF拆分成多个小文件是一个实用的解决方案,下面我们就来看看如何使用Python实现PDF文件拆分... 目录使用工具将PDF按页数拆分将PDF的每一页拆分为单独的文件将PDF按指定页数拆分根据页码范围拆分

Python中常用的四种取整方式分享

《Python中常用的四种取整方式分享》在数据处理和数值计算中,取整操作是非常常见的需求,Python提供了多种取整方式,本文为大家整理了四种常用的方法,希望对大家有所帮助... 目录引言向零取整(Truncate)向下取整(Floor)向上取整(Ceil)四舍五入(Round)四种取整方式的对比综合示例应

python 3.8 的anaconda下载方法

《python3.8的anaconda下载方法》本文详细介绍了如何下载和安装带有Python3.8的Anaconda发行版,包括Anaconda简介、下载步骤、安装指南以及验证安装结果,此外,还介... 目录python3.8 版本的 Anaconda 下载与安装指南一、Anaconda 简介二、下载 An

Python自动化处理手机验证码

《Python自动化处理手机验证码》手机验证码是一种常见的身份验证手段,广泛应用于用户注册、登录、交易确认等场景,下面我们来看看如何使用Python自动化处理手机验证码吧... 目录一、获取手机验证码1.1 通过短信接收验证码1.2 使用第三方短信接收服务1.3 使用ADB读取手机短信1.4 通过API获取

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.