news 2026/4/28 21:16:30

深度学习打卡第J2周:ResNet50V2算法实战与解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深度学习打卡第J2周:ResNet50V2算法实战与解析
  • 🍨本文为🔗365天深度学习训练营中的学习记录博客
  • 🍖原作者:K同学啊
import tensorflow as tf import tensorflow.keras.layers as layers from tensorflow.keras.models import Model def block2(x, filters, kernel_size=3, stride=1, conv_shortcut=False, name=None): preact = layers.BatchNormalization(name=name + '_preact_bn')(x) preact = layers.Activation('relu', name=name + '_preact_relu')(preact) if conv_shortcut: shortcut = layers.Conv2D(4 * filters, 1, strides=stride, name=name + '_0_conv')(preact) else: shortcut = layers.MaxPooling2D(1, strides=stride)(x) if stride > 1 else x x = layers.Conv2D(filters, 1, strides=1, use_bias=False, name=name + '_1_conv')(preact) x = layers.BatchNormalization(name=name + '_1_bn')(x) x = layers.Activation('relu', name=name + '_1_relu')(x) x = layers.ZeroPadding2D(padding=((1, 1), (1, 1)), name=name + '_2_pad')(x) x = layers.Conv2D(filters, kernel_size, strides=stride, use_bias=False, name=name + '_2_conv')(x) x = layers.BatchNormalization(name=name + '_2_bn')(x) x = layers.Activation('relu', name=name + '_2_relu')(x) x = layers.Conv2D(4 * filters, 1, name=name + '_3_conv')(x) x = layers.Add(name=name + '_out')([shortcut, x]) return x def stack2(x, filters, blocks, stride1=2, name=None): x = block2(x, filters, conv_shortcut=True, name=name + '_block1') for i in range(2, blocks): x = block2(x, filters, name=name + '_block' + str(i)) x = block2(x, filters, stride=stride1, name=name + '_block' + str(blocks)) return x def ResNet50V2(include_top=True, # 是否包含位于网络顶部的全连接层 preact=True, # 是否使用预激活 use_bias=True, # 是否对卷积层使用偏置 weights='imagenet', input_tensor=None, # 可选的keras张量,用作模型的图像输入 input_shape=None, pooling=None, classes=1000, # 用于分类图像的可选类数 classifier_activation='softmax'): # 分类层激活函数 img_input = layers.Input(shape=input_shape) x = layers.ZeroPadding2D(padding=((3, 3), (3, 3)), name='conv1_pad')(img_input) x = layers.Conv2D(64, 7, strides=2, use_bias=use_bias, name='conv1_conv')(x) if not preact: x = layers.BatchNormalization(name='conv1_bn')(x) x = layers.Activation('relu', name='conv1_relu')(x) x = layers.ZeroPadding2D(padding=((1, 1), (1, 1)), name='pool1_pad')(x) x = layers.MaxPooling2D(3, strides=2, name='pool1_pool')(x) x = stack2(x, 64, 3, name='conv2') x = stack2(x, 128, 4, name='conv3') x = stack2(x, 256, 6, name='conv4') x = stack2(x, 512, 3, stride1=1, name='conv5') if preact: x = layers.BatchNormalization(name='post_bn')(x) x = layers.Activation('relu', name='post_relu')(x) if include_top: x = layers.GlobalAveragePooling2D(name='avg_pool')(x) x = layers.Dense(classes, activation=classifier_activation, name='predictions')(x) else: if pooling == 'avg': # GlobalAveragePooling2D就是将每张图片的每个通道值各自加起来再求平均, # 最后结果是没有了宽高维度,只剩下个数与平均值两个维度。 # 可以理解为变成了多张单像素图片。 x = layers.GlobalAveragePooling2D(name='avg_pool')(x) elif pooling == 'max': x = layers.GlobalMaxPooling2D(name='max_pool')(x) model = Model(img_input, x) return model if __name__ == '__main__': model = ResNet50V2(input_shape=(224, 224, 3)) model.summary()

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 19:29:36

League Akari终极指南:快速掌握免费英雄联盟智能助手

League Akari终极指南:快速掌握免费英雄联盟智能助手 【免费下载链接】LeagueAkari ✨兴趣使然的,功能全面的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/LeagueAkari 想要彻底改…

作者头像 李华
网站建设 2026/4/28 23:45:10

OpenAI开源安全推理引擎震撼发布:gpt-oss-safeguard改写AI内容治理规则

2025年10月29日,人工智能领域再次迎来里程碑事件——OpenAI正式对外开源其安全分类推理模型gpt-oss-safeguard。这款包含1200亿和200亿参数两个版本的重磅产品,不仅采用商业友好的Apache 2.0许可证,更以"策略即规则"的创新理念&…

作者头像 李华
网站建设 2026/4/29 7:40:50

匹配回文串:利用KMP算法求解

一、先明确问题:什么是 “回文串”?回文串定义:回文串是指正读和反读都完全相同的字符串比如 “abcba”“aaa”“level” 都是回文串,而 “abcd”“abbaa” 不是。可以简单理解为:字符串从左到右读,和从右到…

作者头像 李华
网站建设 2026/4/23 12:22:49

C语言实现strsep函数功能(附带源码)

一、项目背景详细介绍在字符串处理领域中,“分割字符串”几乎是最常使用的操作之一,从配置文件解析、命令行解析,到数据协议中的字段切分,都离不开字符串分割技术。在 Unix/Linux 环境中,常见的字符串分割函数有&#…

作者头像 李华