CN109998536A - 一种基于支持向量机的癫痫检测集成电路及其训练方法 - Google Patents
一种基于支持向量机的癫痫检测集成电路及其训练方法 Download PDFInfo
- Publication number
- CN109998536A CN109998536A CN201910245466.0A CN201910245466A CN109998536A CN 109998536 A CN109998536 A CN 109998536A CN 201910245466 A CN201910245466 A CN 201910245466A CN 109998536 A CN109998536 A CN 109998536A
- Authority
- CN
- China
- Prior art keywords
- sample
- module
- input
- support vector
- error
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- A—HUMAN NECESSITIES
- A61—MEDICAL OR VETERINARY SCIENCE; HYGIENE
- A61B—DIAGNOSIS; SURGERY; IDENTIFICATION
- A61B5/00—Measuring for diagnostic purposes; Identification of persons
- A61B5/24—Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
- A61B5/30—Input circuits therefor
-
- A—HUMAN NECESSITIES
- A61—MEDICAL OR VETERINARY SCIENCE; HYGIENE
- A61B—DIAGNOSIS; SURGERY; IDENTIFICATION
- A61B5/00—Measuring for diagnostic purposes; Identification of persons
- A61B5/24—Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
- A61B5/316—Modalities, i.e. specific diagnostic methods
-
- A—HUMAN NECESSITIES
- A61—MEDICAL OR VETERINARY SCIENCE; HYGIENE
- A61B—DIAGNOSIS; SURGERY; IDENTIFICATION
- A61B5/00—Measuring for diagnostic purposes; Identification of persons
- A61B5/24—Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
- A61B5/316—Modalities, i.e. specific diagnostic methods
- A61B5/369—Electroencephalography [EEG]
-
- A—HUMAN NECESSITIES
- A61—MEDICAL OR VETERINARY SCIENCE; HYGIENE
- A61B—DIAGNOSIS; SURGERY; IDENTIFICATION
- A61B5/00—Measuring for diagnostic purposes; Identification of persons
- A61B5/40—Detecting, measuring or recording for evaluating the nervous system
- A61B5/4076—Diagnosing or monitoring particular conditions of the nervous system
- A61B5/4094—Diagnosing or monitoring seizure diseases, e.g. epilepsy
Landscapes
- Health & Medical Sciences (AREA)
- Life Sciences & Earth Sciences (AREA)
- Heart & Thoracic Surgery (AREA)
- Medical Informatics (AREA)
- Physics & Mathematics (AREA)
- Veterinary Medicine (AREA)
- Biophysics (AREA)
- Pathology (AREA)
- Engineering & Computer Science (AREA)
- Biomedical Technology (AREA)
- Public Health (AREA)
- General Health & Medical Sciences (AREA)
- Molecular Biology (AREA)
- Surgery (AREA)
- Animal Behavior & Ethology (AREA)
- Neurology (AREA)
- Neurosurgery (AREA)
- Physiology (AREA)
- Psychiatry (AREA)
- Psychology (AREA)
- Complex Calculations (AREA)
- Measurement And Recording Of Electrical Phenomena And Electrical Characteristics Of The Living Body (AREA)
Abstract
本发明公开一种基于支持向量机的癫痫检测集成电路及其训练方法,在特征提取部分使用分布式查找表滤波器,降低了电路复杂度;增加频域方差特征,能够更好地反应脑电信号特征,提高了检测精度;使用改进版本的序贯最小化算法进行支持向量机训练电路的设计,避免原始版本的序贯最小化算法寻找不满足最优条件的拉格朗日乘子时产生的误判,可以使用更少的迭代次数达到相似性能,进一步提高了能效。同时通过将核函数计算模块进行流水线设计,提高了片上支持向量机的训练速度。本发明可以提高癫痫检测系统的便携性,提供更高能效的片上训练功能。
Description
技术领域
本发明属于集成电路技术领域,具体涉及一种基于支持向量机的癫痫检测集成电路及其训练方法。
背景技术
大脑神经元异常放电会引发癫痫,对人的生活健康影响严重。头皮无创式脑电图,在癫痫发作诊断中扮演着重要的角色。然而,目前主要依靠医生对患者的脑电信号进行人工分析,这种方法不仅耗时,而且没有统一的判断依据,无法保证其准确性。随着医疗电子技术的不断发展,人工智能算法开始被应用在癫痫的自动诊断过程中,然而大部分的算法需要在计算机上实现,仍然不够方便。因此,将人工智能学习算法集成在电路上,使整个自动诊断系统可便携,并且可针对脑电信号状态的改变重新学习,对提高病人的日常生活质量有很重要的意义。
支持向量机学习方法适用性较广、精度较高,可以针对不平衡的数据集使用,因此在便携式癫痫自动诊断系统中被采用。支持向量机方法作为全监督的分类方法,可以分为训练与分类两个过程:在训练过程中,利用标记好的样本集,寻找处于样本集边界上的特征向量作为支持向量,在分类过程中使用支持向量对输入样本进行分类。训练支持向量机是解决标准的二次规划问题,然而在数据量较大时,计算复杂度高、需要较高的能耗和较大的存储空间,因此在芯片上实时低功耗地训练有一定的难度。较为常用的是序贯最小化算法训练支持向量机,改进版本的序贯最小化算法能进一步加速训练过程、降低功耗。
使用支持向量机方法,需要先对脑电信号进行特征提取以得到特征向量。使用带通滤波器对脑电信号进行频域滤波,然后计算频域能量,是一种常用的特征提取方法。然而通带较窄的带通滤波器的电路复杂度高;另外,频域能量仅能反应信号的一个方面,需要更多的特征对脑电信号进行表征。
经过对现有资料文献的检索发现,现有的基于支持向量机的便携式癫痫自动诊断集成电路系统,滤波器实现较为复杂,且频域特征普遍仅有能量值,不能反应信号的变化范围,另外普遍不具备支持向量机的训练功能。
发明内容
本发明针对上述现有技术的不足,提出了一种基于支持向量机的癫痫检测集成电路,降低了电路复杂度,提高了检测精度。
本发明是通过以下技术方案来实现:
一种基于支持向量机的癫痫检测集成电路,包括特征提取模块和支持向量机;
特征提取模块用于获取训练样本,并将获取的训练样本输入至支持向量机;
支持向量机包括控制调度模块、误差更新模块、样本选择模块、核函数计算模块和拉格朗日乘子优化模块;
所述样本选择模块,用于选择不满足KKT条件的样本,将样本对应的拉格朗日乘子输送至拉格朗日乘子优化模块;
所述拉格朗日乘子优化模块,用于对不满足KKT条件的样本的拉格朗日乘子进行优化,并将优化后的样本输入误差更新模块;
所述误差更新模块,用于更新所有优化后样本的预测误差Fi,然后对优化后样本子集边界进行更新,直至所有样本满足KKT条件时结束;
核函数计算模块,用于加速拉格朗日乘子优化模块和误差更新模块的核函数计算过程;
控制调度模块,用于控制支持向量机的片上训练过程。
优选的,所述特征提取模块包括滤波器模块和特征计算模块;
滤波器模块,用于对输入的脑电信号进行滤波计算,并将得到的滤波后的脑电信号x[i]输入至特征计算模块,脑电信号x[i]如下;
其中,EEGb[p]代表第p个EEG脑电信号的第b位,C[p]为滤波器参数;
特征计算模块包括方差计算电路和均值计算电路,分别用于计算滤波后的脑电信号x[i]的均值mean与方差值variance,得到一个多维特征向量,并将得到的多维特征向量作为样本输入至支持向量机;
脑电信号x[i]的均值如下;
其中,l表示滤波后信号的长度;
脑电信号x[i]的方差值如下;
优选的,所述特征提取模块包括8个滤波器模块和8特征计算模块;输入的脑电信号分为8个频段,分别输入至8个滤波器模块中进行滤波,每个滤波器模块连接一个特征计算模块,8特征计算模块共得到16个特征,作为16维的特征向量输入至支持向量机。
优选的,所述滤波器为分布式查找表滤波器。
优选的,所述样本选择模块包括多路分配器DEMUX1、多路选择器MUX1、第一中断生成电路,以及寄存器BL、寄存器BU、寄存器IL和寄存器IU;第一中断生成电路包括比较器COM1和比较器COM2;
多路分配器DEMUX1的输入端输入误差Fi2,其0端输出与比较器COM1的负端输入连接,1端输出与比较器COM2的正端输入连接;
多路选择器MUX1的0端输入与寄存器IL连接,其1端输入与寄存器IU连接,多路选择器MUX1的输出选中的样本地址i1;
比较器COM1正端输入与寄存器BL连接,比较器COM2负端输入与寄存器BU连接;比较器COM1和比较器COM2输出中断信号INT1给控制调度模块;
寄存器BL和寄存器BU分别存储样本子集边界blow和bup,寄存器IL和寄存器IU分别存blow和bup对应的下标地址ilow和iup。
优选的,所述拉格朗日乘子优化模块包括拉格朗日乘子存储器、αi2优化电路、αi1优化电路和第二中断生成电路;
其中,αi1表示为样本i1的拉格朗日乘子,αi2表示为样本i2的拉格朗日乘子;
拉格朗日乘子存储器存储样本对应的拉格朗日乘子αi;αi2优化电路输入端分别与核函数计算模块和拉格朗日乘子存储器连接,αi2优化电路输出优化后的αi2 new写入拉格朗日存储器,以及输出αi2的改变量Δαi2到αi1优化电路和第二中断生成电路;
αi1优化电路接收αi2优化电路输出的改变量Δαi2,并从拉格朗日乘子存储器读取αi1 old,对拉格朗日乘子αi1进行优化,得到优化后的αi1写入拉格朗日存储器,最后输出αi1的改变量Δαi1;
第二中断生成电路生成INT2信号输入控制调度模块,控制调度模块根据INT2信号判断状态转移。
优选的,所述核函数计算模块包括乘法器MUL1—MULn、加法器ADD2—ADDn、样本存储器XMem[1]—XMem[n]、XiReg[1]—XiReg[n]和XjReg[1]—XjReg[n];
在为拉格朗日乘子优化模块计算核函数时,乘法器MULdm交替输入样本存储器XMem[dm]和样本寄存器XiReg[dm],样本存储器XMem[dm]和样本寄存器XjReg[dm];
在为误差更新模块计算核函数时,乘法器MULdm输入XiReg[dm]和XjReg[dm];
ADD2—ADDn顺次相连,ADDn输出核函数Ki,j=XiXj;
其中,X表示为样本,i和j分别为样本的下标。
优选的,所述误差更新模块包括乘法器MUL0、加法器ADD1、寄存器Temp、误差存储器以及第三中断生成电路;
其中,乘法器MUL0依次接收核函数计算模块计算出的核函数Ki,i1和Ki,i2,核函数Ki,i1与拉格朗日乘子优化模块计算出的yi1Δαi1相乘,核函数Ki,i2与拉格朗日乘子优化模块计算出的yi2Δαi2相乘,输出连接ADD1;ADD1第一次输出中间结果存入寄存器Temp,第二次输出更新后的误差Fi new,写入误差存储器,并输入第三中断生成电路,判断是否满足KKT条件,输出中断信号INT3。
优选的,所述支持向量机采用基于改进版本的序贯最小化算法完成片上训练过程。
本发明还提供了一种基于支持向量机的癫痫检测集成电路的片上训练方法,包括以下步骤;
步骤1、将脑电信号分为若干个频段,然后将若干个频段的脑电信号对应输入至若干个滤波器中进行滤波,得到滤波后的脑电信号x[i];
步骤2、将得到若干个滤波后的脑电信号对应输入至若干个特征计算模块,计算滤波后的脑电信号x[i]的均值mean与方差值variance,得到一个多维特征向量,并将得到的多维特征向量作为样本输入至支持向量机;
步骤3、将样本分为五个子集:I0={i:0<αi<C},I1={i:yi=+1,αi=0},I2={i:yi=-1,αi=C},I3={i:yi=+1,αi=C},I4={i:yi=-1,αi=0};
其中,C是可设定的常数,上集合为I0∪I1∪I2,标签值记为0,下集合为I0∪I3∪I4标签值记为1,上集合所对应的预测误差Fi中最小的误差记为bup,下集合所对应的预测误差中最大的误差记为blow,bup和blow对应地址记为iup和ilow;
步骤4.初始化拉格朗日乘子αi为0,预测误差Fi为负的样本标签(-yi);
步骤5.样本选择模块选择不满足式KKT最优条件的样本i2,KKT最优条件如下:
i∈I0∪I1∪I2,and Fi≥blow-τ,i∈I0∪I3∪I4,and Fi≤bup+τ
其中,τ=2-10是允许的误差;样本i2对应的样本i1如下:
i1=iup,if i2∈I0∪I3∪I4
i1=ilow,if i2∈I0∪I1∪I2
步骤6.拉格朗日乘子优化模块更新步骤5所选的样本i2对应的拉格朗日乘子αi2,得到更新后的更新方法如下;
其中η=2Ki1i2–Ki1i1–Ki2i2;L和H限制αi2的有效范围;
对所选的样本i2对应样本i1的拉格朗日乘子αi1进行更新,得到更新后的
步骤7.更新模块更新所有i∈I0的预测误差Fi,得到更新后的
在更新完误差Fi后,更新bup、blow、iup和ilow;若blow–bup≥τ,则令αi1=iup、αi2=ilow,返回步骤6;否则i∈I0的样本满足优化条件,返回步骤5,直至整个集合上的样本都满足KKT最优条件后训练结束。
与现有技术相比,本发明具有以下有益的技术效果:
本发明提供的一种基于支持向量机的癫痫检测集成电路,在特征提取部分使用分布式查找表滤波器,降低了电路复杂度;增加频域方差特征,能够更好地反应脑电信号特征,提高了检测精度;使用改进版本的序贯最小化算法进行支持向量机训练电路的设计,避免原始版本的序贯最小化算法寻找不满足最优条件的拉格朗日乘子时产生的误判,可以使用更少的迭代次数达到相似性能,进一步提高了能效。同时通过将核函数计算模块进行流水线设计,提高了片上支持向量机的训练速度。
附图说明
图1为本发明电路结构框图;
图2为本发明特征提取部分的结构框图;
图3为本发明滤波器模块图;
图4为本发明特征计算模块图;
图5为本发明的支持向量机部分的结构框图;
图6为本发明控制调度模块状态转移图;
图7为本发明样本选择模块图;
图8为本发明拉格朗日乘子优化模块图;
图9为本发明误差更新模块图;
图10为本发明核函数计算模块图。
具体实施方式
下面结合附图对本发明做进一步的详细说明,所述是对本发明的解释而不是限定。
参见图1,一种基于支持向量机的癫痫检测集成电路,包括特征提取和支持向量机两大部分。由特征提取部分对脑电信号进行处理,得到特征向量;由支持向量机部分对特征向量进行训练与分类,得到检测结果。
参阅图2,本发明的特征提取部分包括八个滤波器模块和与八个特征计算模块,每一个滤波器模块连接一个特征计算模块。
其中,八个滤波器模块的结构相同,分别为八个不同通带的带通滤波器,用于将脑电信号在频域分为8个频段;八个特征计算模块分别用于计算8个频段脑电信号的均值与方差,得到16维的特征向量。
参阅图3,滤波器模块的滤波计算过程具体如下,由于8个滤波器模块结构相同,因此仅以其中一个滤波器模块为例进行说明。
分布式查找表滤波器采用以下方法完成滤波计算,具体如下:
其中,EEGb[p]代表第p个EEG脑电信号的第b位,C[p]为滤波器参数。根据查找表完成乘积C[p]×EEGb[p],再将16位脑电信号每一位对应的乘积相加,得到最终滤波后的脑电信号x[i]=C×EEG。
继续参阅图4,将以上得到的滤波后的脑电信号x[i]=C×EEG输入至对应滤波器模块连接的特征计算模块,得到脑电波的均值与方差值,由于8个特征计算模块结构相同,因此仅以其中一个特征计算模块为例进行说明,具体计算方法如下;
特征计算模块包括均值计算电路和方差计算电路;
均值计算电路根据完成长度为2秒的脑电信号经过滤波后的均值的计算,其中l表示滤波后信号的长度;
方差计算电路根据计算信号方差。
8个特征计算模块总共产生16个特征,将16维特征向量作为样本输入至支持向量机进行学习与分类,以完成癫痫检测。
请继续参阅图5,本发明的支持向量机包括控制调度模块、样本选择模块、拉格朗日乘子优化模块、误差更新模块和核函数计算模块。
支持向量机的向量维数为16维,数据类型为有符号16位定点数,其中符号位1位,整数部分7位,小数部分8位。
控制调度模块控制用于完成基于改进版本的序贯最小化算法对支持向量机的片上训练过程。
核函数计算模块用于计算16维特征向量;
拉格朗日乘子优化模块用于计算样本对应的拉格朗日乘子数据;
误差更新模块用于计算误差;
继续参阅图6,图6为控制调度模块的状态转移图。控制调度模块为有限状态机,该模块共有五个状态:初始状态,样本选择状态,乘子优化状态,误差更新状态,结束状态。各状态根据其他模块的反馈信息进行切换。
初始化完成后,进入样本选择状态;样本选择状态下,使用计数器得到样本地址,以遍历整个样本集,直到找到不满足最优条件的样本,进入乘子优化状态,如果无法找到则说明样本集已优化完成,训练结束;乘子优化存在无法成功优化的情况(乘子的改变量小于预定值),则需返回样本选择状态,若成功优化,则进入误差更新状态;误差更新出新的样本子集边界后,判断子集是否满足最优条件,不满足则进入乘子优化状态优化边界对应的乘子,直至满足局部最优条件后,再进入样本选择状态,在整个集合上寻找不满足最优条件的样本;当整个集合上的样本都满足最优条件后训练结束,进入结束状态。
根据样本的标记yi的值和样本对应的拉格朗日乘子αi的大小,将训练样本分为五个子集:I0={i:0<αi<C},I1={i:yi=+1,αi=0},I2={i:yi=-1,αi=C},I3={i:yi=+1,αi=C},I4={i:yi=-1,αi=0}。
其中C是可设定的常数。上集合为I0∪I1∪I2,标签值记为0,下集合为I0∪I3∪I4标签值记为1。上集合所对应的预测误差Fi中最小的误差记为bup,下集合所对应的预测误差中最大的误差记为blow,对应地址记为iup和ilow。
具体改进版本的序贯最小化算法步骤如下:
步骤1.初始化拉格朗日乘子αi为0,预测误差Fi为负的样本标签(-yi)。
步骤2.选择不满足式(1)所示KKT(Karush-Kuhn-Tucker)最优条件的样本i2:
i∈I0∪I1∪I2,and Fi≥blow-τ,i∈I0∪I3∪I4,and Fi≤bup+τ(1)
其中,τ=2-10是允许的误差,对应的样本i1根据式(2)确定:
如果所有的样本满足KKT条件,则算法终止。
步骤3.根据式(3)和(4)更新所选择的样本i2对应的拉格朗日乘子αi2。
其中,η=2Ki1i2–Ki1i1–Ki2i2;L和H限制αi2的有效范围,通过式(5)和(6)计算:
拉格朗日乘子αi1通过式(7)进行更新:
步骤4.根据式(8)更新所有i∈I0的预测误差Fi。
在更新完误差Fi后,根据定义更新bup、blow、iup和ilow。若blow–bup≥τ,则令αi1=iup、αi2=ilow,返回步骤3继续更新;否则i∈I0的样本满足优化条件,返回步骤2寻找新的样本进行更新,直至整个集合上的样本都满足最优条件后训练结束。
图7为所述样本选择模块,是指根据改进的序贯最小化算法,利用样本子集的边界,对样本的优化特性进行判断,选择不满足KKT条件的样本,将其对应的拉格朗日乘子送入拉格朗日乘子优化模块进行优化。
该模块包括寄存器BL、BU、IL、IU,多路分配器DEMUX1、多路选择器MUX1,比较器COM1和比较器COM2组成第一中断生成电路。
寄存器BL、BU、IL和IU分别存储样本子集边界blow、bup、ilow和iup。DEMUX1的输入端接误差Fi2,0端输出接COM1的负端输入,1端输出接COM2的正端输入。多路选择器MUX1的0端输入接样本边界地址寄存器IL,1端输入接寄存器IU,输出选中的样本地址i1。COM1正端输入边界寄存器BL,COM2负端输入边界寄存器BU;COM1和COM2输出中断信号INT1给控制调度模块。
根据控制调度模块计数器的值i2,从误差存储器中读取误差数据Fi2,以及Fi2所属样本子集的标签(0代表上集合,1代表下集合);误差数据Fi2输入DEMUX1(多路分配器),标签控制DEMUX1选通:若样本属于上集合,则通过COM1(比较器)比较Fi2与寄存器BL中的值大小,反之,若样本属于下集合,通过COM2与寄存器BU中的值比较大小,BL、BU分别存储下集合与上集合误差边界的值;
COM1与COM2构成中断生成电路,输出为中断信号INT1(为0代表第i2个样本满足最优条件,为1代表不满足),控制调度模块根据INT1的值判断样本选择状态的切换方向。
参见图8,所述拉格朗日乘子优化模块包括拉格朗日乘子存储器、αi2优化电路、αi1优化电路和第二中断生成电路。
拉格朗日乘子存储器存储样本对应的拉格朗日乘子;αi2优化电路输入端接核函数计算模块和从拉格朗日乘子存储器读取数据,输出优化后的αi2 new写入拉格朗日存储器,以及输出Δαi2到αi1优化电路和第二中断生成电路;αi1优化电路接收αi2优化电路输出的Δαi2,从拉格朗日乘子存储器读取αi1 old,和将优化后的αi1写入拉格朗日存储器,最后输出Δαi1;第二中断生成电路生成INT2信号供控制调度模块判断状态转移使用。
αi2优化电路接收核函数计算模块计算出的核函数Ki1i2、Ki1i1、Ki2i2,并从拉格朗日乘子存储器中读取旧的αi2,进行αi2的优化,再将优化后的αi2写入拉格朗日乘子存储器,同时计算αi2的改变量Δαi2,供αi1优化电路、第二中断生成电路和误差更新模块使用;αi1优化电路接收Δαi2,并从拉格朗日乘子存储器中读取旧的αi1,完成αi1的优化,再将优化后的αi1写入拉格朗日乘子存储器,同时计算αi1的改变量Δαi1,供误差更新模块使用;中断生成电路2根据αi2的改变量Δαi2绝对值的大小,判断优化是否成功,输出中断信号INT2,为0代表优化成功,1代表失败。
所述αi2优化电路,根据式(3)-(6)完成αi2的优化。
所述αi1优化电路,根据式(7)完成αi1的优化。
所述第二中断生成电路通过判断Δαi2绝对值的大小,决定中断信号INT2的值。若Δαi2的绝对值小于寄存器τ的值,则中断信号INT2为1,表示拉格朗日乘子优化失败,由控制调度模块控制状态转移,进入样本选择状态继续寻找样本;若Δαi2的绝对值大于寄存器τ的值,则中断信号INT2为0,表示拉格朗日乘子优化成功,由控制调度模块控制状态转移,进入误差更新状态。
参见图9,所述误差更新模块包括乘法器MUL0、加法器ADD1、寄存器Temp、误差存储器以及第三中断生成电路。
其中,乘法器MUL0依次输入由核函数计算模块计算出的核函数Ki,i1和Ki,i2,与由拉格朗日乘子优化模块计算出的yi1Δαi1和yi2Δαi2依次相乘,输出连接ADD1;ADD1第一次输出中间结果存入寄存器Temp,第二次输出更新后的误差Fi new,写入误差存储器,并输入第三中断生成电路,判断是否满足KKT条件,输出中断信号INT3。
所述误差更新模块根据式(8),完成误差的更新。由核函数计算模块读入的Ki,i1、Ki,i2,i∈I0∪{i1,i2},依次输入乘法器MUL0,与由拉格朗日乘子优化模块读入的yi1Δαi1、yi2Δαi2依次相乘;得到的yi1Δαi1Ki,i1与Fi old通过ADD1相加,结果存入寄存器Temp;yi2Δαi2Ki,i2再接下来与Temp中的值相加,完成式(6)的计算得到更新后的误差Fi new,写入误差存储器,并输入第三中断生成电路,完成中断信号INT3的判断和样本上下误差集合的边界blow和bup的更新。若blow-bup<τ则INT3为1,表示i∈I0∪{i1,i2}的样本满足最优条件,通过控制调度模块将操作状态转移至样本选择状态;反之INT3为0,表示i∈I0∪{i1,i2}对应的样本仍未满足最优条件,状态转移至乘子优化状态,继续优化blow和bup和对应的αilow和αiup。
参见图10,所述核函数计算模块包括乘法器MUL1—MUL16、加法器ADD2—ADD16、样本存储器XMem[1]—XMem[16]、样本寄存器XiReg[1]—XiReg[16]和XjReg[1]—XjReg[16]。
乘法器MULdm输入XMem[dm]和XiReg[dm],XMem[dm]和XjReg[dm]或XiReg[dm]和XjReg[dm];MUL16输入XMem[16]和XiReg[16],XMem[16]和XjReg[16]或XiReg[16]和XjReg[16]的值,输出连ADD16;ADD2—16顺次相连,ADD16输出核函数Ki,j=XiXj。
核函数计算模块完成核函数Ki,j的计算过程。所使用的样本向量为16维,因此Ki,j=Xi[1]Xj[1]+Xi[2]Xj[2]+…+Xi[d]Xj[d]+…+Xi[16]Xj[16],d∈Z+,1≤d≤16。在XMem[d]中存储Xi[d],i∈I0;在XiReg[d]中存储Xi1[d];在XjReg[d]中存储Xi2[d]。核函数计算模块在误差更新状态下使用以加速电路计算式(6)。
在误差更新状态下,需要计算Ki,i1和Ki,i2以计算式(6),更新误差Fi,i∈I0∪{i1,i2}。由于有多个误差需要更新,计算量较大、耗时较长,因此将核函数计算模块设计为ADD2—ADD16组成的流水线,来加速众多Fi的更新过程。以下以流水线前两级(MUL1和MUL2)的前五个时钟周期说明流水线的操作过程:
第一个时钟周期:MUL1输出Xi[1]Xi1[1];
第二个时钟周期:MUL1输出Xi[1]Xi2[1];MUL2输出Xi[2]Xi1[2],并通过ADD2,与上一周期MUL1输出的Xi[1]Xi1[1]相加,得到Xi[1]Xi1[1]+Xi[2]Xi1[2];
第三个时钟周期:MUL1输出Xi+1[1]Xi1[1];MUL2输出Xi[2]Xi2[2],并通过ADD2,与上一周期MUL1输出的Xi[1]Xi2[1]相加,得到Xi[1]Xi2[1]+Xi[2]Xi2[2];
第四个时钟周期:MUL1输出Xi+1[1]Xi2[1];MUL2输出Xi+1[2]Xi1[2],并通过ADD2,与上一周期MUL1输出的Xi+1[1]Xi1[1]相加,得到Xi+1[1]Xi1[1]+Xi+1[2]Xi1[2];
第五个时钟周期:MUL1输出Xi+2[1]Xi2[1];MUL2输出Xi+1[2]Xi2[2],并通过ADD2,与上一周期MUL1输出的Xi+1[1]Xi2[1]相加,得到Xi+1[1]Xi2[1]+Xi+1[2]Xi2[2]。
由以上五个周期可以看到,ADD2交替输出Xi,i∈I0∪{i1,i2}前两维与Xi1、Xi2前两维的点乘结果;ADD3—ADD16的输出类似ADD2,但是增加了维数,ADD16输出总共16维的点乘结果,交替得到Xi,i∈I0∪{i1,i2}与Xi1、Xi2的完整点乘结果。即每个时钟周期输出一个核函数值。
本发明提供的一种基于支持向量机的癫痫检测集成电路,包括特征提取和支持向量机两大部分。其中特征提取包括滤波器模块和特征计算模块。滤波器模块将脑电信号等频率间隔滤波,特征计算模块根据滤波后的信号计算特征,得到特征向量供支持向量机使用。支持向量机包括控制调度模块,样本选择模块,拉格朗日乘子优化模块,误差更新模块,核函数计算模块。控制调度模块基于训练算法,根据其余各模块的反馈信息,控制整个电路的训练过程。样本选择模块通过样本子集的边界寻找不满足优化条件的样本,交由拉格朗日乘子优化模块更新样本对应的拉格朗日乘子,再用误差更新模块计算拉格朗日乘子更新后的误差,为继续寻找不满足优化条件的样本做准备。核函数计算模块用来加速拉格朗日乘子优化模块和误差更新模块的计算过程。整个过程迭代多次,在所有样本满足最优条件时停止。本发明可以提高癫痫检测系统的便携性,提供更高能效的片上训练功能。
以上内容仅为说明本发明的技术思想,不能以此限定本发明的保护范围,凡是按照本发明提出的技术思想,在技术方案基础上所做的任何改动,均落入本发明权利要求书的保护范围之内。
Claims (10)
1.一种基于支持向量机的癫痫检测集成电路,其特征在于,包括特征提取模块和支持向量机;
特征提取模块用于获取训练样本,并将获取的训练样本输入至支持向量机;
支持向量机包括控制调度模块、误差更新模块、样本选择模块、核函数计算模块和拉格朗日乘子优化模块;
所述样本选择模块,用于选择不满足KKT条件的样本,将样本对应的拉格朗日乘子输送至拉格朗日乘子优化模块;
所述拉格朗日乘子优化模块,用于对不满足KKT条件的样本的拉格朗日乘子进行优化,并将优化后的样本输入误差更新模块;
所述误差更新模块,用于更新所有优化后样本的预测误差Fi,然后对优化后样本子集边界进行更新,直至所有样本满足KKT条件时结束;
核函数计算模块,用于加速拉格朗日乘子优化模块和误差更新模块的核函数计算过程;
控制调度模块,用于控制支持向量机的片上训练过程。
2.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述特征提取模块包括滤波器模块和特征计算模块;
滤波器模块,用于对输入的脑电信号进行滤波计算,并将得到的滤波后的脑电信号x[i]输入至特征计算模块,脑电信号x[i]如下;
其中,EEGb[p]代表第p个EEG脑电信号的第b位,C[p]为滤波器参数;
特征计算模块包括方差计算电路和均值计算电路,分别用于计算滤波后的脑电信号x[i]的均值mean与方差值variance,得到一个多维特征向量,并将得到的多维特征向量作为样本输入至支持向量机;
脑电信号x[i]的均值如下;
其中,l表示滤波后信号的长度;
脑电信号x[i]的方差值如下;
。
3.根据权利要求2所述基于支持向量机的癫痫检测集成电路,其特征在于,所述特征提取模块包括8个滤波器模块和8特征计算模块;输入的脑电信号分为8个频段,分别输入至8个滤波器模块中进行滤波,每个滤波器模块连接一个特征计算模块,8特征计算模块共得到16个特征,作为16维的特征向量输入至支持向量机。
4.根据权利要求2所述基于支持向量机的癫痫检测集成电路,其特征在于,所述滤波器为分布式查找表滤波器。
5.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述样本选择模块包括多路分配器DEMUX1、多路选择器MUX1、第一中断生成电路,以及寄存器BL、寄存器BU、寄存器IL和寄存器IU;第一中断生成电路包括比较器COM1和比较器COM2;
多路分配器DEMUX1的输入端输入误差Fi2,其0端输出与比较器COM1的负端输入连接,1端输出与比较器COM2的正端输入连接;
多路选择器MUX1的O端输入与寄存器IL连接,其1端输入与寄存器IU连接,多路选择器MUX1的输出选中的样本地址i,;
比较器COM1正端输入与寄存器BL连接,比较器COM2负端输入与寄存器BU连接;比较器COM1和比较器COM2输出中断信号INT1给控制调度模块;
寄存器BL和寄存器BU分别存储样本子集边界blow和bup,寄存器IL和寄存器IU分别存blow和bup对应的下标地址ilow和iup。
6.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述拉格朗日乘子优化模块包括拉格朗日乘子存储器、αi2优化电路、αi1优化电路和第二中断生成电路;
其中,αi1表示为样本i1的拉格朗日乘子,αi2表示为样本i2的拉格朗日乘子;
拉格朗日乘子存储器存储样本对应的拉格朗日乘子αi;αi2优化电路输入端分别与核函数计算模块和拉格朗日乘子存储器连接,αi2优化电路输出优化后的αi2 new写入拉格朗日存储器,以及输出αi2的改变量Δαi2到αi1优化电路和第二中断生成电路;
αi1优化电路接收αi2优化电路输出的改变量Δαi2,并从拉格朗日乘子存储器读取αi1 old,对拉格朗日乘子αi1进行优化,得到优化后的αi1写入拉格朗日存储器,最后输出αi1的改变量Δαi1;
第二中断生成电路生成INT2信号输入控制调度模块,控制调度模块根据INT2信号判断状态转移。
7.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述核函数计算模块包括乘法器MUL1-MULn、加法器ADD2-ADDn、样本存储器XMem[1]-XMem[n]、XiReg[1]-XiReg[n]和XjReg[1]-XjReg[n];
在为拉格朗日乘子优化模块计算核函数时,乘法器MULdm交替输入样本存储器XMem[dm]和样本寄存器XiReg[dm],样本存储器XMem[dm]和样本寄存器XjReg[dm];
在为误差更新模块计算核函数时,乘法器MULdm输入XiReg[dm]和XjReg[dm];
ADD2-ADDn顺次相连,ADDn输出核函数Ki,j=XiXj;
其中,X表示为样本,i和j分别为样本的下标。
8.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述误差更新模块包括乘法器MUL0、加法器ADD1、寄存器Temp、误差存储器以及第三中断生成电路;
其中,乘法器MUL0依次接收核函数计算模块计算出的核函数Ki,i1和Ki,i2,核函数Ki,il与拉格朗日乘子优化模块计算出的yilΔαil相乘,核函数Ki,i2与拉格朗日乘子优化模块计算出的yi2Δαi2相乘,输出连接ADD1;ADD1第一次输出中间结果存入寄存器Temp,第二次输出更新后的误差Fi new,写入误差存储器,并输入第三中断生成电路,判断是否满足KKT条件,输出中断信号INT3。
9.根据权利要求1所述基于支持向量机的癫痫检测集成电路,其特征在于,所述支持向量机采用基于改进版本的序贯最小化算法完成片上训练过程。
10.一种基于权利要求1-9任一基于支持向量机的癫痫检测集成电路的片上训练方法,其特征在于,包括以下步骤;
步骤1、将脑电信号分为若干个频段,然后将若干个频段的脑电信号对应输入至若干个滤波器中进行滤波,得到滤波后的脑电信号x[i];
步骤2、将得到若干个滤波后的脑电信号对应输入至若干个特征计算模块,计算滤波后的脑电信号x[i]的均值mean与方差值variance,得到一个多维特征向量,并将得到的多维特征向量作为样本输入至支持向量机;
步骤3、将样本分为五个子集:I0={i:0<αi<C},I1={i:yi=+1,αi=0},I2={i:yi=-1,αi=C},I3={i:yi=+1,αi=C},I4={i:yi=-1,αi=0};
其中,C是可设定的常数,上集合为I0UI1∪I2,标签值记为0,下集合为I0UI3UI4标签值记为1,上集合所对应的预测误差Fi中最小的误差记为bup,下集合所对应的预测误差中最大的误差记为blow,bup和blow对应地址记为iup和ilow;
步骤4.初始化拉格朗日乘子αi为0,预测误差Fi为负的样本标签(-yi);
步骤5.样本选择模块选择不满足式KKT最优条件的样本i2,KKT最优条件如下:
i∈I0∪I1∪I2,and Fi≥blow-τ,i∈I0∪I3∪I4,and Fi≤bup+τ其中,τ=2-10是允许的误差;样本i2对应的样本i1如下:
i1=iup,if i2∈I0∪I3∪I4
i1=ilow,if i2∈I0∪I1∪I2
步骤6.拉格朗日乘子优化模块更新步骤5所选的样本i2对应的拉格朗日乘子αi2,得到更新后的更新方法如下;
其中η=2Ki1i2-Ki1i1-Ki2i2;L和H限制αi2的有效范围;
对所选的样本i2对应样本i1的拉格朗日乘子αi1进行更新,得到更新后的
步骤7.更新模块更新所有i∈I0的预测误差Fi,得到更新后的
在更新完误差Fi后,更新bup、blow、iup和ilow;若blow-bup≥τ,则令αil=iup、αi2=ilow,返回步骤6;否则i∈I0返回步骤5,直至整个集合上的样本都满足KKT最优条件后训练结束。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910245466.0A CN109998536B (zh) | 2019-03-28 | 2019-03-28 | 一种基于支持向量机的癫痫检测集成电路及其训练方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910245466.0A CN109998536B (zh) | 2019-03-28 | 2019-03-28 | 一种基于支持向量机的癫痫检测集成电路及其训练方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109998536A true CN109998536A (zh) | 2019-07-12 |
CN109998536B CN109998536B (zh) | 2021-01-22 |
Family
ID=67168714
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910245466.0A Active CN109998536B (zh) | 2019-03-28 | 2019-03-28 | 一种基于支持向量机的癫痫检测集成电路及其训练方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109998536B (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110558977A (zh) * | 2019-09-09 | 2019-12-13 | 西北大学 | 基于机器学习模糊特征选择的癫痫发作脑电信号分类方法 |
CN111603135A (zh) * | 2020-05-11 | 2020-09-01 | 江南大学 | 一种基于主从支持向量机的低功耗癫痫检测电路 |
CN114431829A (zh) * | 2020-11-05 | 2022-05-06 | 四川大学华西医院 | 一种癫痫发作判断模型的建模方法、癫痫监控方法及装置 |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060112026A1 (en) * | 2004-10-29 | 2006-05-25 | Nec Laboratories America, Inc. | Parallel support vector method and apparatus |
CN101308551B (zh) * | 2008-05-05 | 2010-06-02 | 西安理工大学 | Ls-svm分类与回归学习递归神经网络硬件电路及实现方法 |
CN102613972A (zh) * | 2012-03-28 | 2012-08-01 | 西安电子科技大学 | 运动想象脑电信号特征的提取方法 |
KR20130038085A (ko) * | 2011-10-07 | 2013-04-17 | 전자부품연구원 | 통합형 서포트 벡터 머신 회로 장치 |
CN103699697A (zh) * | 2014-01-16 | 2014-04-02 | 北京航空航天大学 | 一种支持向量机的fpga并行计算实现装置 |
CN104112143A (zh) * | 2014-07-23 | 2014-10-22 | 大连民族学院 | 基于加权超球支持向量机算法的图像分类方法 |
CN106442122A (zh) * | 2016-09-19 | 2017-02-22 | 哈尔滨工业大学 | 基于图像分割和辨识的钢材料落锤撕裂试验断口韧性断面百分比检测方法 |
CN106874958A (zh) * | 2017-02-28 | 2017-06-20 | 中南大学 | 一种基于多元多项式拟合的支持向量机模型近似方法及其应用 |
CN107203469A (zh) * | 2017-04-28 | 2017-09-26 | 北京大学 | 基于机器学习的编译器测试加速方法 |
CN108242239A (zh) * | 2016-12-23 | 2018-07-03 | 张学阳 | 一种声纹识别方法 |
-
2019
- 2019-03-28 CN CN201910245466.0A patent/CN109998536B/zh active Active
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060112026A1 (en) * | 2004-10-29 | 2006-05-25 | Nec Laboratories America, Inc. | Parallel support vector method and apparatus |
CN101308551B (zh) * | 2008-05-05 | 2010-06-02 | 西安理工大学 | Ls-svm分类与回归学习递归神经网络硬件电路及实现方法 |
KR20130038085A (ko) * | 2011-10-07 | 2013-04-17 | 전자부품연구원 | 통합형 서포트 벡터 머신 회로 장치 |
CN102613972A (zh) * | 2012-03-28 | 2012-08-01 | 西安电子科技大学 | 运动想象脑电信号特征的提取方法 |
CN103699697A (zh) * | 2014-01-16 | 2014-04-02 | 北京航空航天大学 | 一种支持向量机的fpga并行计算实现装置 |
CN104112143A (zh) * | 2014-07-23 | 2014-10-22 | 大连民族学院 | 基于加权超球支持向量机算法的图像分类方法 |
CN106442122A (zh) * | 2016-09-19 | 2017-02-22 | 哈尔滨工业大学 | 基于图像分割和辨识的钢材料落锤撕裂试验断口韧性断面百分比检测方法 |
CN108242239A (zh) * | 2016-12-23 | 2018-07-03 | 张学阳 | 一种声纹识别方法 |
CN106874958A (zh) * | 2017-02-28 | 2017-06-20 | 中南大学 | 一种基于多元多项式拟合的支持向量机模型近似方法及其应用 |
CN107203469A (zh) * | 2017-04-28 | 2017-09-26 | 北京大学 | 基于机器学习的编译器测试加速方法 |
Non-Patent Citations (2)
Title |
---|
BAI HAILONG 等: "Automatic ECG-based seizure prediction VLSI system with pipelined support vector machine", 《INTERNATIONAL CONFERENCE ON BIOLOGICAL INFORMATION AND BIOMEDICAL ENGINEERING》 * |
WANG YUANFA等: "Hardware design of multiclass SVM classification for epilepsy and epileptic seizure detection", 《IET CIRCUITS DEVICES & SYSTEMS》 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110558977A (zh) * | 2019-09-09 | 2019-12-13 | 西北大学 | 基于机器学习模糊特征选择的癫痫发作脑电信号分类方法 |
CN111603135A (zh) * | 2020-05-11 | 2020-09-01 | 江南大学 | 一种基于主从支持向量机的低功耗癫痫检测电路 |
CN111603135B (zh) * | 2020-05-11 | 2021-09-28 | 江南大学 | 一种基于主从支持向量机的低功耗癫痫检测电路 |
CN114431829A (zh) * | 2020-11-05 | 2022-05-06 | 四川大学华西医院 | 一种癫痫发作判断模型的建模方法、癫痫监控方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN109998536B (zh) | 2021-01-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110376457B (zh) | 基于半监督学习算法的非侵入式负荷监测方法及装置 | |
Chicco et al. | Support vector clustering of electrical load pattern data | |
Kupinski et al. | Multiobjective genetic optimization of diagnostic classifiers with implications for generating receiver operating characteristic curves | |
CN109998536A (zh) | 一种基于支持向量机的癫痫检测集成电路及其训练方法 | |
US6128608A (en) | Enhancing knowledge discovery using multiple support vector machines | |
EP1192595B8 (en) | Enhancing knowledge discovery from multiple data sets using multiple support vector machines | |
CN107678845A (zh) | 应用程序管控方法、装置、存储介质及电子设备 | |
CN110210513A (zh) | 数据分类方法、装置及终端设备 | |
CN111597760B (zh) | 一种实现小样本条件下获取气路参数偏差值的方法 | |
CN109635990A (zh) | 一种训练方法、预测方法、装置及电子设备 | |
US20240062816A1 (en) | Adaptive memory management and control circuitry | |
CN111639586A (zh) | 非侵入式负荷识别模型构建方法、负荷识别方法及系统 | |
US20240045697A1 (en) | Smart compute resistive memory | |
Zhang et al. | Optimal echo state network parameters based on behavioural spaces | |
CA2330878C (en) | Pre-processing and post-processing for enhancing knowledge discovery using support vector machines | |
Zhang et al. | WOA-DBSCAN: application of whale optimization algorithm in DBSCAN parameter adaption | |
Cordella et al. | A feature selection algorithm for handwritten character recognition | |
Duan et al. | ECC++: An algorithm family based on ensemble of classifier chains for classifying imbalanced multi-label data | |
CN102202018B (zh) | 一种基于支持向量机的信道估计方法 | |
Huang et al. | Temporal output discrepancy for loss estimation-based active learning | |
Li et al. | Characterizing on-chip traffic patterns in general-purpose GPUs: A deep learning approach | |
KR20230142121A (ko) | 신경망 기반의 배터리 사용량 예측 방법 및 장치 | |
Li et al. | Modulation recognition analysis based on neural networks and improved model | |
Pavlou et al. | Monitoring domestic water consumption: a comparative study of model-based and data-driven end-use disaggregation methods | |
CN112906783A (zh) | 一种适用于跨被试的脑电情绪识别方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |