EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset

这篇具有很好参考价值的文章主要介绍了EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

2023/3/9 -3/11 脑机接口学习内容一览:

        

        前段时间做了比较多的提取频谱特征来进行机器学习,进而完成模式识别的任务。在这这一篇博客中,将尝试使用EEG信号,主要使用plt.specgram()函数来生成脑电信号的时频图dataset,为接下来使用神经网络进行深度学习做准备。


一、需求分析:

        在本次工作开始之前,我们先对本次的尝试进行一次简单的需求分析。

        (在参加服务外包期间因为没有做好这些基础工作吃了很大的亏,不得不频繁修改代码)

1.数据集

        本次尝试采用的数据集仍然与往期博文对脑电信号进行特征提取并分类(二分类)相同,采用的是matlab脑电处理工具EEGlab的自带数据集。数据集中包括两种刺激rt与square,对于我们的工作来说是一个较为简单的二分类问题。

2.输出数据

        根据参考资料【1】中对脑电数据源的要求,可知卷积核面向的脑电数据尽量具有图像结构,并且为一个三维张量,包括三个维度即时间,频率,频道。根据参考资料【4】中dataset讲解部分分析可得,可能需要输出的图片结构如图所示:

EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset

        除此之外,我们根据参考资料【3】的建议,将生成图片以224像素大小的png格式输出。


二、处理流程

        在这个环节,我们事先敲定一下处理的流程,避免出现想到哪里做到哪里这种没有规划的情况。

        1.导入数据集;

        2.使用之前预处理所用函数过一遍预处理,参考对脑电信号进行特征提取并分类(二分类)中的transform( )函数;

        3.遍历训练集和测试集中的epochs片段,根据标签和频道来生成对应的时频图并保存到指定路径中。


三、完整代码

        这次的代码时间较为简单。花那么长时间的主要原因在于需要调查适合于投入CNN网络的数据集格式与回想复习之前所学习的神经网络知识。一开始对mne不熟悉,没有立刻想起epochs的采样点具体数据是由get_data()得到的,也花费了不少查询时间。

        需要注意的是程序生成图片的数量较多(约4000~5000张),所以跑的时间比较长,我运行了大概四个小时左右。

import os
import matplotlib.pyplot as plt
import mne


def transform(raw, event_id):
    # 有别于之前繁琐的预处理,这里尽量少采用预处理,保持EEG数据的完整性
    events, _ = mne.events_from_annotations(raw, event_id=event_id, chunk_duration=None)
    '''
    根据事件创建epochs
    在这个部分,提取epochs的各项参数需要自己仔细确定
    比如tmin和tmax这两个值,可以通过raw的plot图像来大致确定
    picks这里选取的是eeg通道
    同时使用了基线校正
    '''
    tmin, tmax = -0.2, 0.3
    epochs = mne.Epochs(raw=raw, events=events, event_id=event_id, tmin=tmin,
                        tmax=tmax, baseline=(None, 0), preload=True, reject_tmax=0, reject_by_annotation=False)
    epochs_data = epochs.get_data()
    """
    print(epochs.get_data().shape)
    print(events.shape)
    (65, 32, 65)
    (65, 3)
    get_data()方法将带epoch的数据作为NumPy数组返回,形状为(n_epochs, n_channels, n_times):可选的picks参数根据索引、名称或类型选择频道的子集:
    打印第一次的train处理部分可得epochs_train中包括65个片段
    event_train的[:, 2]为每个片段的event标识
    """
    events_data = events[:, 2]
    return epochs_data, events_data


def draw_save(data, label_list, ch_names, save_path):
    # 这里对提取的数据进行绘制时频图并保存
    label_list = [str(i) for i in label_list]
    ch_len = len(ch_names)
    label_len = len(label_list)
    for count in range(label_len):
        # epochs标签(data.shape[0])
        for i in range(ch_len):
            # 通道数
            plt.rcParams['figure.figsize'] = (4.48, 4.48)  # 2.24, 2.24 设置figure_size尺寸
            plt.rcParams['savefig.dpi'] = 50  # 图片像素 这样输出的就是4.48*50=224
            plt.specgram(data[count][i], NFFT=16, Fs=128, noverlap=10)
            k = str(i)
            q = str(count)
            path = save_path + label_list[count] + "/" + ch_names[i] + "_" + k + "_" + q + ".png"
            plt.savefig(path, bbox_inches='tight', pad_inches=0)  # 后两项为去除白边
            # print("1")

    print(save_path + "has been finished\n")


def main(file):
    raw = mne.io.read_raw_eeglab(file, preload=True, uint16_codec=None)
    print(raw.info)

    # 切出训练和测试集
    event_id = {'rt': 1, 'square': 2}
    raw_train = raw.copy()
    raw_train = raw_train.crop(0, 100)
    raw_test = raw.crop(100, 200)

    # 根据raw生成epochs,参考之前的transform()函数,具体在处理流程部分提供链接
    epochs_train, events_train = transform(raw_train, event_id)
    epochs_test, events_test = transform(raw_test, event_id)
    ch_names = raw.ch_names
    print(ch_names)

    train_save_path = os.path.join(os.getcwd(), "data/root/train/")
    draw_save(epochs_train, events_train, ch_names, train_save_path)
    test_save_path = os.path.join(os.getcwd(), "data/root/test/")
    draw_save(epochs_test, events_test, ch_names, test_save_path)


if __name__ == "__main__" :
    # 获取父路径
    father_path = os.getcwd()
    # 设定子路径
    son_path = "eeglab-read-set/secdata.set"
    file = os.path.join(father_path, son_path)
    main(file)

四、结果展示

        输出结果与之前的预期基本相同。

EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset

EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset


五、总结归纳

        相比与之前,对于解决一个问题需要采用什么方法比较好有了较深的认识,对python的熟悉度也有了进一步的提高,但是解决问题的速度依然较慢。


六、参考文献:

【1】脑电EEG代码开源分享 【6. 分类模型-深度学习篇】

【2】python 绘制时频图 plt.specgram

【3】python将批量音频信号(wav)转化为语谱图并保存(jpg/png)

【4】PyTorch深度学习快速入门教程(绝对通俗易懂!)【小土堆】

      


UPDATE

2023/3/13 增加后续cnn网络部分流程EEG深度学习实战:脑电信号通过CNN神经网络进行二分类文章来源地址https://www.toymoban.com/news/detail-460243.html

到了这里,关于EEG&CNN深度学习神经网络前置:处理EEG脑电信号生成时频图dataset的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 深度学习05-CNN循环神经网络

    循环神经网络(Recurrent Neural Network,RNN)是一种具有循环连接的神经网络结构,被广泛应用于自然语言处理、语音识别、时序数据分析等任务中。相较于传统神经网络,RNN的主要特点在于它可以处理序列数据,能够捕捉到序列中的时序信息。 RNN的基本单元是一个循环单元(

    2024年02月11日
    浏览(41)
  • 深度学习入门教学——卷积神经网络CNN

    1、应用领域 检测任务 分类与检索 超分辨率重构 2、卷积网络与传统网咯的区别 传统神经网络和卷积神经网络都是用来 提取特征 的。 神经网络: 可以将其看作是一个二维的。 卷积神经网络: 可以将其看作是一个三维的。  3、整体框架 该层主要是对原始图像数据进行预处

    2024年02月10日
    浏览(38)
  • 深度学习入门(三):卷积神经网络(CNN)

    给定一张图片,计算机需要模型判断图里的东西是什么? (car、truck、airplane、ship、horse) CONV:卷积计算层,线性乘积求和 RELU:激励层,激活函数 POOL:池化层,取区域平均或最大(MAX POOL) PC:全连接层 对CNN来说,它是一块一块进行对比的,“小块”称之为Features特征。

    2024年02月11日
    浏览(42)
  • 【深度学习】最强算法之:卷积神经网络(CNN)

    小屌丝 :鱼哥, 看下这个流程图,我没看明白 小鱼 :啥流程图。 小屌丝 :你看,就是这个。 小鱼 :嗯,不错,不错。 小屌丝 :能不能给我讲一讲这个? 小鱼 :你要了解CNN ? 小屌丝 :CNN 是? 小鱼 :…你这… 深度学习知道吗? 小屌丝 :知道啊 小鱼 :你都知道深度

    2024年04月09日
    浏览(40)
  • 【深度学习_TensorFlow】卷积神经网络(CNN)

    这篇文章的行文思路如下: 先根据视频了解卷积和卷积神经网络的整体框架 接着了解卷积神经网络构建过程中的一些重要操作,包括内积、填充、池化。 然后介绍卷积层如何实现。 最后用卷积神经网络的开山之作(LeNet-5)来进行上手练习。 最近学习信号与系统的时候,了

    2024年02月07日
    浏览(50)
  • 学习笔记:深度学习(3)——卷积神经网络(CNN)理论篇

    学习时间:2022.04.10~2022.04.12 CNN(Convolutional Neural Networks, ConvNets, 卷积神经网络)是神经网络的一种,是理解图像内容的最佳学习算法之一,并且在图像分割、分类、检测和检索相关任务中表现出色。 3.1.1 什么是CNN? CNN是一种带有卷积结构的前馈神经网络, 卷积结构 可以减少

    2024年02月03日
    浏览(91)
  • 深度学习入门——卷积神经网络CNN基本原理+实战

    ​ 卷积神经网络(Convolutional Neural Network,CNN)是深度学习技术中最基础的网络结构,模拟人脑工作,具备强大的特征学习能力。CNN结构主要由两部分组成:特征提取部分和分类部分color{blue}{特征提取部分和分类部分}特征提取部分和分类部分。特征提取部分网络将执行一系列

    2024年01月21日
    浏览(49)
  • 【深度学习】6-4 卷积神经网络 - CNN的实现

    CNN的实现 网络的构成是“Convolution - ReLU - Pooling -Affine - ReLU - Affine - Softmax”,我们将它实现为名为 SimpleConvNet 的类。 首先来看一下 SimpleConvNet的初始化( init ),取下面这些参数。 input_dim——输入数据的维度:(通道,高,长) conv_param——卷积层的超参数(字典)。字典的

    2024年02月10日
    浏览(46)
  • 深度学习实战——卷积神经网络/CNN实践(LeNet、Resnet)

          忆如完整项目/代码详见github: https://github.com/yiru1225 (转载标明出处 勿白嫖 star for projects thanks) 本系列博客重点在深度学习相关实践(有问题欢迎在评论区讨论指出,或直接私信联系我)。 第一章  深度学习实战——不同方式的模型部署(CNN、Yolo)_如何部署cnn_

    2023年04月11日
    浏览(48)
  • 文本分类系统Python,基于深度学习CNN卷积神经网络

    文本分类系统,使用Python作为主要开发语言,通过TensorFlow搭建CNN卷积神经网络对十余种不同种类的文本数据集进行训练,最后得到一个h5格式的本地模型文件,然后采用Django开发网页界面,实现用户在界面中输入一段文字,识别其所属的文本种类。 在我们的日常生活和工作中

    2024年02月08日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包