手把手教你EEG脑电数据预处理-操作篇

更多技术干货第一时间送达

感谢简书ID:亚内士多德

授权分享

EEG脑电数据预处理-操作篇

关于EEG数据预处理的原理,前面已经介绍过了,大家可以查看《手把手教你EEG脑电数据预处理-原理篇》。下面是亚内士多德分享的操作篇。

基本步骤

  • 定位通道位置

  • 删除无用通道

  • 滤波

  • 分段

  • 基线校正

  • 重参考

  • 降低采样率

  • 插值坏导

  • 独立主成分分析

  • 剔除坏段

导入数据

选择要导入的数据格式

接下来会弹出一个对话框,是否要对数据进行选择性导入,一般都是全部导入,直接点OK即可。

接下来又会再弹出一个对话框,是否要对数据进行命名。基本上在EEGLAB的每一步操作之后都会弹出这样的对话框,询问你是否需要对新产生的数据进行命名,根据自己需要选择即可。

对数据进行初步认识

  • channel per frame:64   指导入的数据有64个通道

  • frames per epoch:一段数据的总长度,是439880采样点

  • epochs:指当前数据的段数,原始数据还没有进行分段,因此显示只有一段

  • events:检测到当前数据一共有202个events

  • sampling rate(HZ):数据的采样率为1000HZ

  • epoch start和epoch end: 这个的分段是从0秒开始,到439.879秒结束。还没有进行分段所以看这个数值没有意义

  • reference: 指数据的参考点,重参考后会显示重参考的电极点,或者average,目前还没有进行重参考所以是unknown

  • channel locations:是否有对通道进行定位,目前显示没有,定位后会显示为yes

  • ICA weights:是否对数据进行了ICA独立主成分分析,分析后会显示yes

  • dataset size:数据的大小

电极定位

默认文件是standard-10-5-cap385.elp,点击确定即可

channel locations

channel locations

点击OK之后可以进入下一步查看数据

channel locations info

如果检查到某个电极点的坐标信息为空白(如上图所示),可能是该通道的名称在加载的模板文件中找不到,那么

  • 如果确定该通道是根据国际排布系统来确定的,那可以修改label名称后再点击下方的look up locs来更新通道位置信息,比如上图的VEO改为VEOG,然后更新位置信息之后就可以看到了

  • 如果不是国际排布系统,可以向厂家要电极的坐标位置信息

  • 如果知道该电极点的精确坐标,可以手动输入

  • 双侧乳突的电极点位置可能会根据脑电系统的不同而不同,比如TP9 TP10,A1 A2, M1 M2这三对都是指双侧乳突

更新后的电极点坐标

移除无用电极

此处我们要移除掉两个眼电数据

select data

select data

select data

重参考

此处要将数据转换为双侧乳突平均参考,即TP9,TP10

re-reference

re-reference

重采样

不一定每个数据都需要进行重采样,可根据需要进行。

re-sampling

re-sampling

滤波

此处选择默认的滤波器进行0.1-30Hz的滤波

filter

依次在第一框中填入0.1和第二个框中填入30进行计算,两个一起填代表进行带通滤波,建议分开进行

filter

分段和基线校正

extract epochs

extract epochs

点击OK后会弹出下一个要求基线校正的对话框,默认是event前的数据作为基线来进行校正,点击OK即可。

baseline correction

插值坏导

对数据进行检查,如果发现某个通道的数据坏了,可以用插值的方式来进行校正,此处要校正的通道为FC3,选择插值的通道为它周围的四个电极点,F3,FC1,C3,FC5

  • 第一种方法是代码操作

    EEG.data(a,:,:) = mean(EEG.data([b c d],:,:)) ;

    其中a代表坏掉的电极点数值,b c d 代表要进行插值平均的电极点数值
    如果不确定通道数值是多少,可以通过Plot - channel locations - by name 来进行查看。

    画出通道图之后,可以通过单击通道名字来查看通道数值。

    channel name

    channel name

    所以这句代码为

      EEG.data(17,:,:) = mean(EEG.data([8 18 26 16],:,:)) ;

      这句代码的意思是指,第17个通道的数值,用第8,18,26,16这四个通道数值的平均值来代替。

      • 第二种方法是面板操作,用eeglab的默认算法进行

      interpolate electrodes

      interpolate electrodes

      ICA

      使用ICA算法剔除伪迹,此步操作耗时较长

      run ICA

      因为我们有一个坏通道的数据是用其他通道的数据生成的,相当于我们损失了一个有效通道数据,而ICA默认是在所有通道都是有效数据的情况下进行的,所以此处我们需要进行一些修改,在'extended', 1后面加上'pca', 59,中间用逗号和空格隔开,逗号要用英文输入法下的

      run ICA

      点击确定之后会出现一个对话框,显示正在进行ICA计算,计算结束后该对话框会消失

      run ICA

      在跑完ICA之后建议保存当前数据,在进行伪迹剔除操作。这样做可以保证在剔除不当的时候随时回到未剔除的状态下重新进行选择。

      此时会保存为eeglab的.set的格式文件

      save dataset

      在跑完ICA之后就可以用ICA进行伪迹剔除了

      reject ICA

      选择要画出的成分数,此处我们选择默认状态

      plot ICA

      eeglab提示我们一张画布只能画下35个图,剩下的会在第二张画布中画出,点击OK即可

      plot ICA

      plot ICA

      此时我们可以对所有的ICA成分进行查看和标记,点击成分数字,会出现该成分的详细情况。如果觉得该成分代表伪迹成分,想要剔除的话,可以先将它标记起来。标记的方式是单机下方绿色的ACCEPT,单击之后会变成红色的REJECT

      plot ICA

      这一步需要对每一个成分进行查看和判断,然后将想要剔除的成分先标记起来。ICA可以进行眼电伪迹,肌电伪迹,坏导伪迹以及心电伪迹等的辨识与剔除,但是此处我们只进行眼电伪迹的剔除,我们将第一个成分和第13个成分标记起来,标记了的成分数会变成红色。然后点OK。此时还没有进行剔除操作。

      mark ICA

      除了上面那种方式之外,还可以使用逐个成分画出的方式来查看和标记

      plot ICA

      plot ICA

      剔除ICA成分

      remove ICA

      eeglab默认两个框都是一样的信息,此时记得把第二个框的信息给清除掉

      remove ICA

      在接下来的对话框里,我们可以对剔除了ICA成分和未剔除的数据进行比较

      check data

      红色代表未剔除的数据,蓝色代表剔除后的数据

      所有通道的ERP图

      从红色框中的部分可以看到,我们还是很有效地剔除了眼动伪迹的

      所有通道单个trial的图

      检查确认无误后点击accept进行剔除操作

      剔除坏段

      • 绝对阈值法
        此处我们选择剔除掉超出±100μV的trial。

      reject epoch

      reject epoch

      目视检查法

      channel data

      逐个trial进行查看,如果发现有伪迹过大的trial想要剔除的话,单击该trial,它会变成黄色。选择完所有trials后,点击下方的reject即可。此处选中的两个trials仅仅作为演示用。

      reject trials

      保存数据

      至此EEG数据的预处理就基本完成了,我们可以再次将这个数据保存起来,以供下一步操作。

      更多阅读

      手把手教你EEG脑电数据预处理-原理篇

      浙大“强基计划”-脑科学与脑医学方向

      ERP大神Steven Luck的线上ERP免费训练营调查

      北大读博手记:怎样完成自己的博士生涯?非常具有指导性!

      如何识别ICA成分

      letswave7中文教程1:软件安装与脑电数据导入

      letswave7中文教程2:脑电数据预处理-通道位置分配

      letswave7中文教程3:脑电数据预处理-ICA去除伪影

      letswave7中文教程4:脑电数据预处理-时域分析

      这次我终于弄懂了院士、杰青、长江、百千万人才的区别了以及评选有多难了?评选条件了解一下

      眼动追踪与VR

      DEAP数据集--一个重要的情绪脑电研究数据集(更新)

      EEG数据、伪影的查看与清洗

      什么是EEG以及如何解释EEG?

      Python-可视化Evoked数据

      应用深度学习EEGNet来处理脑电信号

      一种基于脑电图情感识别的新型深度学习模型

      脑机音乐接口,高效检测用户的情绪状态

      将深度学习技术应用于基于情境感知的情绪识别

      EEG信号特征提取算法

      EEGNet: 神经网络应用于脑电信号

      信号处理之倒频谱原理与python实现

      信号处理之功率谱原理与python实现

      脑电信号滤波-代码实现

      运动想象系统中的特征提取算法和分类算法

      特征提取算法 | 共空间模式 Common Spatial Pattern(CSP)

      功率谱估计-直接法原理与案例

      MNE中文教程(16)-脑电数据的Epoching处理

      DEAP数据库介绍--来自于音乐视频材料诱发得到的脑电数据

      PsychoPy安装与测试案例

      PsychoPy文字刺激、图片刺激和光栅刺激

      Python机器学习算法随机森林判断睡眠类型

      (0)

      相关推荐

      • ​EEG中如何鉴别心电干扰信号

        <本文同步发布于"脑之说"微信公众号,欢迎搜索关注~~> 在EEG的信号处理过程中,通过独立成分分析(ICA)去除各种干扰信号应该是最麻烦的步骤,因为它需要操作者的主观 ...

      • TESA:分析同步经颅磁刺激和脑电图数据

        经颅磁刺激与脑电图(transcranial magnetic stimulation with electroencephalography, TMS-EEG) 的同时使用作为一种评估各种皮质属性( ...

      • 基于Matlab、EEGLab和ERPlab的偏侧化差异波(N2pc/Pd/CDA )成分分析方法

        转载自:流浪心球:作者:念靖晴 N2pc.Pd.CDA都是偏侧化差异波成分,是视觉目标对侧视野与目标同侧视野(如:威胁刺激在右侧, 则左半球电极点为对侧, 右半球电极点为同侧)电极点的波幅差异波. 因 ...

      • IEEE Signal Processing Magazine:fMRI数据的时变脑连接

        使用功能磁共振成像(fMRI)对全脑的功能性连接研究基于以下假设,即可以通过对整个实验进行平均来评估给定的条件(如休息状态或在任务状态).实际上,数据具有动态性,即使在相同的实验条件下,也显示出连接模 ...

      • 用于追踪认知任务期间的亚秒级脑动态的高密度脑电

        这项工作为社区提供了高密度脑电图(HD-EEG, 256个通道)数据集,这些数据集是在无任务和任务相关范式下收集的.它包括43名健康的参与者执行视觉命名和拼写任务,视觉和听觉命名任务和视觉工作记忆任务 ...

      • 头皮和硬膜下EEG对脑深部活动的定位

        对于皮层脑电图(ECoG)和头皮脑电图(sEEG)在定位大脑深层活动来源的能力上的不同尚不明显.与sEEG相比,ECoG的空间分辨率和信噪比更高,但其空间覆盖范围受到更多限制,有效测量组织活动的体积也 ...

      • 手把手教你EEG脑电数据预处理-原理篇

        更多技术干货第一时间送达 感谢简书ID:亚内士多德 授权分享 EEG脑电数据预处理-原理篇 本文不涉及具体的操作步骤,而是对脑电数据预处理中的每一步进行解说,根据我自己的经验来解释为什么要这么做,希望 ...

      • letswave7中文教程2:脑电数据预处理-通道位置分配

        更多技术干货第一时间送达 原始的脑电图信号是有噪声的.预处理对于提高信号的信噪比以获得"清晰"的脑电图数据是非常有必要的.但是,想要完全区分噪音和信号却是几乎不可能的.在脑电信号中 ...

      • letswave7中文教程3:脑电数据预处理-ICA去除伪影

        更多技术干货第一时间送达 ICA/BSS的理论与模型 独立成分分析(ICA)是一种盲信号分离(Blind Signal Separation,BSS)方法.ICA可线性建模如下图所示. 假设X为&qu ...

      • letswave7中文教程4:脑电数据预处理-时域分析

        更多技术干货第一时间送达 在本章中,我们将继续对ICA过滤后的P300数据集进行预处理. 说明,这部分的教程是基于前面几次教程的基础上进行的.所以要进行ICA预处理进行伪影去除,需要: 先导入数据&l ...

      • 手把手教你设置北上资金数据指标

        上一周介绍了如何在通达信使用跳空高开选股,发现了很多让卡尔哭笑不得的问题,文中的几个图已经把最终的界面展现出来,按部就班的抄都抄错,要么没有设置参数N,要么少了个冒号,或者分号写成冒号等等,大家照着葫 ...

      • MNE中文教程(16)-脑电数据的Epoching处理

        更多技术干货第一时间送达 Epoch概念简介 从连续的脑电图信号中提取一些特定时间窗口的信号,这些时间窗口可以称作为epochs.由于EEG是连续收集的,要分析脑电事件相关的电位时,需要将信号&quo ...

      • DEAP数据库介绍--来自于音乐视频材料诱发得到的脑电数据

        更多技术干货第一时间送达 DEAP数据库简介 DEAP[1](Database for Emotion Analysis usingPhysiological Signals),该数据库是由来自英国伦 ...

      • Python-使用多种滤波器对脑电数据去除伪影

        更多技术干货第一时间送达 一些由电源线造成的伪影具有某些特定范围的频率(比如,由电网产生的电力线噪声,主要由50Hz(或60Hz取决于实验的地理位置)的尖峰组成).因此可以通过滤波来固定. 本文分别使 ...

      • Python-生成模拟原始脑电数据

        更多技术干货第一时间送达 在实验中有时需要原始脑电数据来进行模拟实验,但又限于实验条件的不足,需要构造模拟的原始脑电数据. 本示例通过多次重复所需的源激活来生成原始数据. 案例介绍 # 导入工具包im ...