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将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.