news 2026/4/23 18:45:23

深度学习打卡第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/23 9:54:30

【智能制造典型场景参考指引(2025 年版)解读】 -产品研发环节

智能制造作为制造业转型升级的核心驱动力,通过深度融合新一代信息技术与先进制造技术,推动生产模式向数字化、网络化、智能化方向演进。智能制造典型场景参考指引(2025 年版)旨在为制造业企业提供可落地的典型场景参考&#xff0c…

作者头像 李华
网站建设 2026/4/23 9:55:19

LeetCode 面试经典150题之合并两个有序数组

LeetCode 面试经典150题之合并两个有序数组 一、题目 1.题目描述 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非…

作者头像 李华
网站建设 2026/4/23 9:55:33

大模型落地加速:15+15+8精选资源清单助力开发者攻克技术难关

大模型落地加速:15158精选资源清单助力开发者攻克技术难关 【免费下载链接】LongAlign-7B-64k 项目地址: https://ai.gitcode.com/zai-org/LongAlign-7B-64k 在人工智能技术迅猛发展的浪潮中,大语言模型(LLM)正经历着从实…

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

算法综合训练:五类编程题深度解析与实践(收藏这一篇就够了)

算法综合训练:五类编程题深度解析与实践 引言 算法是计算机科学的核心,也是编程能力的重要体现。在实际编程和算法竞赛中,我们常常会遇到各种类型的题目,它们考察不同的算法思想和编程技巧。本文将通过五类共十四道编程题的详细解…

作者头像 李华