图像分类——VGG

文章介绍了使用VGG网络结构进行手写数字识别的过程。首先,定义了VGG块的构建函数,通过一系列卷积层和池化层组成。接着,利用这个函数构建整个VGG网络,并添加全连接层、Dropout层以及Softmax激活的输出层。然后,提到了数据读取、模型编译、训练和评估的步骤,但具体内容引用了AlexNet的部分实现。
摘要由CSDN通过智能技术生成

VGG的网络架构

在这里插入图片描述
在这里插入图片描述

import tensorflow as tf
def vgg_block(num_conv,num_filters):
    #序列模型
    blk=tf.keras.models.Sequential()
    #遍历卷积层
    for _ in range(num_conv):
        #设置卷积层
        blk.add(tf.keras.layers.Conv2D(num_filters,kernel_size=3,padding='same',activation='relu'))
    #设置池化层
    blk.add(tf.keras.layers.MaxPool2D(pool_size=2,strides=2))
    return blk

def vgg(conv_arch):
    #序列模型
    net=tf.keras.models.Sequential()
    #生成卷积部分
    for (num_conv,num_filters) in conv_arch:
        net.add(vgg_block(num_conv,num_filters))
    #全连接层
    net.add(tf.keras.models.Sequential([
        #展平
        tf.keras.layers.Flatten(),
        #全连接层
        tf.keras.layers.Dense(4096,activation='relu'),
        #随机失活
        tf.keras.layers.Dropout(0.5),
        #全连接层
        tf.keras.layers.Dense(4096,activation='relu'),
        #随机失活
        tf.keras.layers.Dropout(0.5),
        #输出层
        tf.keras.layers.Dense(10,activation='softmax')
    ]))
    return net
#卷积层的参数
conv_arch=((2,64),(2,128),(3,256),(3,512),(3,512))

net=vgg(conv_arch)
x=tf.random.uniform((1,224,224,1))
y=net(x)
net.summary()

在这里插入图片描述

手写数字识别

在这里插入图片描述

数据读取

见alex net

模型编译

见alex net

模型训练

见alex net

模型评估

见alex net

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

醋酸洋红就是我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值