仿Yasa算法-睡眠分期,目前五分期86.5%

参考链接

具体内容可见:个人文章

参考代码

The code that was used to train the classifiers can be found on GitHub at:
Link

验证数据集

PhysiNet-Haaglanden
选取了其中150例数据(剔除了No.98,标签数据长度不匹配)

特征

参考Yasa的定义,每个脑电通道筛选了(283=84)个特征,每个眼电通道筛选了(233=69)个特征,肌电通道筛选了(10*3=30)个特征。

结果

在这里插入图片描述

(1)论文作者以训练好的模型(对单人)

1.三通道

使用通道名称:eeg_name=“EEG C4-M1”, eog_name=“EOG E1-M2”, emg_name=“EMG chin”
准确率:73.62%

// 
def calculate_accuracy(edf_file, txt_file):
    # 这里应该是你的准确率计算逻辑
    # 例如,打开EDF文件,进行一些处理,然后使用TXT文件中的数据进行比较
    # 返回计算得到的准确率

    # 加载 EDF 文件
    raw = mne.io.read_raw_edf(edf_file, preload=True)
    # Let's now load the human-scored hypnogram, where each value represents a 30-sec epoch.
    hypno = np.loadtxt(txt_file, dtype=str)

    sls = yasa.SleepStaging(raw, eeg_name="EEG C4-M1", eog_name="EOG E1-M2", emg_name="EMG chin")

    y_pred = sls.predict()

    # What is the accuracy of the prediction, compared to the human scoring
    accuracy = (hypno == y_pred).sum() / y_pred.size

    return accuracy

在这里插入图片描述

2.单通道脑电

使用通道名称:eeg_name=“EEG C4-M1”
准确率:72.79%

def calculate_accuracy(edf_file, txt_file):
    # 这里应该是你的准确率计算逻辑
    # 例如,打开EDF文件,进行一些处理,然后使用TXT文件中的数据进行比较
    # 返回计算得到的准确率

    # 加载 EDF 文件
    raw = mne.io.read_raw_edf(edf_file, preload=True)
    # Let's now load the human-scored hypnogram, where each value represents a 30-sec epoch.
    hypno = np.loadtxt(txt_file, dtype=str)

    # sls = yasa.SleepStaging(raw, eeg_name="EEG C4-M1", eog_name="EOG E1-M2", emg_name="EMG chin")
    sls = yasa.SleepStaging(raw, eeg_name="EEG C4-M1")

    y_pred = sls.predict()

    # What is the accuracy of the prediction, compared to the human scoring
    accuracy = (hypno == y_pred).sum() / y_pred.size

    return accuracy

在这里插入图片描述

(2)全连接,单通道脑电

通道:EEG C4-M1
准确率:77.23%

# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 构建模型
model = Sequential()
model.add(Dense(128, input_shape=(84,), activation='relu'))
model.add(Dense(64, activation='relu'))
model.add(Dense(5, activation='softmax'))  # 5 类分类

# 训练模型
model.fit(X_train, y_train, epochs=500, batch_size=32, validation_data=(X_test, y_test))

在这里插入图片描述
在这里插入图片描述

(3)全连接,4通道脑电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’
准确率:79.26%

# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 构建模型
model = Sequential()
model.add(Dense(128, input_shape=(336,), activation='relu'))
model.add(Dense(64, activation='relu'))
model.add(Dense(5, activation='softmax'))  # 5 类分类

# 训练模型
model.fit(X_train, y_train, epochs=500, batch_size=32, validation_data=(X_test, y_test))

在这里插入图片描述
在这里插入图片描述

(4)LightGBM,4通道脑电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’
准确率:82.62%

# 创建 LightGBM 分类器
lgbm = LGBMClassifier(n_estimators=100, learning_rate=0.05)
y_train_1d = np.argmax(y_train, axis=1)
y_test_1d = np.argmax(y_test, axis=1)

# 然后使用这个一维数组进行训练
lgbm.fit(X_train, y_train_1d)

# 预测和评估
y_pred = lgbm.predict(X_test)
accuracy = accuracy_score(y_test_1d, y_pred)
print(f"Accuracy: {accuracy}")

在这里插入图片描述
在这里插入图片描述

(5)全连接,4通道脑电+EMG+2通道眼电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’, ‘EMG chin’, ‘EOG E1-M2’, ‘EOG E2-M2’
准确率:81.24%

# 构建模型
model = Sequential()
model.add(Dense(128, input_shape=(504,), activation='relu'))
model.add(Dense(64, activation='relu'))
model.add(Dense(5, activation='softmax'))  # 5 类分类

在这里插入图片描述
在这里插入图片描述

(6)LSTM,4通道脑电+EMG+2通道眼电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’, ‘EMG chin’, ‘EOG E1-M2’, ‘EOG E2-M2’
准确率:81.68%

def build_lstm_model(input_shape, num_classes):
    model = Sequential()

    # model.add(LSTM(50, input_shape=input_shape))
    model.add(LSTM(100, input_shape=input_shape))

    model.add(Dense(num_classes, activation='softmax'))
    model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy'])
    return model

在这里插入图片描述
在这里插入图片描述

(7)LightGBM,4通道脑电+EMG+2通道眼电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’, ‘EMG chin’, ‘EOG E1-M2’, ‘EOG E2-M2’
准确率:84.22%

# 创建 LightGBM 分类器
lgbm = LGBMClassifier(n_estimators=100, learning_rate=0.05)

在这里插入图片描述
在这里插入图片描述

(8)CNN,4通道脑电+EMG+2通道眼电

通道:‘EEG F4-M1’, ‘EEG C4-M1’, ‘EEG O2-M1’, ‘EEG C3-M2’, ‘EMG chin’, ‘EOG E1-M2’, ‘EOG E2-M2’
准确率:86.50%

# 由于是1D数据,我们需要扩展一个维度来适配CNN
X_train = X_train[..., np.newaxis]
X_test = X_test[..., np.newaxis]

# 构建模型
model = tf.keras.models.Sequential([
    tf.keras.layers.Conv1D(filters=64, kernel_size=3, activation='relu', input_shape=(504, 1)),
    tf.keras.layers.Conv1D(filters=64, kernel_size=3, activation='relu'),
    tf.keras.layers.Dropout(0.5),
    tf.keras.layers.MaxPooling1D(pool_size=2),
    tf.keras.layers.Flatten(),
    tf.keras.layers.Dense(100, activation='relu'),
    tf.keras.layers.Dense(5, activation='softmax')
])

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/272213.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Shell 脚本应用(四)

正则表达式概述 正则表达式又称正规表达式,常规表达式。在代码中常简写为regex,regexp 或RE.正则表达式 是使用单个字符串来描述,匹配一系列符合某个句法规则的字符串,简单来说,是一种匹配字符串 的方法,通…

Nacos2.1.2改造适配达梦数据库7.0

出于业务需求,现将Nacos改造适配达梦数据库7.0,记录本次改造过程。 文章目录 一、前期准备二、适配流程1、项目初始化2、引入驱动3、源码修改 三、启动测试四、打包测试 一、前期准备 Nacos源码,版本:2.1.2:源码下载…

【Linux驱动】驱动框架的进化 | 总线设备驱动模型

🐱作者:一只大喵咪1201 🐱专栏:《Linux驱动》 🔥格言:你只管努力,剩下的交给时间! 目录 🥩驱动框架的进化🥠分层🥠面向对象🥠编程&am…

爬虫工作量由小到大的思维转变---<第二十八章 Scrapy中间件说明书>

爬虫工作量由小到大的思维转变---<第二十六章 Scrapy通一通中间件的问题>-CSDN博客 前言: (书接上面链接)自定义中间件玩不明白? 好吧,写个翻译的文档点笔记,让中间件更通俗一点!!! 正文: 全局图: 爬虫中间件--->翻译笔记: from scrapy import s…

蓝桥小课堂-平方和【算法赛】

问题描述 蓝桥小课堂开课啦! 平方和公式是一种用于计算连续整数的平方和的数学公式。它可以帮助我们快速求解从 1 到 n 的整数的平方和,其中 n 是一个正整数。 平方和公式的表达式如下: 这个公式可以简化计算过程,避免逐个计算…

JRT支持人大金仓

之前对接了PostGreSql和iris和Cache库,表的主键列都是RowID,列同时区分大小写带引号。这次试试连人大金仓库,主键列不叫RowID了,改id,然后不使用大小写。 代码生成器生成的代码效果 测试表 生成实体 生成后台 生…

vue 脚手架文件结构及加载过程浅谈

1. 初始化脚手架 1.1 全局安装 vue/cli npm install -g vue/cli 1.2 切换到创建项目的目录,执行 vue create projectname 1.3 选择符合自己要求的项进行Y/N,最终生成项目文件 2. 脚手架文件结构 |-- node_modules: 存放下载依赖的文件夹 |-- public: …

【HTML5】第2章 HTML5标签和属性

学习目标 掌握文本控制标签的用法,能够使用文本控制标签设置文本样式。 掌握图像标签的用法,能够使用图像标签在网页中嵌入图片。 掌握超链接标签的用法,能够使用超链接实现页面的跳转。 掌握列表标签的用法,能够使用列表标签设…

【Java中序列化的原理是什么(解析)】

🍁序列化的原理是什么? 🍁典型-----解析🍁拓展知识仓🍁Serializable 和 Externalizable 接门有何不同? 🍁如果序列化后的文件或者原始类被篡改,还能被反序列化吗?🍁serialVersionU…

JSON在Java中的使用

目录 第一章、快速了解JSON1.1)JSON是什么1.2)json的语法格式①键值对、字符串、数字、布尔值、数组、对象②嵌套的格式 1.3)为什么使用JSON 第二章、发送和接收JSON格式数据2.1)postman发送JSON格式数据2.2)Java后端接…

C/C++图形化编程(1)

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言​📝 信念是一把无坚不摧的利刃&#xff01…

JavaOOP篇----第十九篇

系列文章目录 文章目录 系列文章目录前言一、数组有没有length()这个方法? String有没有length()这个方法二、用最有效率的方法算出2乘以8等于几三、float型float f=3.4是否正确?四、排序都有哪几种方法?请列举五、静态变量和实例变量的区别?前言 前些天发现了一个巨牛的人…

基础数论一:判定质数和求约数相关

1.试除法求质数 质数就是大于1的整数中除了1和自身没有其他因数的数 1.1暴力求解 暴力求解的思路就是从2遍历到自身判断是否有被整除的数&#xff0c;时间复杂度为O(n)的 bool is_prime(int x) {if(x<2)return false;for(int i2;i<x;i){if(x%i0){return false;}}return…

第十七章 多线程基础

一、线程相关概念 1. 程序 程序&#xff1a;是为完成特定任务、用某种语言编写的一组指令的集合。 简单说就是代码。 2. 进程 &#xff08;1&#xff09;进程是指运行中的程序&#xff0c;比如我们使用QQ&#xff0c;就启动了一个进程&#xff0c;操作系统会为该进程分配内存空…

离职的赔偿算法n 、n+1、2n你还不懂嘛?

亲爱的小伙伴们&#xff0c;由于微信公众号改版&#xff0c;打乱了发布时间&#xff0c;为了保证大家可以及时收到文章的推送&#xff0c;可以点击上方蓝字关注测试工程师成长之路&#xff0c;并设为星标就可以第一时间收到推送哦&#xff01; 哪些情况需要支付经济补偿? 劳动…

看图了解ODF光纤配线架,详细熔接过程学习

弱电工程&#xff0c;远距离传输离不开光纤&#xff0c;只有光纤才能让网络传输的更远&#xff0c;今天了解光纤的配套产品&#xff0c;光纤配线架&#xff08;Optical Distribution Frame&#xff09;用于光纤通信系统中局端主干光缆的成端和分配&#xff0c;可方便地实现光纤…

【Python】requests库在CTFWeb题中的应用

目录 ①Bugku-GET ②Bugku-POST ③实验吧-天下武功唯快不破 ④Bugku-速度要快 ⑤Bugku-秋名山车神 ⑥Bugku-cookies ①Bugku-GET import requestsresprequests.get(urlhttp://114.67.175.224:12922/,params{what:flag}) print(resp.text)//或者 //resprequests.get(urlht…

使用Visual Studio调试VisionPro脚本

使用Visual Studio调试VisionPro脚本 方法一 &#xff1a; 修改项目文件 csproj步骤&#xff1a; 方法二 &#xff1a; Visual Studio附加功能步骤&#xff1a; 方法一 &#xff1a; 修改项目文件 csproj 步骤&#xff1a; 开启VisionPro脚本调试功能 创建一个VisionPro程序…

VBA技术资料MF99:在代码中使用VLookUp函数

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到…

华为数通方向HCIP-DataCom H12-831题库(多选题:221-240)

第221题 在割接项目的项目调研阶段需要对现网硬件环境进行观察,主要包括以下哪些内容? A、设备的位置 B、ODF位置 C、接口标识 D、光纤接口对应关系 答案:ABCD 解析: 在项目割接前提的项目调研阶段,需要记录下尽可能详细的信息。 第222题 以下哪些项能被正则表达式10*成…