当前位置: 首页 > news >正文

深度学习打卡第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()

http://www.jsqmd.com/news/79620/

相关文章:

  • 团队协作神器!本地部署 ONLYOFFICE + cpolar,多人编辑文档超方便
  • 实用方法:轻松实现NCM文件格式转换的完整解析
  • 终极指南:快速掌握Scarab空洞骑士模组管理神器
  • 端侧多模态新纪元:MiniCPM-V 2.6重新定义移动端AI交互体验
  • 学习c语言第一天的学习笔记
  • 激活函数应该具有哪些特征
  • C++课后习题训练记录Day49
  • 【智能制造典型场景参考指引(2025 年版)解读】 -产品研发环节
  • 利用用户的通话记录、通讯录以及短信内容可以极大提高销售效率和精准度
  • 【YOLO11-MM 多模态目标检测】动态门控MCFGatedFusion特征融合【自研模块】、抛弃Concat、实现特征动态补偿
  • 技术工具类文章仿写专家Prompt指南
  • LeetCode 189. 旋转数组 | 三步反转最优解全拆解
  • 【YOLO11-MM 多模态目标检测】MSAA多尺度特征融合、轻量而且高效、抛弃Concat普通融合
  • 百度网盘高速下载工具使用手册:告别蜗牛速度的秘诀
  • LeetCode 49. 字母异位词分组 | 从排序到计数的哈希表优化之路
  • 终极英雄联盟智能助手:三步实现游戏自动化完全指南
  • 亲测!高性价比AI数字员工租赁公司分享
  • downkyi视频下载:告别卡顿与画质损失的终极解决方案
  • LLM本地推理全流程:基于LMDeploy的pipeline实战指南
  • 空洞骑士模组管理大师课:5个关键技巧让Scarab成为你的游戏管家
  • OpenAI开源安全推理引擎震撼发布:gpt-oss-safeguard改写AI内容治理规则
  • Linux基础命令和工具详解,让你轻松应对各种任务!
  • 匹配回文串:利用KMP算法求解
  • NCM文件转换神器:NCMconverter完全使用指南
  • Openresty基础知识详解:轻松驾驭高性能web网关
  • DPDK KNI 模块:高性能网络数据平面的内核交互桥梁
  • Flutter 设计系统构建指南
  • LeetCode 面试经典150题之合并两个有序数组
  • 代码生成效率革命:DeepSeek智能编码工具实战指南与技术解析
  • Openresty驱动下的高性能Web网关实战