全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 物联网 >

分享一下卷积神经网络的代码实战

时间:2023-06-02 16:20

人气:

作者:admin

标签:   神经网络  分享  下卷   

导读:CNN 模型为深度学习模型,其具有局部连接、权 值共享和空间相关等特性,以及强鲁棒性和容错能力,适用于提取深层数据特征。...

1、相关理论

CNN 模型为深度学习模型,其具有局部连接、权 值共享和空间相关等特性,以及强鲁棒性和容错能力,适用于提取深层数据特征。经典的 CNN 模型结构包含输入层、隐含层、全连接层和输出层。卷积神经网络的模型如下图所示。

图片

2、数据集的准备

以手写数据集为例,搭建卷积神经网络进行分类识别。数据集下载地址: ,下面为部分数据集图片展示。

图片

3、数据集的读取与划分

将下载好的数据集保存好,digitDatasetPath 填写数据集的保存路径即可。每一类随机选择750张图片作为测试数据,其他的作为训练数据。

%%数据集的读取
digitDatasetPath = 'D:\\MTALAB2019\\手写数据集\\DigitDataset';
imds = imageDatastore(digitDatasetPath, ...
    'IncludeSubfolders',true,'LabelSource','foldernames');
%%数据集的划分
numTrainFiles = 750;
[imdsTrain,imdsValidation] = splitEachLabel(imds,numTrainFiles,'randomize');

4、卷积神经网络的搭建

layers = [
    imageInputLayer([28 28 1])  %%输入层
    %%卷积层
    convolution2dLayer(3,8,'Padding','same')  
    batchNormalizationLayer
    reluLayer
    %%池化层
    maxPooling2dLayer(2,'Stride',2)
    %%卷积层
    convolution2dLayer(3,16,'Padding','same')
    batchNormalizationLayer
    reluLayer
    %%池化层
    maxPooling2dLayer(2,'Stride',2)
    %%卷积层
    convolution2dLayer(3,32,'Padding','same')
    batchNormalizationLayer
    reluLayer
    %全连接层
    fullyConnectedLayer(10)
    softmaxLayer
    classificationLayer];

网络搭建好了,就需要对网络的参数进行设置,相关参数代码如下:

options = trainingOptions('sgdm', ...
    'InitialLearnRate',0.01, ...
    'MaxEpochs',10, ...
    'Shuffle','every-epoch', ...
    'ValidationData',imdsValidation, ...
    'ValidationFrequency',30, ...
    'Verbose',false, ...
    'Plots','training-progress');

** 5、训练卷积神经网络**

net = trainNetwork(imdsTrain,layers,options);

** 训练结果如下 **

图片

6、测试与运行结果

YPred = classify(net,imdsValidation);
YValidation = imdsValidation.Labels;
accuracy = sum(YPred == YValidation)/numel(YValidation)

accuracy = 0.9868

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信