增强深度学习与对抗训练对癫痫发作的鲁棒预测

标题:Augmenting Deep Learning with Adversarial Training for
Robust Prediction of Epilepsy Seizures

Abstract:

癫痫是一种慢性疾病,涉及异常的大脑活动,导致患者失去对意识或运动活动的控制。因此,在癫痫发作之前检测出癫痫发作前的状态可以挽救生命。这个问题是具有挑战性的,因为很难区分在频前状态的脑电图信号和正常频间状态的信号。有三个关键的挑战是以前没有解决的:(1)预测模型在患者之间的表现不一致,(2)缺乏完美的预测来保护患者免受任何事件的影响,以及(3)用于推进机器学习(ML)方法的临界前标记数据数量有限。本文通过一种新颖的方法解决了这些限制,该方法使用对抗性示例,并对带有门控循环单元的组合卷积神经网络进行了优化调整。

与目前的技术水平相比,结果表明,模型鲁棒性提高了3倍,曲线下面积(AUC)的变化减少了,AUC精度平均提高了6.7%。该方法在机器学习和癫痫预测领域的其他进展(包括高斯噪声数据增强和多任务学习)中也表现出优异的性能。

1 Introduction

本文解决了这些挑战,并介绍了一些贡献:

用脑电图时间序列数据增强对抗实例(AE)用于癫痫发作预测。对于机器学习领域来说,AE并不陌生,但它在癫痫数据生成方面的应用是新的。该方法有助于确保模型在数据变化的情况下得到训练时的稳健性。随着更多的训练数据变得可用,该方法也有助于克服训练数据的限制。

虽然卷积神经网络(CNN)和门控递归单元(GRU)的选择对于时间序列来说并不新鲜,但它在癫痫以及癫痫发作预测组件优化方面的应用是新的:(1)时间处理,仔细选择时间窗口,同时检查数据的稳定性,以确保窗口足够大,能够捕捉到所需的模式,同时确保不同时间窗口的一致性。(2)层的具体选择是通过调整过程选择的,以确保最高的准确性,同时保持曲线下面积(AUC)达到的所需稳健性。由此产生的网络拓扑不同于先前的工作。(3)通过用独特的患者数据进行训练并为每个患者生成个体AE,为每个患者开发个体模型。这种方法确保了导出的模型可以在患者之间提供改进的区分。所提出的方法在两个基准数据集上实现了最先进的性能,通过AUC、每小时假阳性率(FPR/小时)和灵敏度进行测量,如下所述。与基于频谱分析的现有技术[36]的比较表明了基于时间的处理的优越性。

在稳健性方面,对于两个基准数据集,结果显示患者之间的差异显著减少。稳健性在两个基准数据组中用几个指标证明,包括:每个数据组中患者的AUC平均标准偏差减少2倍和2.5倍,灵敏度的平均标准偏差减少2倍,每个数据组的AUC范围(患者的最大和最小AUC值之间的差异)减少2.5倍和3倍。就发作前预测的准确性而言,结果显示每个数据集的平均AUC分别提高了2.8%和6.7%。对于每个数据集,灵敏度分别平均提高了3.96%和1.8%。每个数据集的FPR/h分别提高了8%和62.5%。本文的其余部分组织如下:第2节概述了癫痫发作预测的相关工作。第3节介绍了我们提出的方法,第4节包含了实验和结果,并与最先进的技术进行了比较。在第5节中,我们包括了结论和研究结果的总结。

2相关工作

使用机器学习技术进行癫痫分类的相关工作可以分为基于特征的方法和深度学习方法。在每个类别中,研究人员已经检查了癫痫检测和预测的两个不同问题,但通常检查信号中的相似特征。这些方法在这里进一步详述。

2.1基于特征的方法

2.1.1癫痫发作检测:

为特定患者的癫痫发作检测而定制的特征工程技术已经成功实现了非常高的灵敏度89.66%,在21名患者中获得了0.49的FPs/h值[11]和(100%),在相同患者中具有非常低的假阳性率[7,27]。在[31]中,作者开发了一个机器学习框架,能够识别癫痫检测的关键特征。他们使用支持向量机构建患者特异性模型,同时考虑灵敏度、特异性和潜伏期作为性能指标。该工作为癫痫脑电数据预处理以及特征提取和评价方法提供了一种新的途径。尽管这些方法获得了非常高的灵敏度,但它们严重偏向于特定的数据集。此外,它们仅用于癫痫发作检测,而非预测。

为了推广使用MTL的癫痫发作检测,在[38]中提出了基于特征的患者特异性MTL-SVM模型。提取的特征是通过使用频率范围为0.5至25 Hz的四个滤波器组对每个通道的EEG信号进行滤波,然后类似于[31]中所做的工作计算每个频带内的能量而获得的。此外,所提出的模型被开发来学习各种患者特异性癫痫发作的一般表示,以便更好地推广到所有不同类型的患者特异性癫痫发作。虽然这项工作的目标是提高模型的可推广性,但模型的特征不足以预测癫痫发作,因为它们仅包括来自滤波器组频带的能量特征,不足以检测代表发作前状态的EEG信号的变化。

2.1.2癫痫发作预测:

癫痫发作预测的主要目标是检测发作间期和发作前状态之间的过渡期,称为发作前状态[12]。在以前的工作中,使用机器学习方法探索了用于癫痫发作预测的不同信号处理技术。例如,在[10]中,探索了用于癫痫发作预测的频域和时域特征组合的合理性。提出的特征向量包括自回归拟合误差、去相关时间、能量、迁移率和复杂度、δ、θ、α、β和γ频带中的谱功率、谱边缘(功率、频率)、四个矩(均值、方差、偏斜度、峰度)、六个分解级的能量小波系数。对216名患者测试了所提出的方法,并且对所有患者实现了38.47%的灵敏度和平均0.2 FPR/小时,而仅对24名患者实现了统计显著性。在[28]中,EEG信号段被过滤以获得四个频带,即δ、θ、α、β和γ。从每个频带中提取以下特征:1)归一化谱功率特征2)四个矩3)活动性、移动性和复杂性特征4)信号的累积能量5)拟合10阶AR模型产生的自回归(AR)误差6)去相关时间7)谱边缘功率8)小波系数。此外,实验还包括确定发作前时间、标准化方法、平滑和异常值去除的最佳组合。发现平滑、异常值去除和通过每个特征的最大值进行归一化为大多数患者提供了最好的结果。所提出的方法实现了73.9%的平均灵敏度,10名患者的FPR/h平均为0.15。以前的方法主要依赖于单变量特征,而不是从多个通道的组合中提取的多变量特征。例如,在[3]中,提出了双变量谱带功率特征用于癫痫发作预测。所提出的特征在24名患者中实现了75.8%的平均灵敏度和0.1的FPR/h。在[22]中,探索了非线性双变量特征的使用,例如小波同步。此外,所提出的特征实现了71%的平均灵敏度,15名患者的平均FPR/小时为零。

虽然在基于特征的癫痫发作预测的文献中可以找到不同的推荐特征集,但没有特定的特征集被证明是预测癫痫发作的最佳集[2]。此外,所提出的方法需要领域知识,并且对于不同的患者或不同的数据集可能不能类似地执行。

2.2深度学习方法

深度神经网络(DNN)模型,如卷积神经网络CNN和递归神经网络(RNNs),已被证明在从时间序列序列中自动提取特征和学习时间动态方面非常有效[25,40]。在[16]中,研究人员引入了一种自动癫痫检测方法,这种方法对现实生活条件下的噪声具有鲁棒性。他们使用具有时间分布密集层的长短期记忆(LSTM)从EEG信号中自动提取鲁棒特征。在一项预测癫痫发作的模型性能研究中,由[13]进行了全面的比较。有人指出,由CNN和长短期记忆(LSTM)组成的模型在灵敏度和虚警率方面优于(隐马尔可夫模型(HMM)、HMM堆叠去噪自动编码器(SdA)、HMM-LSTM、增量主成分分析(IPCA) -LSTM、CNN多层感知器)。

对于癫痫发作预测,[1]的作者使用由5个卷积层组成的1D-CNN从原始EEG信号进行自动癫痫发作预测。这种方法只在FB数据集[24]上进行了测试。在[18]中,作者提出在将数据馈送到CNN模型之前,对EEG信号使用小波变换(CWT)作为预处理步骤。在[19]中,提出了一种可以在低功率设备上运行的深度学习模型,用于使用从大脑表面获得的颅内EEG信号来执行实时癫痫预测。在使用期内,可以使用用户的数据来自动重新训练所提出的模型,其中在每个月之后,可以使用来自患者的新记录数据来微调该模型。该模型还可以在智能手表上运行,并提供比随机预测器好42%的预测,平均灵敏度为69%。所提供的模型是用户特定的,需要在开始预测之前记录用户2个月的数据,并且对于真实世界的使用来说不够可靠,因为它只对15个患者和一个数据集进行了测试。此外,在保持整个发作前状态进行测试,同时对其余数据进行训练以确保概括的情况下,没有对所有前述方法进行评估。在[36]中,研究人员提供了一种癫痫发作预测的通用方法,其中他们使用只有三层的2D CNN以避免过度拟合。使用短时傅立叶变换(STFT)将EEG信号转换成类似图像的数据,以使其适用于2D CNN。然而,这种方法的主要缺点是它不能模拟信号的时间动态和长期相关性。

2.3泛化方法

研究表明,研究深度网络如何失败并强化其对抗对抗性攻击将有助于更好地理解dnn的工作原理并提高其泛化能力[4,23,29,35]。[15]表明,与生成ae的原始数据相比,ae具有不同的统计分布。这表明ae在统计上不同于生成它们的数据集。在[34]中,作者提出用ae增强训练数据以提高网络的鲁棒性。此外,[14]引入了具有对抗目标函数的训练,与dropout相比,该函数表现为更好的正则化器,并实现了更好的泛化。因此,[33]使用ae训练来提高深度神经网络对噪声和信道变化语音识别的鲁棒性。

总之,现有的方法都没有解决模型对其他大脑活动噪声的鲁棒性和患者癫痫发作预测的差异。

3 所提出的机器学习模型

本文的目的是开发一种适用于从原始脑电信号中自动提取特征、准确检测癫痫发作前状态并对脑电信号中的噪声具有鲁棒性的方法。癫痫发作预测的主要挑战之一是一些发作间期状态类似于发作前状态,如图2所示。可以看出,有时,对一个患者来说似乎是发作前信号的信号可能对另一个患者来说似乎是发作间信号,反之亦然。

 图二 来自CHB-MIT数据集的EEG信号。a)患者(1)在频域和时域中的发作间信号。b)患者(3)在频域和时域中的发作前信号。频域中每个子图的“X”轴表示频率,单位为赫兹,时域中表示时间,单位为秒。两个子图的“Y”轴是以微伏为单位的振幅。

另一个更具挑战性的情况是,发作间状态可能类似于同一患者的发作前状态,如图3所示。

 图3 来自CHB-MIT数据集的EEG信号。a)患者(14)在频域和时域中的发作前信号。b)患者(14)在频域和时域中的发作间信号。频域中每个子图的“X”轴代表以Hz为单位的频率,时域中代表以秒为单位的时间。两个子图的“Y”轴是以伏特为单位的幅度。

图4显示了针对提议的对立示例(AEs)的高级解决方案。图4描述了使用(AEs)进行学习的高级步骤,其中首先使用EEG信号训练建议的模型,然后使用训练的模型生成AEs。然后,将训练数据与AEs相结合,以在扩充数据上重新训练模型。系统的输入包括从颅骨外的皮肤电极(头皮脑电图)和大脑表面的植入电极(颅内脑电图)记录的脑电图信号。该系统的输出是癫痫发作状态预测、发作间期或发作前状态。

3.1数据预处理

采用陷波滤波器对脑电信号进行滤波,去除电力线噪声。Freiburg数据集被50 Hz的电源频率污染,而CHB-MIT数据集被60 Hz的电源频率污染。因此,对于Freiburg数据集和CHB-MIT数据集,频率范围为47–53Hz和97–103Hz以及57–63Hz和117–123Hz的分量分别被移除。

之后,使用z-score对数据进行归一化,以确保所有通道的平均值和单位方差为零。之后,EEG信号用长度为30s的滑动窗口分割,50%重叠以确保平稳性。使用增广的Dickey-Fuller (ADF)测试检查加窗信号的平稳性,这是一种单位根测试,使用自回归模型并优化多个不同滞后值的信息标准[9]。在ADF测试中,我们首先定义了零假设,该假设表明信号可以由单位根来表示,单位根表示信号中的时间相关结构,因此表示其非平稳性。我们指定显著性水平为5%。在对加窗信号应用这种测试方法之后,我们发现所有生成段的p值都显著低于5%。因此,我们拒绝零假设,并得出结论,有足够的证据表明,所产生的部分是稳定的。

3.2 CNN-GRU模型

 图5所示 采用CNN-GRU架构,其中FB和CHB-MIT数据集的批大小为256,脑电信号的窗口长度为7680,通道数分别为6和22。

所提出的模型如图5所示,其简短描述如下:C(f,k,s):用过滤器数量“ f ”、内核大小“k”和步进数量“s”表示卷积层。该模型由卷积层组成,通过叠加多个操作符来创建抽象特征的层次。在处理EEG时间序列时,采用一维卷积运算对时间序列信息进行建模。每个卷积核都充当一个过滤器,过滤掉时间序列数据并检测相关模式。此外,卷积核对多变量信号进行深度滤波,其中每个通道对应的权重在训练阶段被学习,从而通过通道获得最佳的信号集成。

循环层由门控循环单元(gru)组成,对脑电信号的时间依赖性进行建模。gru是一种特殊的循环单元,它具有更新和重置门,允许模型决定保留多少历史信息。该特性使所提出的深度体系结构能够对时间序列的时间动态以及长期依赖关系进行建模。

 3.3对抗性学习

通常,经过良好训练的机器学习模型 f(x:θ)能够捕捉模型的输入 Xi 和输出 Yi 之间的非线性关系,其中 θ 代表模型参数。为了给学习模型提供更好的泛化,我们建议使用用对抗性示例来增强训练数据的想法,以提高模型对对抗性示例以及来自破坏EEG信号的真实生活条件的噪声:肌肉伪影和眨眼的稳健性。

文献中已经表明,最先进的模型很容易对与原始数据略有变化的示例进行错误分类[14]。此外,已证明神经网络的分类决策在高维是线性的,它只需要知道扰动的方向就可以越过分类边界并误导模型预测。因此,我们期望对抗性样本训练方法将有助于模型更好地区分具有较高相似性的不同脑电信号,并降低噪声引起的虚警率。

AES是一种特殊类型的数据,它是通过向原始输入数据添加噪声而生成的,该噪声经过优化以误导模型分类。增加的对抗性噪音是人类感觉不到的。在这篇文章中,我们假设一个白盒设置,在这里我们可以访问模型参数θ。为了生成与模型 f(x':θ)相反的实例X',通过计算关于导致网络到错误分类Yt的输入的梯度来获得少量噪声 σ,如等式所示(1-4)。

图6进一步说明了生成ae的过程。第一步是在真实数据上训练模型 f(x;θ) 通过最小化损失函数        J ( f(x;θ),y) 相对于模型参数 θ 。损失函数J ( f(x;θ),y) )是平均交叉熵。在第二步中,保持模型参数不变,并通过计算相对于输入的梯度来获得所需的噪声′σ′,该噪声将使网络对相应的输出进行错误分类。生成AEs需要找到 x' ,x' = x + σ, 最小化损失函数的选择相应的目标类 yt ,yt ≠ ytrue, ytrue 才是真正的 x 相应的类,M是类的数量,N是批处理的样品数量,是在Eq(5、6)。

L2范数正则化加上Eq.(5)中的损失 J (yt,y^) 用于惩罚优化过程中较大的噪声值,其中 λ 表示最小化噪声的重要性。正则化确保生成的ae接近原始输入。

图6所示。对抗性示例生成方法的框图。输入是一个三维张量[B, W, CH],其中“B”表示批大小,“W”表示脑电信号的窗口长度,“CH”是通道数,对应于用于脑电信号记录的电极数量

4实验与结果

提出的方法通过受试者工作特征曲线(ROC)进行评估,该曲线绘制了所有分类阈值的真阳性率与假阳性率。计算曲线下面积(AUC)、灵敏度和每小时FPR/h假阳性率,量化各模型的性能。为了得到FPR/h,我们进行k-of-n分析,与[36]保持一致,其中对于每n个预测,只有在至少有k个正预测时才会发出警报。在[36]中,k和n的取值分别为8和10。由于数据是用30秒的窗口分割的,所以模型每30秒产生一次预测。如果有告警,35分钟内算作1次告警。

为了与[36]进行公平的比较,对两个数据集的每个患者采用留一发作交叉验证方法。如果患者有N个发作前状态,则在每一叠中保留一个状态进行测试,并使用N-1个发作前状态进行训练。发作间期状态被随机分成N个部分,但每个发作间期状态都比发作前期状态长得多。训练数据是平衡的,使得发展前状态的数量等于发作间期状态的数量。因此,在每一叠中使用N-1个间期状态和N-1个前期状态进行训练,使用一个间隔状态和一个前期状态进行测试。此外,将训练数据分成90%用于训练,10%用于监测模型在每个epoch的学习过程,如图7所示。

 

4.1实验设置

 所有的单任务模型都是使用谷歌的深度学习库Tensor-Flow实现的。我们在一台配备NVIDIA GTX 1080 GPU、英特尔酷睿i7-7700 (3.60 GHz) CPU和32gb内存的PC上运行我们的模型。对于Multitask模型,我们使用了一台配备NVIDIA Tesla T4 GPU、16个vcpu、128 GB RAM的Google Cloud虚拟机。

4.2数据集

为了将我们的结果与[36]得到的结果进行比较,我们遵循相同的数据准备步骤,为两个数据集Freiburg Hospital dataset (FB)[24]和CHB-MIT dataset[31]提取每个患者的发作前和发作间状态。FB数据集包含21例患者的颅内脑电图(iEEG)信号,采用6个通道,采样率为256hz。然而,由于缺乏完整的FB数据集,仅选择了13例患者。CHB-MIT数据集由23名患者的头皮脑电图(sEEG)数据组成。该数据以256hz的采样率为每位患者使用22个通道记录844小时。

在[36]的工作中,间期状态定义为癫痫发作前至少4小时至癫痫发作结束后4小时之间的时间段。多次发作可能彼此紧密地发生,因此癫痫发作前状态与前一次发作间隔小于30min的癫痫发作前状态被视为一次癫痫发作前状态,癫痫发作预测任务成为预测前次癫痫发作的任务。此外,有些患者平均每2小时发作一次,这不足以预测癫痫发作。因此,只考虑每天癫痫发作少于10次的患者。根据这些定义,仅从CHB-MIT和FB数据集中选择了13例患者。癫痫发作前状态被认为是30分钟,在癫痫发作前5分钟结束,让患者有足够的时间采取适当的行动。

 4.3 CNN-GRU模型参数的整定

为了对CNN-GRU模型进行超参数调优,我们采用了与[36]相同的方法,从不同时期选择训练和测试样本,以避免过拟合。具体来说,发作间期和发作前期的后30%的样本被选择用于测试而前70%的数据用于CHB-MIT和FB数据集的训练。架构大小和复杂性的选择都经过仔细检查,以确保模型不会太复杂而过拟合数据,也不会太浅而欠拟合。我们使用AUC度量作为真阳性和假阳性之间平衡的指标。卷积层从(1-6)层变化,核数从(32、64、128、256)中选择。内核大小和步进数量的选择使得每次执行一个步进时过滤器至少重叠30%。从(3,5,7,9,11)中采样核的大小,每个核对应的步长为(1,2,3,4,5),并在每个大小和步长为2的卷积层后进行最大池化操作。可以获得最佳性能的层数为4层,如图8所示。

循环层的数量从(1,2,3)改变,单元的数量从(32,64,128,256)中选择。结果发现,增加1层以上的层数和增加128层以上的单元数并不能提高精度。因此,我们选择了一层128个单元的GRU。

4.4对抗性学习

为了生成对抗性示例,在优化过程中使用Eq.(5,6),并遵循图6所示的方法。此外,对噪声采用L2范数,使其不超过原脑电图信号L2范数的1%。生成的样本由50%的间期和50%的前期组成,因为发作间期状态的信号如[36]中被下采样,以使数据平衡。Eq.(6)中 λ 的最佳值选择0.001,既保证了快速收敛(200步),又保证了有效的脑电信号与原始脑电信号无法区分,如图9所示。在一次发作-遗漏交叉验证期间,只有训练数据在每一叠上增加ae。选择此配置是为了在训练数据增强后测量测试数据上的确切性能。

为了验证声ae增强不会破坏窗口的平稳性,我们运行了增强的Dickey-Fuller (ADF)测试,该测试通常用于检查平稳性。ADF检验表明,所有AE生成片段的p值都显著低于5%,保证了平稳性。

图9所示。用对抗性噪声干扰脑电图前信号分类的实例。“X”轴以秒为单位表示时间,“Y”轴以微伏为单位表示振幅.

4.5结果与讨论

表(1,2)总结了在FB和CHB-MIT数据集上使用AEs增强和不使用AEs增强训练的CNN-GRU基础模型的结果,并与MTL增强方法和现有技术进行了比较[36]。此外,我们将我们提出的ae增强与高斯噪声(GN)的数据增强进行了比较。灵敏度、FPR/h和AUC通过对每个患者的一次发作遗漏交叉验证的折叠数进行平均得到。

可以看出,我们提出的ae增强模型在FB和CHB-MIT数据集上的平均灵敏度分别为83.18%和85.16%,FPR/h分别为0.055和0.06。将我们提出的方法与先前[36]的工作进行比较,我们注意到它在CHB-MIT数据集上的灵敏度提高了3.96%,平均降低了62.2% FPR/h的相对百分比。另一方面,对于FB数据集,我们提出的方法的灵敏度提高了1.8%,平均降低了8% FPR/h的相对百分比。此外,

结果显示,与目前的技术水平相比,CHB-MIT和FB数据集的灵敏度平均标准差显著降低了约2X[36]。还可以注意到,与没有AEs增强的FB数据集相比,所提出的CNN-GRU模型在CHB-MIT数据集上的平均灵敏度更高,FPR/h更低。这些结果是合理的,因为CHB-MIT数据丰富,有22个通道,而FB数据集iEEG信号只有6个通道。

图10。发作前和发作间分类的15号患者嵌入的2D t-SNE可视化FB数据集。a)没有AEs的所提出的CNN-GRU方法的嵌入。b)提出的CNN-GRU方法与AEs的嵌入。

我们现在进一步分析和讨论了CNN-GRU模型在FB和CHB-MIT数据集上对ae增强数据的训练效果。在每个折叠中,只使用训练数据生成3.3节所述的ae,而测试数据保持不变。可以注意到,在用ae增加数据后,大多数患者的敏感性提高了,两个数据集的FPR/h都降低了。对抗性样本的训练可以作为一种正则化器,防止模型过度拟合。从患者14 FB数据集的AUC结果可以看出,在增加ae数据后,AUC从0.72跃升至0.98。在CHB-MIT数据集的患者(2,3,5)和FB数据集的患者(5,15,20)中观察到类似的结果。增强结果的改进也可以从对抗性训练模型的思想来解释示例允许模型为分类任务绘制更鲁棒的边界决策,因为这些示例被明确地精心制作以误导模型预测,同时在视觉上与原始数据无法区分。通过可视化基于原始数据训练的基础模型的嵌入,以及使用t分布随机邻居嵌入(t-SNE)进行AEs增强训练的基础模型的嵌入[21],对这一想法进行了进一步分析,如图10所示。很明显,经过ae增强训练后,两个类有了更好的分离边界。这两个数据集的其他患者也注意到这些结果。用ae增加训练数据的另一个优点是,这有效地增加了训练集的大小,而不需要新的数据。实验结果证明了用ae增强脑电信号数据的有效性,提高了模型的泛化能力

图11所示。在(a) Freiburg和(b) CHB-MIT数据集下,采用AE增强方法的STL的训练样本大小与灵敏度的性能增益.

图12所示。我们提出的带有ae增强的CNN-GRU模型和最先进的谱图方法在所有患者中的AUC性能比较[36]。可以看出,我们提出的方法的结果平均实现了更高的AUC,每个数据集内和两个数据集之间的方差较小

此外,研究所提出的带有AE增强的STL模型的性能如何随不同患者的训练样本量的变化而变化,将是一个有趣的问题。图11 (a)显示,最大样本数为1020的患者的平均表现与最大样本数为765的患者相似。此外,具有510个训练样本的患者比具有更高训练样本计数的数据集中的所有其他患者表现更好。同样,对于CHB-MIT数据集的图11 (b),我们看到500-600个训练样本的患者与1530个样本的患者具有相似的性能。此外,拥有1277个训练样本的患者似乎在所有患者中表现最差,包括那些只有510个训练样本的患者。性能与训练样本数量之间缺乏相关性,这可能表明所提出的模型对输入间期进行了过采样,因此,对于实例数量较少的患者来说,该模型是足够的,并且表现同样良好。

最后,为了比较所有阈值的灵敏度和FPR/h,获得了FB和CHB-MIT数据集的AUC结果。这些结果是在使用大小为256的小批进行50次epoch后获得的。使用所有患者的平均AUC及其方差来比较我们提出的CNN-GRU方法与ae增强和[36]的工作,如图12所示。

总体而言,我们提出的方法在CHB-MIT和FB数据集上的平均AUC分别达到90%和89%,显著高于谱图方法[36]的83.3%和86.2%。此外,我们的AUC结果显示,在每个数据集中,CHB-MIT和FB的AUC范围分别减少了3倍(从0.7到0.23)和2.5倍(从0.5到0.20),患者之间的范围变化较小(患者之间最大和最小AUC值的差异)。结果,我们注意到CHB-MIT和FB患者AUC的平均标准差分别显著降低了2倍和2.5倍,如图6所示。这些结果表明了我们的方法的鲁棒性,它以更少的方差实现了更高的AUC。这是预期的,因为大多数先前提出的癫痫发作预测方法在研究中过度拟合到特定的数据集,并且无法在不同的数据集之间保持一致的结果。

4.6与其他泛化方法的比较

在先前针对癫痫发作检测的工作中,已经表明多任务学习(Multitask Learning, MTL)有助于增强不同患者的训练数据,从而提高灵敏度和FPR/h[38]。我们将ae方法提供的性能增益与基线MTL方法提供的性能增益进行比较。

我们实现了一个与我们在3.2节中提出的模型在架构上相似的MTL模型,该模型由共享CNN层和GRU层组成,以提取不同患者的共同特征,然后为每个患者建立一个完全连接的层。MTL模型输出对多个患者的预测,其中对特定患者的预测被认为是一项任务。在MTL训练的每次批处理迭代中,训练优化共享层和特定于患者数据的GRU层。属于其他患者的其他GRU层在该批处理期间保持不活动状态。在从训练集中的所有患者中提取批次的epoch中,对所有患者重复该过程。

表1和表2分别显示了我们提出的单任务学习(STL)模型不加对抗示例(AE)增强、STL模型加AE增强、MTL模型同时在所有受试者上联合训练的结果。通过检查表1和表2,我们可以看到,就这两个指标而言,我们的AE增强方法在所有患者中平均优于MTL方法。

对于表1中的个体患者,患者21除外,AEs增强法在FPR/h方面优于MTL法,在敏感性方面优于MTL模型,但患者除外(6,17,19,20,21)。对于表2中的个别患者,我们的AEs增强方法在灵敏度和FPR/h方面优于MTL方法,除了患者5。

为了使MTL为不同的任务提供改进,这些任务之间应该存在大部分共享信息;否则,不同任务之间会发生负向信息传递,导致性能下降[30]。我们探讨不同患者之间的相似性,以便深入了解MTL方法在不同患者上的表现。首先从脑电信号中提取两种不同类型的特征:

•手工特征:我们按照[39]中提出的方法提取患者特异性特征,用于癫痫发作预测。

深度学习(DL)嵌入:我们对每个患者进行无AE的STL模型训练。训练后,在输出处得到的特征向量被提取为每个输入样本的特征向量。

在特征提取之后,利用欧氏距离对发作前期和发作间期特征进行K-means聚类。选择的簇数等于数据集中患者的数量。只有当两个患者的发作前期和发作间期特征向量大部分属于同一聚类时,我们才定义两个患者是相关的。

 图13所示。CHB-MIT数据集中使用手工特征的患者大脑活动的相似矩阵。a)临界点前信号的相似矩阵。b)间隔信号的相似矩阵。

图13 (a)和(b)分别显示了CHB-MIT数据集中患者发作前期和发作间期手工特征之间的相似程度。该图显示,大多数患者聚集到单独的集群中,解释了为什么MTL对这些患者的效果不佳。然而,该图并不能解释表2所示患者5 MTL表现良好的原因。

图14所示。使用DL嵌入的CHB-MIT数据集中患者大脑活动的相似矩阵。a)发作前期信号的相似矩阵。b)发作间期的相似矩阵。

图14 (a)和(b)分别显示了CHB-MIT数据集中患者发作前期和发作间期深度学习嵌入特征之间的相似程度。与手工制作的特征相比,这些数字显示不同患者的特征之间有更多的相似性。与手工特征相反,嵌入的相似性解释了为什么MTL模型在表2中对患者5表现良好。然而,它并不能解释为什么,例如,患者21的表现下降,尽管患者5和21与其他患者存在普遍的相似性。

同样,FB数据集显示,在患者之间显示的相似性与他们在MTL模型中的相应表现之间的解释不一致。虽然FB患者的相似性解释了表1所示患者21和19的表现改善,但相似性测量显示患者(6、17、20)独立于其他患者,而表1中他们的表现在敏感性方面有所改善。

我们可以得出结论,使用上述手工制作和深度学习的特征并不能准确反映不同患者之间的关系,因此不能解释MTL模型的性能。对于未来的工作,我们建议探索一种准确、一致地反映不同患者数据之间关系的特征提取方法。

另一种常用的数据增强方法是高斯噪声(GN)增强。GN增强通常用于图像数据,以提高模型的泛化性。在这一部分中,我们比较了我们提出的ae数据增强方法与传统GN增强方法的性能。训练数据用以下标准差的GN增强:0.01,0.001和0.0001。结果如表3所示,其中列类似于训练数据上使用的增强技术,行类似于FB和CHB-MIT数据集上的性能,格式如下:[灵敏度,FPR/h, AUC]。

可以看出,对训练数据进行GN增强后,与未进行增强的原始信号和AE增强相比,性能更差。而且,随着GN标准差的增大,结果会变差。另一方面,AE增强被证明是优越的。

5 结论

在这项工作中,我们提出了一种新的方法,通过对抗性示例(AE)训练来优化分层卷积神经网络(CNN)和门控循环单元(GRU)网络,用于癫痫发作预测。提出的方法旨在解决癫痫发作预测文献的三个主要局限性:(1)不同患者和同一患者数据中,癫痫发作前和正常活动之间的信号差异很大;(2)预测精度仍未达到为避免受影响患者发生危及生命的情况所要求的标准;(3)每位患者的癫痫发作前状态样本标记训练数据数量有限。

在波士顿儿童医院(CHB-MIT)和弗莱堡医院(FB)这两个基准数据集上,所提出的方法在灵敏度、每小时假阳性率(FPR/h)和曲线下面积(AUC)方面,与现有技术水平[36]相比有了显著改进。我们显示,在患者和数据集之间,模型稳健性提高了3倍在AUC变化中。此外,我们发现两个数据集的平均AUC增加了6.7%。最后,我们比较了传统的数据增强方法,包括多任务学习(MTL)和高斯噪声增强,其中所提出的方法在所有指标上都优于这两种基线。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用TIA博途自带的函数实现用户登录并显示用户名的具体方法

使用TIA博途自带的函数实现用户登录并显示用户名的具体方法 本例以TP1200 Comfort精智触摸屏为例进行说明: 如下图所示,打开TIA博途软件,添加一个TP1200触摸屏,找到左侧项目树中的“用户管理”,添加一个用户:abc,密码:1234, 如下图所示,添加一个画面,这里命名为:…

12.JavaWeb-Node.js

1.Node.js的概念 传统的Web服务器中,每个请求都会创建一个线程,这会导致线程数的增加,从而影响服务器的性能和扩展性,Ryan Dahl借助Chrome的V8引擎提供的能力实现了Node.js——可以在服务端运行的JavaScript(可以把Nod…

利用Dockerfile构建带sshd、jdk服务的自定义镜像

什么是Dockerfile? Dockerfile 是一个文本格式的配置文件, 用户可以使用 Dockerfile 来快速创建自定义的镜像 dockerfile 的基本结构 Dockerfile 由一行行命令语句组成,并且支持以 # 开头的注释行。 一般的,Dockerfile 分为四部分&#…

TypeScript 5.1发布,新功能更新

文章目录 1:返回类型增加undefined2:getter可以设置和 setter 的不相关类型3:对 JSX 元素和 JSX 标签的异步支持4:支持命名空间属性名称 JSX5:typeRoots在模块更新6:JSX 标签的链接游标7:param …

PHP:查询数据库,并将数据传给前端(在script中直接嵌套php语句)

例子&#xff1a;在php中定义数据&#xff0c; 并将数据通过js在控制台输出 <script><?php// 在这里插入你的PHP代码&#xff0c;例如执行查询操作获取数据$data array(array(name > Alice, age > 25),array(name > Bob, age > 30),array(name > Ch…

4.39ue4:ue4表格设置、读取

1.创建表格&#xff0c;内容浏览器&#xff0c;右键&#xff0c;其他&#xff0c;数据表格&#xff0c;下拉选择一个数据结构类型的起始项。 2.被选择的数据结构将以表格的形式列出数据。 3.使用方式&#xff1a; i: 输出一行数据&#xff08;text&#xff09; ii&#xff…

SparkSQL的数据结构DataFrame构建方式(Python语言)

SparkSQL 是Spark的一个模块, 用于处理海量结构化数据&#xff0c;其提供了两个操作SparkSQL的抽象&#xff0c;分别是DataFrame和DataSet&#xff0c;spark2.0之后&#xff0c;统一了DataSet和DataFrame&#xff0c;以后只有DataSet。 以Python、R语言开发Spark&#xff0c;使…

SpringBoot 的 概念、创建和运行

目录 1.什么是Spring Boot&#xff1f; 为什么要学Spring Boot&#xff1f; SpringBoot的优点 Spring Boot 项目创建 前置工作&#xff1a;配置国内源 使用 idea 创建 Spring Boot 项目 网页版创建&#xff08;了解&#xff09; 拓展&#xff1a;删除 项目中无用的目录和…

quiche编译

netty http3使用了rust语言的quiche&#xff0c;quiche使用了c语言的boringssl&#xff0c; 网上没有找到编译好的quiche&#xff0c;只能自己搭建rust环境编译 1、rust安装 见官网https://www.rust-lang.org/tools/install 我是用的是windows的ubuntu&#xff0c;所以直接使…

web学习--maven--项目管理工具

写在前面&#xff1a; 这学期搞主攻算法去了&#xff0c;web的知识都快忘了。开始复习学习了。 文章目录 maven介绍功能介绍maven安装jar包搜索仓库 pom文件项目介绍父工程依赖管理属性控制可选依赖构建 依赖管理依赖的传递排除依赖可选依赖 maven生命周期分模块开发模块聚合…

debian linux安装配置企业私有网盘

一、适用环境 1、中小型企业的某些部门之间经常要进行数据的交换与共享时&#xff0c;则可使用企业内部专业的服务器&#xff0c;把剩余的硬盘存储容量配置成为共享网盘的形式&#xff0c;供部门之间进行数据交换。 2、可将多个硬盘通过debian Linux系统组成软阵列的1个逻辑盘…

【Matlab】神经网络遗传算法(BP-GA)函数极值寻优——非线性函数求极值

目前关于神经网络遗传算法函数极值寻优——非线性函数求极值的博客资源已经不少了&#xff0c;我看了下来源&#xff0c;最初的应该是来自于Matlab中文论坛&#xff0c;论坛出版的《MATLAB神经网络30个案例分析》第4章就是《神经网络遗传算法函数极值寻优——非线性函数极值寻优…