声明:转自https://blog.csdn.net/qq_27914913/article/details/71436838

https://blog.csdn.net/evil_xue/article/details/89765890

在matlab中,既有各种分类器的训练函数,比如“fitcsvm”,也有图形界面的分类学习工具箱,里面包含SVM、决策树、Knn等各类分类器,使用非常方便。接下来讲讲如何使用。

一、使用

1、启动:

点击“应用程序”,在面板中找到“Classification Learner”图标点击即启动,也可以在命令行输入“classificationLearner”,回车,也可启动。如下图:

2、导入数据:

点击“New Session”,可以从工作空间或文件中导入数据。
(默认数组中最后一列为标签)
选择数据后,导入分为三步:

第一步,确定你的数据格式,这里导入的数据是一个矩阵,既有样本输入也有对应的输出。比如,我导入的数据data是33000的矩阵,3000个样本,每个样本两个特征值,第三行是每个样本对应的输出。这时我应该选择“Use row as variables”,如果数据格式为30003,则选择“Use column as variables”。
第二步,指定哪一行为“response”即输出响应,在本数据中,第三行为输出,其余为“predictor”。
第三步,是否需要验证,一般都选择交叉验证“Cross Validation”,folds表示几次,自己选择即可。

确定后,点击“start session”。

3、选择分类器:

如下图,原始数据的散点图会显示出来,由于这数据只有两维,因此可以全部显示在二维坐标中。如果你的数据多于两维,二维坐标系不能完全显示每一维,你可以在右边红圈的X、Y下拉条中选择显示哪两维。

训练前可以选择训练的模型,点击红圈中的下拉箭头,可以看到各类训练模型,选择一个即可,也可以选择某一类的“ALL”,该类所有模型都会训练一遍。
选好模型后,点击“train”,开始训练。

4、训练结果:

训练结果显示在左边,每个模型训练后的准确率都会显示出来,最高准确率会被标注,下面即为模型的信息。

点击“Advance”可以设置模型的具体参数。点击“Confusion Matrix”可以查看混淆矩阵等。

点击“Export Model”可以将模型导出到工作空间,这样就可以利用模型来测试新的数据。也可以导出为代码,方便研究。

当后续需要处理的数据量比较大或者需要重复使用时,建议导出代码。

5、样本预测

模型导出到workespace中,命令窗口会显示一下提示信息

这里的T应该值得是一个类,需要自己定义,如果不需要立即保存,可以用另外一种方式进行样本分类预测。

[LABEL,SCORE]=predict(SVM,X)

X是大小为N*P的数字矩阵,其中P是用于训练此模型的预测变量的数量。SCORE代表各个样本的各个特征对此分类的权值,LABEL为预测分类。
——————
样本预测转自:
https://blog.csdn.net/weixin_38645024/article/details/80010714

二、导出 Classification Learner生成的图

画出的图有时需要导出放到论文里,但是里面并没有相关按钮。

这时可以使用

hFigs = findall(groot,'type','figure');

导出图像句柄,再生成图,可以使用saveas来导出pdf或者eps等格式的图片,

saveas(hFigs,'Confusion Matrix.pdf');

感谢https://blog.csdn.net/yq_forever/article/details/85264920#comments的分享。

但现在仍有一个问题,对于39×39的大型矩阵,只有颜色显示,无法显示具体的结果,是否可以将混淆矩阵中计算得到的具体结果导出?如果直接使用工具箱生成的code来计算结果,得到是所有结果的平均值,也无法获取中间过程结果。

1、以下是matlab中给出的混淆矩阵计算方式

%Compute the confusion matrix using stratified 10-fold cross validation:

clear;
load('fisheriris');
y = species;
X = meas;
order = unique(y); % Order of the group labels
cp = cvpartition(y,'k',10); % Stratified cross-validation

f = @(xtr,ytr,xte,yte)confusionmat(yte,...
classify(xte,xtr,ytr),'order',order);

cfMat = crossval(f,X,y,'partition',cp);
cfMat = reshape(sum(cfMat),3,3)

2、常规混淆矩阵的画法,可以,- 保存混淆矩阵文本文件 - matlab中使用imagesc命令

例如:[mat,order] = confusionmat(actual,predicted);%生成混淆矩阵,或者rand(10,10) %以一个随机生成的矩阵为例

imagesc(mat);%生成图查看矩阵的结果,可以添加colorbar给出图例
colormap(flipud(gray)); %或者将彩色的图转化为黑白灰的图,higher values are black and lower values are white

but无法获得predicted

注:还可以直接使用plotconfusion函数绘制混淆矩阵,函数的3种用法

plotconfusion(targets,outputs)
plotconfusion(targets,outputs,name)
plotconfusion(targets1,outputs1,name1,targets2,outputs2,name2,...,targetsn,outputsn,namen)

详细参考官方解释https://ww2.mathworks.cn/help/deeplearning/ref/plotconfusion.html?tdsourcetag=s_pcqq_aiomsg

关于混淆矩阵画法的有很多,具体参考:

https://blog.csdn.net/dujiahei/article/details/80789945

https://blog.csdn.net/dujiahei/article/details/80789945

https://blog.csdn.net/xuyingjie125/article/details/78417760

(7.26补充:上述问题在耐心看完全部程序之后解决了,可以在工具箱generate code后输出参数添加response,validationPredictions,或者直接修改导出的模型code)

% Perform cross-validation
partitionedModel = crossval(trainedClassifier.ClassificationKNN, 'KFold', 10);% Compute validation accuracy
validationAccuracy = 1 - kfoldLoss(partitionedModel, 'LossFun', 'ClassifError');% Compute validation predictions and scores
[validationPredictions, validationScores] = kfoldPredict(partitionedModel);%plot confusion matrix
[cfmat,order] = confusionmat(response,validationPredictions);
imagesc(cfmat);
colormap(flipud(gray)); 

另外,在https://www.mathworks.com/matlabcentral/answers/280897-exporting-roc-curve-and-confusion-matrix-computation-code-from-the-classification-learner-app?s_tid=answers_rc1-1_p1_Topic也验证了想法

  • CONFUSION MATRIX

C = confusionmat(response,validationPredictions);
CP = classperf(response,validationPredictions);

  • ROC CURVE:

[X,Y,T,AUC,OPTROCPT,SUBY,SUBYNAMES] = perfcurve(response,validationScores(:,1),'PositiveClass');
figure, plot(X,Y,OPTROCPT(1),OPTROCPT(2),'r*');

matlab 分类学习工具箱 Classification Learner的使用及导出其生成的图,混淆矩阵confusion matrix的画法相关推荐

  1. matlab 分类学习工具箱 Classification Learner

    转载:https://blog.csdn.net/qq_27914913/article/details/71436838 在matlab中,既有各种分类器的训练函数,比如"fitcsvm& ...

  2. 多分类问题中混淆矩阵(Confusion Matrix)的Matlab画法

    在多分类问题中,有一种很实用的分类问题结果统计图. 比如说多类别文类问题,那么每一个类别分到其他类别都有一些数据,但是分到自己类别的毕竟多,这样计算百分比之后就形成了一个矩阵,如果分类正确率高的话,那 ...

  3. 分类模型之混淆矩阵(Confusion Matrix)

    目录 混淆矩阵简介 混淆矩阵及其参数 混淆矩阵的其他指标 混淆矩阵简介 混淆矩阵是ROC曲线绘制的基础,同时它也是衡量分类型模型准确度中最基本,最直观,计算最简单的方法. 可以简单理解为:将一个分类模 ...

  4. 分类之混淆矩阵(Confusion Matrix)

    1. 写在前面 为什么时隔多年又再做一次混淆矩阵的整理,TMD就是每次用的时候要自己回过头查一遍,老是记不住,为了打好基础,再次进行梳理. 2. 为什么会有混淆矩阵 我们简单的分类衡量模型的好坏,其实 ...

  5. Matlab自带的分类学习工具箱(SVM、决策树、Knn等分类器)

    在matlab中,既有各种分类器的训练函数,比如"fitcsvm",也有图形界面的分类学习工具箱,里面包含SVM.决策树.Knn等各类分类器,使用非常方便.接下来讲讲如何使用. 启 ...

  6. 【MATLAB深度学习工具箱】学习笔记--体脂估计算例再分析:拟合神经网络fitnet里面的数据结构】

    原文链接如下 [MATLAB深度学习工具箱]学习笔记--体脂估计Body Fat Estimation_bear_miao的博客-CSDN博客介绍本示例展示一个函数拟合神经网络如何根据解剖学测量结果估 ...

  7. 【MATLAB深度学习工具箱】学习笔记--体脂估计算例再分析:拟合神经网络fitnet里面的函数】

    介绍 上一篇 [MATLAB深度学习工具箱]学习笔记--体脂估计算例再分析:拟合神经网络fitnet里面的数据结构]_bear_miao的博客-CSDN博客原文链接如下[MATLAB深度学习工具箱]学 ...

  8. 【MATLAB强化学习工具箱】学习笔记--actor网络和critic网络的结果放在哪里?

    原算例见 [MATLAB强化学习工具箱]学习笔记--在Simulink环境中训练智能体Create Simulink Environment and Train Agent_bear_miao的博客- ...

  9. 什么是强化学习,强化学习在控制系统中的应用以及matlab强化学习工具箱的介绍

    一.Reinforcement Learning Toolbox介绍 强化学习工具箱使用强化学习算法(包括DQN,A2C和DDPG)为训练策略(policy)提供函数和模块.您可以使用这些策略为复杂的 ...

最新文章

  1. 例题3-4 猜数字游戏的提示(Master-Mind Hints, UVa 340)
  2. HTTP.sys 远程执行代码验证工具
  3. 虚拟化技术中,为什么说容器技术暂时将不会取代虚拟机模式
  4. Lotus Notes常见问题答疑
  5. 再谈编程范式-程序语言背后的思想
  6. 《Head First Python》第一章
  7. java线程间通信:一个小Demo完全搞懂
  8. 为什么我要重新开始数据科学
  9. 进程已不存在,但端口仍被占用
  10. php +html5 websocket 聊天室
  11. slf4j相关的配置信息
  12. 微软最近宣布了一项政策更新,将限制在Office 365中使用Flash,Shockwave和Sil
  13. Linux网络socket网络抓包工具
  14. QQ特殊字符制作方式
  15. android各版本用户量,谷歌公布:Android用户手机系统版本份额分布
  16. 约翰霍普金斯大学计算机博士收入,约翰霍普金斯大学计算机科学研究生项目详情!...
  17. 剖析拒绝服务攻击-SYN拒绝服务(转)
  18. SP3232串口上电瞬间发乱码问题
  19. 微信小程序 - 实现导航栏和内容上下联动功能
  20. 室内外实时一体化建模

热门文章

  1. ts快捷键 vscode_VS Code快捷键
  2. Android App links 链接打开app功能
  3. matlab画图x轴
  4. Palabos用户手册翻译及学习(四)非本地操作的数据处理器和块之间的耦合
  5. C语言---找零问题------程序优化
  6. 压缩软件如何删除压缩包密码(zip、rar、7-zip),忘记密码如何删除密码?
  7. 【图像处理】漫水填充函数的使用(flags的用法)
  8. [USACO13FEB]拖拉机Tractor
  9. (转)LRC歌词编辑攻略1
  10. 程序人生-哈工大计算机系统大作业2022春