# candock 这是一个用于记录毕业设计的日志仓库,其目的是尝试多种不同的深度神经网络结构(如LSTM,RESNET,DFCNN等)对单通道EEG进行自动化睡眠阶段分期.我们相信这些代码同时可以用于其他生理信号(如ECG,EMG等)的分类.希望这将有助于您的研究.
## 数据集 使用了三个睡眠数据集进行测试,分别是: [[CinC Challenge 2018]](https://physionet.org/physiobank/database/challenge/2018/#files) [[sleep-edf]](https://www.physionet.org/physiobank/database/sleep-edf/) [[sleep-edfx]](https://www.physionet.org/physiobank/database/sleep-edfx/)
对于CinC Challenge 2018数据集,使用其C4-M1通道
对于sleep-edfx与sleep-edf数据集,使用Fpz-Cz通道
值得注意的是:sleep-edfx是sleep-edf的扩展版本.
## 一些说明 * 对数据集进行的处理
读取数据集各样本后分割为30s/Epoch作为一个输入,共有5个标签,分别是Sleep stage 3,2,1,R,W,将分割后的eeg信号与睡眠阶段标签进行对应后,打乱其顺序,并将80%的数据用于训练,20%的数据用于测试.
注意:对于sleep-edfx数据集,我们仅仅截取了入睡前30分钟到醒来后30分钟之间的睡眠区间作为读入数据(实验结果中用only sleep time 进行标注),目的是平衡各睡眠时期的比例并加快训练速度. * 数据预处理
对于不同的网络结构,对原始eeg信号采取了预处理,使其拥有不同的shape:
LSTM:将30s的eeg信号进行FIR带通滤波,获得θ,σ,α,δ,β波,并将它们进行连接后作为输入数据
resnet_1d:这里使用resnet的一维形式进行实验,(修改nn.Conv2d为nn.Conv1d).
DFCNN:将30s的eeg信号进行短时傅里叶变换,并生成频谱图作为输入,并使用图像分类网络进行分类.
* EEG频谱图
这里展示5个睡眠阶段对应的频谱图,它们依次是wake, stage 1, stage 2, stage 3, REM
![image](https://github.com/HypoX64/candock/blob/master/image/spectrum_wake.png) ![image](https://github.com/HypoX64/candock/blob/master/image/spectrum_N1.png) ![image](https://github.com/HypoX64/candock/blob/master/image/spectrum_N2.png) ![image](https://github.com/HypoX64/candock/blob/master/image/spectrum_N3.png) ![image](https://github.com/HypoX64/candock/blob/master/image/spectrum_REM.png) * 关于代码
目前的代码仍然在不断修改与更新中,不能确保其能工作.详细内容将会在毕业设计完成后抽空更新.
## 部分实验结果 该部分将持续更新... ...
[[Confusion matrix]](https://github.com/HypoX64/candock/blob/master/image/confusion_mat)
* sleep-edf
| Network | Label average recall | Label average accuracy | error rate | | :------------- | :------------------- | ---------------------- | ---------- | | lstm | 0.8342 | 0.9611 | 0.0974 | | resnet18_1d | 0.8434 | 0.9627 | 0.0930 | | DFCNN+resnet18 | 0.8567 | 0.9663 | 0.0842 | | DFCNN+resnet50 | 0.7916 | 0.9607 | 0.0983 | * sleep-edfx(only sleep time)
| Network | Label average recall | Label average accuracy | error rate | | :------------- | :------------------- | ---------------------- | ---------- | | lstm | 0.7864 | 0.9166 | 0.2085 | | resnet18_1d | xxxxxx | xxxxxx | xxxxxx | | DFCNN+resnet18 | 0.7844 | 0.9124 | 0.219 | | DFCNN+resnet50 | xxxxxx | xxxxxx | xxxxxx | * CinC Challenge 2018