一个错误的观点:SVM会得到相同的结果即使训练集中只包含支撑向量【转】

本文针对SVM训练中的一种常见误解进行了阐述,指出仅使用支撑向量进行模型训练会导致不同的SVM模型产生,并通过实验证明了非支撑向量虽然不参与决策但确实参与了模型训练,对于最终模型的形成至关重要。

转自 http://hi.baidu.com/liuzhiliangliang/blog/item/bfbb5b277cf05c1c918f9d8c.html#0

博主提出的观点如题目,感觉这是SVM的基本问题,却在论文中被忽视,只能说悲剧。

不说了,原文奉上:

在有些关于SVM的论文中,一些作者认为SVM只依赖于支撑向量集,所以:即使训练样本中只包含支撑向量集,也可以得到与之前一样的SVM模型。这种观点是错误的,因为支撑向量集的产生,是所有样本共同作用的结果,如果缺少任何一个样本都有可能产生不同的SVM模型。所谓支撑向量,只是说是用该训练集得到的SVM模型在进行决策时只依赖于此支撑向量集,其它的非支撑向量不参与决策。

注意:非支撑向量不参与决策,但是参与了模型训练,因此他们也是必不可少的,切不可卸磨杀驴

下面用实例来佐证以上的观点。

load fisheriris

xdata = meas(51:end,3:4);

group = species(51:end);

svmStruct = svmtrain(xdata,group,'showplot',true);

 

如果只用以上模型中的支撑向量,再重新训练SVM,将得到一个不一样的SVM模型。

xdata_sv = xdata(svmStruct.SupportVectorIndices,:);

group_sv = group(svmStruct.SupportVectorIndices);

hold on;

svmStruct1 = svmtrain(xdata_sv,group_sv,'showplot',true);

 

通过上图可见:决策面发生了变化(示意为蓝色粗线),而且支撑向量发生了改变,即有些在之前SVM模型中充当支撑向量的点,在新的SVM模型中不再担当此重任。---来自亮丽的风景线

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值