在无抵押纯信用小额个人贷款越来越有热度的当今社会, 银行等金融行业越来越重视个人消费型贷款业务, 信用评估也成为了大家关注的焦点和金融机构评估信贷风险、增加现金流量、降低违约率的主要方法[1]. 个人信用评估的原理是根据贷款申请人的收入, 支出, 工作性质等基本信息和过去的表现等特征建立信用评估模型, 并用该模型对具有相同特征的未来申请者的信用进行预测[2], 区分出来“好”的贷款和“坏”的贷款, 从而协助银行等金融机构做出是否放贷的决策. 因此, 如何能够在现有信用环境下选取科学、高效的信用评估方法, 从而对贷款申请人做出有效的信用评估, 显得尤为重要[3].
传统用于信用评估的主要是统计学方法比如logistic回归, 判别分析等, 这些方法虽简单, 但处理非线性问题时效果较差. 随着计算机的进步, 人工智能等方法已经被用来进行信用评估, 比如神经网络(ANN)[4]、支持向量机(SVM)[5]、决策树(DT)[6]等. 人工智能的方法可以有效解决非线性问题, 但存在一定缺陷. 例如神经网络基于经验风险最小化原则常常会出现“过拟合”现象, 泛化能力比较差. 此时基于结构风险最小化原则的支持向量机由于很强的泛化推广能力, 且在解决小样本、非线性识别问题中表现出许多特有的优势, 为信用评估提供了更佳的选择[7]. 吴冲[8]等利用基于模糊积分的支持向量机集成方法对客户信用进行评估, 结果表明支持向量机具有较高的预测准确率. 肖智[9]等利用支持向量机建立了大学生助学贷款个人信用评价分析模型, 通过实证体现了支持向量机方法的优越性. 然而现有大多数支持向量机作为基分类器信用评估时, 面向高维或者大规模样本, 存在不能主动进行特征选择和组合的问题, 因此准确率会受到无关维度的影响, 甚至产生维度灾难.
为解决单一模型的缺陷, 取长补短, 模型的组合应用已经成为提高信用评估准确率和稳定性的一大趋势. 文献[10]将主分量分析和神经网络(PCA—NN)模型组合进行个人信用评估取得了更好的预测分类能力. 文献[11]综合比较了多个组合模型在信用评估应用中的效果, 得出了组合模型比单一模型性能更好的结论.
综上所述, 考虑到决策树算法本身以属性的差异性为依据进行分支和最优树的生成, 为优化支持向量机会受冗余属性影响导致准确率下降的缺陷, 本文将基于信息熵增益率分类原理的C4.5最优决策树和SVM模型优化整合, 提出基于C4.5算法优化SVM的个人信用评估模型. 实验部分, 为检测模型效果, 在两个公开数据集上比较了本文提出的模型与常见单一模型的性能, 并用F-score和平均准确率两个指标对模型效果进行评估. 实验结果表明, 基于C4.5算法优化SVM的个人信用评估模型可以取得更好的性能, 能够成为一种有效的信用评估模型.
1 理论简介 1.1 支持向量机支持向量机(Support Vector Machine, SVM)是在Vapnik等人所建立的统计学习理论(Statistical Learning Theory, STL)基础上发展起来的一种新的学习算法, 基于VC维理论和结构风险最小化原理, 根据有限的样本信息在模型的复杂性和学习能力之间寻求最佳折衷[12].
设训练样本集D为
$\left\{ \begin{array}{l} \min \dfrac{1}{2}\left\| {{\omega ^2}} \right\|;\\ {\rm{s}}{\rm{.t}}{\rm{.}}\;{y_i}[{\omega ^{\rm{T}}}x + b] \ge 1\;\;\;\;(i = 1,2, \cdots ,n) \end{array}\right. $ | (1) |
上述二次规划可以用对偶理论求解, 最终线性可分情况下的决策函数为:
$f(x) = {\rm{sgn}} \left\{ {\sum\limits_{i = 1}^n {{\alpha _i}^ * {y_i}({x_i}^{\rm{T}}x) + {b^ * }} } \right\}$ | (2) |
对于线性不可分的问题, 通过核函数将向量映射到一个更高的特征空间, 在高维空间输入的向量可以被超平面成功分开. 通过核函数可以简化内积的运算, 常用核函数有高斯核函数、线性核函数和多项式核函数, 引入松弛变量
$\left\{ \begin{array}{l} \min \dfrac{1}{2}{\left\| \omega \right\|^2} + C\left( {\sum\limits_{i = 1}^n {{\xi _i}} } \right)\\ {\rm{s}}{\rm{.t}}{\rm{.}}\;{y_i}[{\omega ^T}x + b] \ge 1(i = 1,2, \cdots ,n) \end{array}\right. $ | (3) |
根据对偶理论求解可得决策函数为:
$f(x) = {\rm{sgn}} \left\{ {\sum\limits_{i = 1}^n {{\alpha _i}^ * {y_i}K\left( {{x_i},x} \right)} + {b^ * }} \right\}$ | (4) |
本文采用高斯核函数:
$ K({x_i},{x_j}) = \exp \left( {\gamma {{\left\| {{x_i} - {x_j}} \right\|}^2}} \right)\\ \gamma = - \frac{1}{{2{\sigma ^2}}} $ | (5) |
决策树学习是应用统计, 机器学习和数据挖掘领域中一类重要的监督学习算法[13,14]. 采用自顶向下的递归方式, 从树根节点开始在内部进行属性的测试比较, 根据属性值确定分支, 最后在决策树的叶子节点得到分类的结论, 整个过程在以新的节点为根的子树上重复, 直到训练停止得到最优决策树. 影响最大的决策树算法是ID3算法, 它以信息增益来选择属性. 为克服ID3算法信息增益选择属性时偏向于选择取值多的属性和其只能处理离散型和完整性属性等缺点, 1993年提出了C4.5决策树算法, 以信息熵增益率方法测试属性[15].
信息增益率计算公式为:
$ GainRatio(D,A) = \frac{{Gain(D,A)}}{{Split\_\;{\rm{inf}}\;o(D,A)}} $ | (6) |
其中, D为数据集, A是数据集属性,
信用评估领域中, 银行等金融机构为了从众多信用数据中归纳出信用“好”和信用“差”的顾客的一般规律从而降低误判率, 会收集和积累大量的数据, 但是对于数据集本身而言, 并不是所有的样本属性均包含相同的对结果有影响的信息量. 冗余属性较多反而会出现“维数灾难”, 增加了模型计算的复杂度降低模型效率. 基于此, 本文提出C4.5决策树利用自身属性筛选方法优化支持向量机无法主动降维缺陷的个人信用评估模型.
C4.5算法优化SVM的个人信用评估模型包含了两个子系统: 一个是基于C4.5决策树的属性筛选和SVM参数优化系统; 一个是训练和测试SVM分类器性能系统.
2.1 SVM参数优化本文采用高斯核函数作为SVM的核函数解决线性不可分的问题. 惩罚参数C的作用是为了权衡经验风险和结构风险, C值越大, 模型对离群点越重视, 模型越复杂容易出现过拟合; C值越小, 模型对离群点越不重视, 容易出现欠拟合现象. 而高斯核函数的参数
C4.5算法优化SVM的个人信用评估模型流程图如图1所示, 具体步骤如下:
步骤1: 数据预处理. 所有的连续变量都运用公式
步骤2: 确定初始训练集, 测试集.
步骤3: C4.5决策树特征筛选.
(1)设置损失比例. 实际中, 将信用“好”的客户误判为信用“差”的客户损失的可能仅仅是贷款利息, 而将信用“差”的客户误判为信用“好”的客户则可能遭受巨大的违约风险, 二者所造成的损失不对等, 决策树模型通过设置损失比例将可能导致的损失引入系统分析过程.
(2)设置Boosting迭代次数. 反复Boosting迭代, 不断增大误判样本被抽为训练集的可能性, 提高模型精度.
(3)确定决策树的修剪严重性. 对比不同修剪度, 确定决策树最佳修剪程度.
(4)特征筛选. 在最优树下计算特征贡献率, 筛选对分类结果有较大影响属性.
步骤4: 训练SVM模型.
(1)根据步骤3特征筛选的结果, 组成新数据集. 采用k折交叉验证方法, 将全部数据集分成k个不相交的子集, 假设样本数为m, 则子集就有m/k 个样例, 每次从分好的子集中里面, 拿出一个作为测试集, 其它k–1个作为训练集.
(3)训练分类器. 利用网格搜索法优化SVM参数C和核函数参数.
步骤5: 评估C4.5算法优化SVM的个人信用评估模型效果. 选取评价指标, 并取k次实验结果的平均值.
2.3 模型评价指标选择两个指标来评估模型的效果, 分别是F-score和平均准确率accuracy, 这两个指标可以综合常用于信用评估的precision查准率与recall召回率. 根据混淆矩阵, 指标的计算方法如下:
$ F - score = \frac{{2*recall*precision{\rm{ }}}}{{{\rm{ }}recall + precision{\rm{ }}}} $ | (7) |
$ precision = \frac{{TP}}{{TP + FP}} $ | (8) |
$ recall = \frac{{TP}}{{TP + FN}} $ | (9) |
$accuracy = \frac{{TP + TN}}{{TP + FP + FN + TN}}$ | (10) |
本文选取UCI机器学习库中的两组公开数据集验证模型效果, 分别是德国信贷数据集和澳大利亚信贷数据集. 数据集的具体信息如表2所示, 德国信贷数据属性的详细描述如表3所示, 每个样本包含20个属性, 其中4个被转换为8个虚拟的变量最终表现为24维的数字变量和一个类别标签. 澳大利亚信贷数据集共有14个属性特征和一个类别标签.
3.2 基于C4.5决策树算法特征提取
决策树特征提取基于clementine12.0平台, 采用保留法建立模型. 在两组数据集上以4:1的比例设置训练集和测试集, 按文献[13]研究结论, 将损失比例设为最佳2:1, Boosting迭代次数设置为默认值10, 比对不同修剪程度对分类准确率的影响如表4所示, 可知当修剪严重性为85时, 德国数据集测试集与训练集分类准确率最高, 当修剪严重性为65时, 澳大利亚数据集测试集与训练集分类准确率均最高.
按损失比例2:1, Boosting迭代次数10, 修剪严重性85设置生成依托德国信贷数据的最优树, 特征相对重要性排序如图2所示. 根据贡献度大小靠前的变量分别为: 变量1(0.2634)、变量4(0.1478)、变量2(0.1352)、变量3(0.1226)、变量17(0.1122)、变量5(0.076)、变量10(0.0631)、变量21(0.0441)、变量13(0.02)、变量24(0.0094)、变量20(0.0054)、变量16(0.0008). 按损失比例2:1, Boosting迭代次数10, 修剪严重性65设置生成依托澳大利亚信贷数据的最优树, 特征相对重要性排序如图3所示. 根据贡献度大小靠前的属性为: 属性8(0.7678)、属性5(0.0542)属性3(0.052)、属性2(0.0332)、属性9(0.0326)、属性14(0.0091)、属性13(0.0077)、属性4(0.0043)、属性12(0.0025).
3.3 基于C4.5算法优化SVM的个人信用评估
经筛选后, 德国信贷数据从25维降低到13维, 澳大利亚信贷数据从15维降低到10维. 将降维后的数据作为SVM的输入训练分类器. 实验依托Matlab2016a平台, 使用Libsvm工具包, 采用5折交叉验证减少随机抽样对SVM分类结果的影响, 通过网格搜索法与交叉验证的方法, 确定高斯径向基核函数最优参数γ和支持向量机惩罚函数C, 两个参数的网格搜索范围都是[2-5,25],步长均为0.2. 实验比较了C4.5优化SVM的模型(DT+SVM)与C4.5决策树(DT), SVM单独模型(SVM)以及BP神经网络(BPNN)、logistic回归, 模糊支持向量机(B-FSVM)这些常用于信用评估的模型分类性能. 在两组数据集上进行实验, 测试集实验结果如表5表6所示, 表格中F表示F-score指标值, A代表平均准确率.
表5给出了各个常用于信用评估的模型在德国数据集上的实验结果, 从实验结果可以看出: (1)在每次实验中, 不论是从F-score还是平均准确率来看, 本文提出的模型的效果都是最优的, 证明了这种方法用于信用评估是有效的. (2)两个不同的组合模型的效果普遍比单一模型的分类效果性能好. (3)特征筛选后SVM分类效果, 比直接用于SVM分类F-score提高了19%, 平均准确率提高了4.9%, 可以明显得知利用C4.5决策树特征筛选可以弥补SVM的不足.
表6给出了各个信用评估模型用于澳大利亚信贷数据集上的结果, 可以得出如下结论: (1)基于C4.5算法优化SVM的个人信用评估模型综合效果最好. (2)组合模型的效果要优于单一模型. (3)特征筛选前后, 支持向量机模型的F-score提升了19%, 平均准确率提升了5%, 说明非重要属性的减少不会降低模型效果, 反而会提升.
综上所述, 本文提出的基于C4.5算法优化SVM的个人信用评估模型可以取得更加优异的性能, 具有实用性; 部分含有信息量多且对分类结果影响较大的属性, 可以代表全部的属性变量来作为建模的数据集, 并且这样训练出来的模型效果优于全部数据用于建模所取得的模型的效果, 银行或者金融机构可以参考本文方法进行信用评估.
4 结语在信贷消费逐渐普及的高速信息化社会, 个人信用评估的研究意义越来越重要, 信用评估模型的好坏直接影响了信贷消费的走向健康和银行等金融机构的坏账率, 分类器效能哪怕很小的1%的提升都会挽回金融机构数以万计的损失. 考虑到支持向量机处理多数据性能下降的缺点, 本文提出基于C4.5算法优化支持向量机的个人信用评估方法. 该方法将C4.5决策树和支持向量机这两种高效的信息处理方法组合, 优势互补用于个人信用评估领域. 在UCI两组公开数据集上, 用F-score与平均准确率两个指标对模型测试. 实验可得, 该组合模型可以取得很好的分类效果, 有效且实用性较高, 可以为科学决策提供支持.
未来进一步研究的方向: (1)C4.5算法由于使用了熵模型, 里面有大量的复杂的对数运算, 会导致算法复杂度高, 如何全方面考虑到信息增益又降低算法复杂度有待进一步研究. (2)文中仅进行SVM二分类, 多分类问题有待研究. (3)由于数据保密原因, 本文仅在两个公开数据集上进行了测试, 模型在其他的数据集上是否有效有待进一步的验证.
[1] |
Wang G, Hao JX, Ma J, et al. A comparative assessment of ensemble learning for credit scoring. Expert Systems with Applications, 2011, 38(1): 223-230. DOI:10.1016/j.eswa.2010.06.048 |
[2] |
陈启伟, 王伟, 马迪, 等. 基于Ext-GBDT集成的类别不平衡信用评分模型. 计算机应用研究, 2018, 35(2): 421-427. DOI:10.3969/j.issn.1001-3695.2018.02.022 |
[3] |
向小东, 宋芳. 基于核主成分与加权支持向量机的福建省城镇登记失业率预测. 系统工程理论与实践, 2009, 29(1): 73-80. DOI:10.3321/j.issn:1000-6788.2009.01.010 |
[4] |
Guo W, Cao MY, Zheng JF. Study on Chinese banks of credit risk evaluation models of real-estate based on the BP-neural network model. Proceedings of 2009 WRI World Congress on Computer Science and Information Engineering. Los Angeles, CA, USA. 2009. 288–292.
|
[5] |
Koutanaei FN, Sajedi H, Khanbabaei M. A hybrid data mining model of feature selection algorithms and ensemble learning classifiers for credit scoring. Journal of Retailing and Consumer Services, 2015, 27: 11-23. DOI:10.1016/j.jretconser.2015.07.003 |
[6] |
向晖, 唐剑琴. 基于bagging的决策树集成消费者信用评估模型. 消费经济, 2015, 31(3): 72-74. |
[7] |
谢娟英, 王春霞, 蒋帅, 等. 基于改进的F-score与支持向量机的特征选择方法. 计算机应用, 2010, 30(4): 993-996. |
[8] |
吴冲, 夏晗. 基于支持向量机集成的电子商务环境下客户信用评估模型研究. 中国管理科学, 2008, 16(S1): 362-367. |
[9] |
肖智, 王明恺, 谢林林. 基于支持向量机的大学生助学贷款个人信用评价. 清华大学学报(自然科学版), 2006, 46(S1): 1120-1124. |
[10] |
姚尚锋. 基于主分量分析和BP神经网络的个人信用评估模型. 数学的实践与认识, 2007, 37(21): 21-24. DOI:10.3969/j.issn.1000-0984.2007.21.005 |
[11] |
Nanni L, Lumini A. An experimental comparison of ensemble of classifiers for bankruptcy prediction and credit scoring. Expert Systems with Applications, 2009, 36(2): 3028-3033. DOI:10.1016/j.eswa.2008.01.018 |
[12] |
Sain SR. The nature of statistical learning theory. Technometrics, 1996, 38(4): 409. |
[13] |
Han JW. Data mining: Concepts and techniques. San Francisco, CA, USA: Morgan Kaufmann Publishers Inc, 2005.
|
[14] |
Safavian SR, Landgrebe D. A survey of decision tree classifier methodology. IEEE Transactions on Systems, Man, and Cybernetics, 1991, 23(3): 660-674. |
[15] |
Yang Y, Chen WG. Taiga: Performance optimization of the C4.5 decision tree construction algorithm. Tsinghua Science and Technology, 2016, 21(4): 415-425. DOI:10.1109/TST.2016.7536719 |