基于规则的分类系统(rule-based classification systems,RBCSs)由若干条包含数值型前件的规则构成,通过对训练样本的学习实现规则挖掘,根据规则与新样本的匹配程度进行分类.与其他分类系统相比,基于规则的分类系统除了可同时处理专家知识、数学模型和经验数据等多源信息,其输出结果还具有极强的可解释性,给决策者或操作者提供了更好的决策依据,因此,系统被广泛应用于纵多领域[1-2].
文献[3]提出一种基于小生境遗传算法的规则提取算法,从规则编码、适应度设计、搜索策略三个方面做了讨论和分析,但算法耗时长,计算量大,同时种群多样性差;文献[4]通过改进基因表达式编程(GEP)提出兼顾规则一致性增益和完备性的适应度函数,但是GEP采用多基因染色体模式解决问题时,染色体中基因数目不好控制;文献[5]提出一种基于粗糙集增量式规则自动学习的方法获取分类规则,避免了繁琐的重训练过程,但此方法不能准确找到规则进行样本分类且更新过程繁琐;文献[6]通过采用自适应信息素更新和更换启发式函数的蚁群算法(ACO)实现分类规则的挖掘,精度有所提升,但是算法收敛速度缓慢,且易陷入局部最优解;文献[7]在ACO算法的基础上提出了一种自适应蚁群算法,通过动态调整决定性选择概率和波动系数值,加快ACO收敛速度,但搜索空间有限且鲁棒性较差;文献[8]将粒子群算法(PSO)用于分类规则挖掘,通过改变粒子群的位置和速度以及适应度评价指标减少分类规则数目和缩短运行时间,但此方法易早熟收敛,且寻优能力差.
上述基于规则的分类算法中普遍存在着全局搜索能力不强、鲁棒性和种群多样性较差的问题.本文提出基于双链量子遗传的分类规则挖掘算法(DCQGA-CRM),该算法以双链量子遗传算法为框架,采用双链量子和目标函数梯度信息进行分类器构建,将量子比特的两个概率幅作为基因位描述可行解,利用量子旋转门加快规则挖掘收敛速度,通过量子非门对规则前件进行变异.
分类系统由多条分类规则表示,通过分析训练样本数据构建分类系统模型,进而检验分类精确度,实现对未来采集样本数据分类.每个数据样本可看作由条件属性和类标签(目标属性)组成,其表达式为
Vq=(vqj,gl)
(1)
式中:vqj为第q个样本第j个条件属性值,q=1,2,…,N,j=1,2,…,n;gl为第l类标签,l=1,2,…,c.
通常用具有高层次性和象征性的If-Then分类规则来搭建分类器模型,典型的分类规则形式为
Rk:if A1=xk1 and … and Aj=xkj then Ck=gkl
(2)
式中:Aj为第j个条件属性;Ck为第k条规则所属类别;gkl为第k条规则第l类标签.
精确度是评价基于规则分类器的重要指标,分类精度越高,表明分类器分类效果越好.本文用正确分类样本数占分类样本总数的比例表示精确度.
分类问题中样本正确分类数目确定过程如下:1)计算样本数据与分类规则前件差;2)选择前件差最小值作为样本适用规则;3)对样本分类,设样本正确分类数目初值为零,比较样本类标签gl和分类规则类标签gkl是否相等.
采用测试样本对分类模型进行检验,精度越高,表明搭建分类器模型越好,进而对新测试样本数据进行分类,赋予类标签.
量子遗传算法(QGA)是在遗传算法的基础上,将量子理论引入到其中的智能优化算法.本节将双链量子与分类规则挖掘相结合,主要过程包括量子位实数编码、解空间变换、量子旋转门操作和量子非门变异几个部分.
DCQGA-CRM采用双链量子位实数编码方式产生分类规则,每个个体包含上下两条基因链,每条基因链对应优化问题的一个分类规则.在种群规模一定的条件下,通过双链量子位实数编码方式增加种群多样性,加倍搜索空间.
QGA以充当信息存储单元的双态量子比特系统为基础,用量子比特表示染色体,两个量子态的线性叠加态表示一个量子位,其形式为
|φ〉=γ|0〉+β|1〉
(2)
式中,γ、β为量子比特的概率幅,满足归一化条件.考虑归一化约束性,用概率幅编码,则DCQGA-CRM双链编码方式表示为
(3)
式中,cos tij、sin tij为第i个种群、第j个量子位的两个概率幅值.
双链量子实数编码产生分类规则的概率幅在[-1,1]之间,与原始样本数据存在差异.利用解空间变换将量子位概率幅转换为指定范围内相对应实数集,便于分类规则与样本对比.由于每条染色体含有2m个量子位的概率幅,可利用线性变换将m维单位空间Im=[-1,1]转换到实数解空间.令aj表示第j个量子位下限值,bj表示第j个量子位上限值,则相应解空间变换为
(4)
因此,每条染色体对应优化问题中的两个实数解,量子态的概率幅对应的解为
量子态的概率幅
对应的解为
量子旋转门操作的作用是促使染色体上每个基因位概率幅值收敛到预先设定幅值,从而使其收敛到全局最优解.量子旋转门表达式为
(5)
式中,θ为旋转角度.设染色体Pi上第j个量子位为通过量子旋转门调整操作后的量子位为[α′ikj,β′ikj]T,具体的更新过程为
(6)
量子旋转门更新过程中,旋转角方向和大小是根据预先设定调整策略确定的.量子旋转门只改变相位大小,不改变量子位长度.量子基因位幅值对收敛速度造成直接影响,其值一般设置为0.001π~0.1π.
量子旋转门转角大小更新策略为:目标函数在搜索点处梯度较大,即所处搜索过程较陡时,适当减小步长,避免越过全局最优解;反之,适当增大步长,加速其搜索过程,尽快搜寻到全局最优解.根据搜索点处目标函数梯度变化确定搜索点处步长,即
(7)
式中:为迭代初始步长;
f(X)为目标函数f(X)在X处的梯度值.
依据变异概率选择最优染色体,对染色体量子位施加量子非门操作,通过改变量子位概率幅使两条基因链上量子位同时得到变异,其变异过程为
(8)
基于双链量子遗传优化的分类规则挖掘算法流程图如图1所示.
图1 DCQGA-CRM算法流程图
Fig.1 Flow chart of DCQGA-CRM algorithm
本文选取UCI数据库中9个数据集对算法的分类精度和鲁棒性进行对比分析.首先将所提算法与两种基于规则的分类算法(Michigan算法和Pittsburgh算法)进行对比分析.在此基础上,在训练集中添加类噪声,将所提算法与Michigan算法[9]、Pittsburgh算法[10]、C4.5算法[11]和BP神经网络[12]进行对比,验证所提算法的噪声容忍度.
数据集具体描述如表1所示,其中,#Ex.为样本数,#Atts.为属性数,#Class.为类别数.
表1 UCI数据集描述
Tab.1 Description of UCI datasets
数据集#Ex.#Atts.#Class.Bupa34562Contraceptive100053Ecoli32775German1000202Heberman30632Iris15043New thyroid21553Page blocks548105Tae15153
本文采用样本正确分类数占样本总数的比例来进行描述分类精度;引入相对损失精度RLA来描述鲁棒性优劣,其定义为
(9)
式中:e0%为原始数据集下测试分类精度;ex%为噪声水平下测试分类精度.
为验证所提出的DCQGA-CRM与其他分类算法相比具有显著性能,采用Wilcoxon符号秩检验[9]进行显著性测试.比较检验概率p值与显著水平α的大小,判断两个算法预测阶段平均值与各自所代表的总体差异是否显著,本文选取显著水平α=0.05.本实验采用5折交叉验证方式进行算法性能验证,即将数据集随机分成5等份,选取其中的4份作为训练样本集,其余部分作为测试样本,实验结果选取5次运行结果平均值和标准差.
将本文算法与Michigan算法和Pittsburgh算法进行分类精度比较分析,各算法参数设置如表2所示.
表2 不同算法参数设置
Tab.2 Parameters settings of different algorithms
算法参数设置Michigan进化代数:200;种群个数:20;规则数:20;交叉概率:0.5;变异概率:0.2;Don’t care项概率:0.07Pittsburgh进化代数:200;种群个数:20;规则数:20;复制概率:0.5;交叉概率:0.4;变异概率:0.3;Don’t care项概率:0.1DCQGA-CRM进化代数:200;种群个数:20;概率幅幅角初始值:[0,2π];转角方向:正向转角;初始步长:0.05π;转角幅值:0.1;变异概率:0.05
表3为DCQGA-CRM与Michigan算法和Pittsburgh算法分类精度对比,分别记录了各算法对9组数据集的训练精度(eTr)与测试精度(eTst)结果,精度值后面的数值为分类精度的标准差.由表3可以看出,在9个数据集的实验结果中,DCQGA-CRM在测试结果的分类正确率明显高于其他两种对比算法.将DCQGA-CRM与Michigan算法、Pittsburgh算法的Wilcoxon符号秩检验进行对比,本文所提出算法得到的检验概率p值均小于0.05,说明本文提出的DCQGA-CRM与Michigan算法、Pittsburgh算法相比,分类性能有显著性提高.
表3 DCQGA-CRM与其他分类算法分类精度对比
Tab.3 Comparison in classification accuracy between DCQGA-CRM and other classification algorithms %
数据集DCQGA-CRMeTreTstMichiganeTreTstPittsburgheTreTstBupa75.22±1.1670.43±5.1564.09±3.0255.80±4.8668.51±1.9760.87±8.10Contraceptive67.50±3.9161.80±5.0047.78±2.0244.58±3.2750.70±1.3246.67±3.22Ecoli81.03±1.9579.23±2.6069.81±3.5565.07±2.9270.08±2.6967.76±2.77German74.02±0.4871.75±1.6363.70±14.263.00±14.069.19±1.5766.78±1.87Heberman85.76±3.6880.66±6.2676.02±1.5072.73±3.4877.99±0.6472.26±2.87Iris98.33±0.6596.00±2.0098.67±1.6395.67±0.0393.89±2.6289.17±6.40New thyroid92.33±1.3788.37±3.6089.24±5.3284.42±5.7090.23±1.7086.74±4.03Page blocks91.62±1.2789.55±1.1791.71±0.8290.45±1.5392.44±1.0790.27±2.44Tae64.38±6.8050.67±2.2357.58±4.8146.45±7.1055.67±2.0048.06±7.28
表4为本文所提算法与其他算法在分类精度实验中数据集单次运行的时间对比,其中,Pittsburgh算法和本文提出算法中的单个个体均代表一个分类器,因此,单次运行的时间要高于以单条规则为优化对象的Michigan算法,但本文所提算法采用量子旋转门策略提高了单次迭代的运行速度.
表4 各算法运算时间对比
Tab.4 Comparison of operation time among different algorithms s
数据集DCQGA-CRMMichiganPittsburghBupa2.57×1021.77×1023.55×103Contraceptive8.68×1023.85×1029.53×103Ecoli3.36×1022.03×1023.44×103German1.11×1031.95×1033.78×104Heberman2.41×1020.83×1021.82×103数据集DCQGA-CRMMichiganPittsburghIris1.22×1020.57×1021.03×103New thyroid2.61×1021.03×1021.81×103Page blocks1.10×1034.56×1028.65×103Tae1.19×1020.62×1021.22×103
通过向训练数据集中加入类噪声来分析DCQGA-CRM的噪声容忍度.采用不同类噪声水平(noise level,NL)测试其预测精度,并通过相对损失精度RLA分析算法在类噪声作用下的噪声容忍度.
本实验还选择了对类噪声容忍度较强的C4.5算法和BP神经网络进行比较分析.图2为噪声水平分别取NL=10%,20%,30%,40%和50%时不同算法对样本数据集的分类精度.在大多数数据集情况下,DCQGA-CRM类噪声容忍度优于其他算法.
图2 不同噪声水平下DCQGA-CRM与其他算法分类精度对比
Fig.2 Comparison of classification accuracy between DCQGA-CRM and other algorithms under different noise levels
本文给出了类噪声分别为10%、30%、50%时的RLA值,如表5所示.表5中,(·)值表示同一噪声水平下各算法的RLA值排名,Av.Rank表示各算法在9个数据集测试中的平均排名.从表5中可以看出,DCQGA-CRM的RLA在大多数情况下小于其他对比分类算法,拥有良好的噪声容忍度.
本文针对智能优化分类规则挖掘算法中分类精度低及噪声容忍度差等问题,提出一种DCQGA-CRM算法,以基于规则的分类系统为框架,采用双链量子实数编码增加搜索空间多样性,通过量子旋转门操作和量子非门进行策略更新,利用目标梯度函数避免陷入局部最优解.实验利用UCI数据库中9个数据集,将所提出的DCQGA-CRM与对比分类方法相比,实验结果表明,DCQGA-CRM具有较高分类精度和噪声容忍度.相对精度损失RLA和Wilcoxon符号秩检验表明,DCQGA-CRM与其他分类方法相比,噪声容忍度有显著性提高.
表5 不同噪声水平下DCQGA-CRM与其他算法的RLA对比
Tab.5 Comparison of RLA between DCQGA-CRM and other algorithms under different noise levels
数据集NL=10%DCQGA-CRMMichi-ganPitts-burghC4.5BPNNNL=30%DCQGA-CRMMichi-ganPitts-burghC4.5BPNNNL=50%DCQGA-CRMMichi-ganPitts-burghC4.5BPNNBupa1.05(1)12.35(4)2.86(3)12.91(5)1.34(2)14.29(4)9.93(2)13.81(3)19.04(5)9.23(1)21.43(2)14.04(1)23.33(4)24.51(5)22.30(3)Contraceptive0.17(1)3.29(5)2.45(3)1.31(2)3.08(4)3.85(1)13.15(5)10.45(2)11.48(3)12.03(4)7.35(1)28.22(5)14.71(2)22.88(4)15.78(3)Ecoli7.38(5)0.23(1)2.37(3)4.26(4)1.66(2)11.46(3)13.56(4)4.64(1)17.99(5)7.39(2)18.06(3)14.48(2)9.18(1)37.52(5)21.14(4)German1.25(2)7.06(5)5.23(4)3.32(3)0.93(1)1.67(1)28.25(5)15.59(4)14.07(3)10.44(2)31.22(5)19.60(1)27.03(2)30.69(4)29.54(3)Heberman3.46(2)1.12(1)4.26(3)5.34(4)5.83(5)1.63(1)2.23(2)3.27(3)15.78(4)15.98(5)3.05(1)31.70(5)5.17(2)26.45(3)27.21(4)Iris1.45(1)2.18(3)2.06(2)6.96(5)4.59(4)2.17(1)14.55(4)5.05(2)28.57(5)14.49(3)15.94(1)27.64(3)17.76(2)37.73(4)44.17(5)New thyroid0.26(1)2.17(2)3.22(4)9.05(5)3.10(3)4.21(2)3.79(1)7.78(3)29.40(5)9.56(4)15.26(1)23.31(3)15.28(2)46.48(5)37.98(4)Page blocks0.30(1)3.17(3)1.31(2)4.75(4)6.31(5)0.71(1)2.87(3)2.32(2)10.47(5)5.29(4)2.84(1)4.36(3)4.19(2)30.91(5)12.92(4)Tae5.92(1)16.11(5)7.07(3)10.07(4)7.04(2)13.82(1)14.09(2)18.17(4)16.11(3)18.31(5)21.71(1)28.19(3)38.97(5)25.50(2)38.73(4)Av.Rank1.673.223.004.003.111.673.112.674.223.331.782.892.444.113.78
[1] 徐晓滨,郑进,徐冬玲,等.基于证据推理规则的信息融合故障诊断方法 [J].控制理论与应用,2015,32(9):1170-1182.
(XU Xiao-bin,ZHENG Jin,XU Dong-ling,et al.Information fusion method for fault diagnosis based on evidential reasoning rule [J].Control Theory & Applications,2015,32(9):1170-1182.)
[2] Antonelli M,Bernardo D,Hagras H,et al.Multiobjective evolutionary optimization of type-2 fuzzy rule-based systems for financial data classification [J].IEEE Transactions on Fuzzy Systems,2017,25(2):249-264.
[3] 魏晓慧,马晓珍,刘亚秋.基于蜂群单阈值分割的 SRC 板材缺陷分类方法 [J].沈阳工业大学学报,2017,39(3):292-298.
(WEI Xiao-hui,MA Xiao-zhen,LIU Ya-qiu.Classification method for SRC wooden board defects based on single threshold segmentation of artificial bee colony [J].Journal of Shenyang University of Technology,2017,39(3):292-298.)
[4] Nyathi T,Pillay N.Comparison of a genetic algorithm to grammatical evolution for automated design of genetic programming classification algorithms [J].Expert Systems with Applications,2018,104:213-234.
[5] 杜芳华,冀俊忠,吴晨生,等.基于蚁群聚集信息素的半监督文本分类算法 [J].计算机工程,2014,40(11):167-171.
(DU Fang-hua,JI Jun-zhong,WU Chen-sheng,et al.Semi-supervised text classification algorithm based on ant colony aggregation pheromone [J].Computer Engineering,2014,40(11):167-171.)
[6] Otero F E B,Freitas A A.Improving the interpre-tability of classification rules discovered by an ant co-lony algorithm:extended results [J].Evolutionary Computation,2016,24(3):385-409.
[7] Liang Z,Sun J,Lin Q,et al.A novel multiple rule sets data classification algorithm based on ant colony algorithm [J].Applied Soft Computing,2016,38:1000-1011.
[8] Nezamabadi-pour H.A quantum-inspired gravitational search algorithm for binary encoded optimization problems [J].Engineering Applications of Artificial Intelligence,2015,40:62-75.
[9] Ishibuchi H,Nakashima T,Murata T.Comparison of the Michigan and Pittsburgh approaches to the design of fuzzy classification systems [J].Electronics and Communications in Japan,2015,80(12):10-19.
[10] Sharma P,Ratnoo S.A review on discovery of classification rules using pittsburgh approach [J].International Journal of Artificial Intelligence and Knowledge Discovery,2014,4(3):6-16.
[11] Mantas C J,Abelln J,Castellano J G.Analysis of Credal-C4.5 for classification in noisy domains [J].Expert Systems with Applications,2016,61:314-326.
[12] 李福新.基于平稳小波与 BP 神经网络的换相失败检测算法 [J].沈阳工业大学学报,2018,40(3):248-252.
(LI Fu-xin.Commutation failure detection algorithm based on stationary wavelet and BP neural network [J].Journal of Shenyang University of Technology,2018,40(3):248-252.)