✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。
🍎个人主页:Matlab科研工作室
🍊个人信条:格物致知。
更多Matlab仿真内容点击👇
⛄ 内容介绍
针对传统图像分类算法在泛化能力等方面存在的不足,结合当前的深度学习算法,提出一种基于卷积神经网络与SVM的图像识别方法.对此,文章首先以深度学习算法中比较典型的卷积神经网络进行介绍,并重点对原理和训练过程进行介绍;然后构建卷积神经网络结构和SVM分类器,最后以水果图像为例,通过MATLAB对上述模型进行编程仿真.结果表明本文提出的算法在识别的错误率方面都要明显优于单一的算法,进而验证了本文算法的可行性,为当前图像的识别提供了新的参考与借鉴.
⛄ 部分代码
% SVM
clc;
clear all;
%% 鍒掑垎鏁版嵁闆�pwd='.\data'; % 璺緞
currentPath = pwd; % 鑾峰緱褰撳墠鐨勫伐浣滅洰褰�fprintf('鍔犺浇鏁版嵁...');
t = tic;
imdsImage = imageDatastore(fullfile(pwd),'IncludeSubfolders',true,'LabelSource','foldernames'); % 杞藉叆鎵�湁鍥剧墖闆嗗悎
imdsImage.ReadFcn = @readAndPreproc;
numImages = length(imdsImage.Files); %鍥剧墖鎬荤殑寮犳暟
[imdsTrain,imdsTest] = splitEachLabel(imdsImage, 0.8,'randomized');%姣忎釜绫婚兘鎸夋瘮渚嬮殢鏈烘媶鍒嗘暟鎹泦锛岃缁冮泦鍜屾祴璇曢泦8锛�锛�
fprintf('瀹屾垚 %.02f 绉抃n', toc(t));
countEachLabel(imdsTrain)
%% 鎼缓SVM妯″瀷
rng('default');
nTrain = length(imdsTrain.Labels);
nTest = length(imdsTest.Labels);
for i=1:nTrain
I=readimage(imdsTrain,i);
I=imresize(I,[25 25]); % 璋冩暣澶у皬 鍑忓皯杩愮畻鏃堕棿
I_gray=rgb2gray(I);
Train(:,i)=double(I_gray(:));
end
YTrain=double(imdsTrain.Labels);
for i=1:nTest
I=readimage(imdsTest,i);
I=imresize(I,[25 25]); % 璋冩暣澶у皬 鍑忓皯杩愮畻鏃堕棿
I_gray=rgb2gray(I);
Test(:,i)=double(I_gray(:));
end
YTest=double(imdsTest.Labels);
% 璁粌
t = tic;
SVMModel=fitcecoc(Train',YTrain);
fprintf('璁粌缁撴潫鑺辫垂鏃堕棿锛�%.02f 鍒嗛挓\n', toc(t)/60);
%% 娴嬭瘯 + 璇勪及鎸囨爣
YPred = predict(SVMModel,Test');
accuracy = sum(YPred == YTest)/numel(YTest)
save SVM_NET.mat SVMModel
⛄ 运行结果
⛄ 参考文献
[1]刘福珍. 基于卷积神经网络法和支持向量机法的影像科图像识别方法:, CN108389187A[P]. 2018.
[2]杨红云, 黄琼, 孙爱珍,等. 基于卷积神经网络和支持向量机的水稻种子图像分类识别[J]. 中国粮油学报, 2021(012):036.