交叉验证法划分训练集matlab,matlab 下交叉验证与 svm (多分类)模型的使用

这段代码展示了如何运用Matlab进行交叉验证,具体是使用十折交叉验证方法对数据集进行规范化处理后,用fitcecoc训练SVM多分类模型,并计算平均准确率。整个过程包括数据划分、模型训练、预测以及准确率计算。
摘要由CSDN通过智能技术生成

笔记

下面是代码,注释一般都能看懂的。

%datas为读入的数据集 labels为读入的标签

%规范化数据

[datas_normal] = premnmx(datas) ;

%交叉验证

k =10;%预将数据分成十份

sum_accuracy_svm = 0;

[m,n] = size(datas_normal);

%交叉验证,使用十折交叉验证 Kfold

%indices为 m 行一列数据,表示每个训练样本属于k份数据的哪一份

indices = crossvalind('Kfold',m,k);

for i = 1:k

test_indic = (indices == i);

train_indic = ~test_indic;

train_datas = datas_normal(train_indic,:);%找出训练数据与标签

train_labels = labels(train_indic,:);

test_datas = datas_normal(test_indic,:);%找出测试数据与标签

test_labels = labels(test_indic,:);

% 开始svm多分类训练,fitcsvm用于二分类,fitcecoc用于多分类,

classifer = fitcecoc(train_datas,train_labels);%训练模型

predict_label = predict(classifer, test_datas);%测试

accuracy_svm = length(find(predict_label == test_labels))/length(test_labels)%准确率

sum_accuracy_svm = sum_accuracy_svm + accuracy_svm;

end

%求平均准确率

mean_accuracy_svm = sum_accuracy_svm / k;

disp('平均准确率:');

disp( mean_accuracy_svm);

以后不能吃红烧肉了,减肥ing

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值