主干网络篇 | YOLOv5/v7 更换主干网络之 ResNet50/ResNet101 | 对比实验必备

主干网络篇 | YOLOv5/v7 更换主干网络之 ResNet50/ResNet101 | 对比实验必备

1. 简介

ResNet 是近年来最受欢迎的深度卷积神经网络架构之一,它以其优异的性能和鲁棒性而著称。ResNet50 和 ResNet101 是 ResNet 家族中最常用的两个模型,它们分别具有 50 层和 101 层残差块。

YOLOv5 和 YOLOv7 是目前流行的实时目标检测框架,它们以其快速、准确的检测性能而著称。然而,YOLOv5/v7 的默认主干网络通常是轻量级的,例如 Darknet53 或 CSPDarknet53,这可能会导致模型精度略逊于其他更复杂的模型。

将 ResNet50/ResNet101 作为主干网络替换 YOLOv5/v7 中原有骨干网络可以显著提高模型的精度,但同时也增加了模型的计算量。

2. 原理详解

ResNet 的核心思想是通过引入残差连接来解决深度卷积神经网络的梯度消失问题。残差连接可以将输入特征直接传递到输出特征,从而使梯度更容易流过网络。

ResNet 的基本结构如下图所示:

​编辑Opens in a new window​编辑www.researchgate.net

ResNet basic structure

ResNet50 和 ResNet101 的主要区别在于它们残差块的数量。ResNet50 具有 4 个阶段,每个阶段包含 3 个或 4 个残差块。ResNet101 具有 5 个阶段,每个阶段包含 3 个或 4 个残差块。

3. 应用场景解释

将 ResNet50/ResNet101 作为主干网络替换 YOLOv5/v7 中原有骨干网络具有以下优势:

  • 提高模型精度: ResNet50/ResNet101 在 ImageNet 数据集上取得了 76.1% 和 82.1% 的 Top-1 准确率,显著高于 YOLOv5/v7 默认主干网络的精度。
  • 扩展模型应用场景: ResNet50/ResNet101 可以应用于更复杂的场景,例如医学图像分析、遥感图像分析等。

4. 算法实现

将 ResNet50/ResNet101 作为主干网络替换 YOLOv5/v7 中原有骨干网络的具体步骤如下:

  1. 下载 ResNet50/ResNet101 预训练权重: 从 PyTorch 官方网站下载 ResNet50/ResNet101 预训练权重。
  2. 修改 YOLOv5/v7 代码: 修改 YOLOv5/v7 代码,将原有的骨干网络替换为 ResNet50/ResNet101。
  3. 训练模型: 如果需要,可以对模型进行微调以提高性能。

5. 完整代码实现

import torch
import torch.nn as nn
from torchvision.models import resnet50, resnet101class ResNetBackbone(nn.Module):def __init__(self, pretrained=True):super(ResNetBackbone, self).__init__()if pretrained:self.resnet = resnet50(pretrained=True)else:self.resnet = resnet50()self.layer1 = self.resnet.conv1self.layer2 = self.resnet.layer1self.layer3 = self.resnet.layer2self.layer4 = self.resnet.layer3def forward(self, x):x = self.layer1(x)x = self.layer2(x)x = self.layer3(x)x = self.layer4(x)return xdef get_resnet_backbone(pretrained=True):return ResNetBackbone(pretrained=pretrained)def get_backbone(name, **kwargs):"""Get a backbone by name."""if name == 'resnet50':return get_resnet_backbone(**kwargs)elif name == 'resnet101':return get_resnet_backbone(**kwargs)else:raise ValueError('Unknown backbone name: {}'.format(name))

 

6. 部署测试搭建实现

将 ResNet50/ResNet101 作为主干网络的 YOLOv5/v7 模型可以部署在各种平台上,包括:

  • CPU: ResNet50
        return get_resnet_backbone(**kwargs)else:raise ValueError('Unknown backbone name: {}'.format(name))

Python

import torch
import torch.nn as nn
from torch.hub import load_state_dict_from_urlclass Darknet(nn.Module):def __init__(self, pretrained=False, cfg='yolov5s.yaml'):super().__init__()if pretrained:print(f"Loading YOLOv5 {cfg} pretrained model")self.model = load_state_dict_from_url(f"https://github.com/ultralytics/yolov5/blob/master/models/{cfg}",strict=True,)else:print(f"Creating YOLOv5 {cfg} model")self.model = torch.hub.load("ultralytics/yolov5", cfg, pretrained=False)def forward(self, x):return self.model(x)def get_backbone(name, **kwargs):"""Get a backbone by name."""if name == 'darknet53':return Darknet(**kwargs)elif name == 'cspdarknet53':return CSPDarknet(**kwargs)else:raise ValueError('Unknown backbone name: {}'.format(name))def get_model(cfg, pretrained=False, backbone='darknet53'):"""Create a YOLOv5 model."""backbone = get_backbone(backbone, pretrained=pretrained)model = Model(backbone, cfg)return model

 

YOLOv7 完整代码实现

import torch
import torch.nn as nn
from ultralytics.models.common import ConvBNFuseclass Darknet(nn.Module):def __init__(self, pretrained=False, cfg='yolov7.yaml'):super().__init__()if pretrained:print(f"Loading YOLOv7 {cfg} pretrained model")self.model = load_state_dict_from_url(f"https://github.com/ultralytics/yolov7/blob/master/models/{cfg}",strict=True,)else:print(f"Creating YOLOv7 {cfg} model")self.model = torch.hub.load("ultralytics/yolov7", cfg, pretrained=False)def forward(self, x):return self.model(x)def get_backbone(name, **kwargs):"""Get a backbone by name."""if name == 'cspdarknet53':return CSPDarknet(**kwargs)elif name == 'cspdarknet53_v2':return CSPDarknetV2(**kwargs)else:raise ValueError('Unknown backbone name: {}'.format(name))def get_model(cfg, pretrained=False, backbone='cspdarknet53'):"""Create a YOLOv7 model."""backbone = get_backbone(backbone, pretrained=pretrained)model = Model(backbone, cfg)return model

 

HGNetv2 完整代码实现

import paddle
import paddle.nn as nn
from ppcv.modeling import backbonesclass HGNetv2(nn.Layer):def __init__(self, channels=[64, 128, 256, 512, 1024]):super(HGNetv2, self).__init__()self.stages = nn.Sequential(_hgnet_stage(channels[0], name='stage1'),_hgnet_stage(channels[1], name='stage2'),_hgnet_stage(channels[2], name='stage3'),_hgnet_stage(channels[3], name='stage4'),_hgnet_stage(channels[4], name='stage5'),)def forward(self, x):return self.stages(x)def _hgnet_stage(filters, name):return nn.Sequential(_hgnet_block(filters, name=name + '_block1'),_hgnet_block(filters, name=name + '_block2'),_hgnet_block(filters, name=name + '_block3'),)

6. 部署测试搭建实现

将 ResNet50/ResNet101 作为主干网络的 YOLOv5/v7 模型可以部署在各种平台上,包括:

  • CPU: ResNet50/ResNet101 的推理速度较慢,在 CPU 上部署可能会比较慢。
  • GPU: 在 GPU 上部署 ResNet50/ResNet101 可以获得更高的性能。
  • 服务器: ResNet50/ResNet101 可以部署在服务器上,用于处理大规模的目标检测任务。

部署测试搭建的具体步骤取决于所使用的平台和硬件。以下是一些通用的步骤:

  1. 安装依赖库: 安装 PyTorch、YOLOv5/v7 等必要的库。
  2. 下载模型权重: 下载训练好的 ResNet50/ResNet101 YOLOv5/v7 模型权重。
  3. 转换模型格式: 如果需要,将模型权重转换为目标平台的格式。
  4. 部署模型: 将模型部署到目标平台上。
  5. 测试模型: 测试模型的性能和精度。

7. 文献材料链接

  • Deep Residual Learning for Image Recognition
  • YOLOv5: An Enhanced Version of YOLOv3
  • PP-LCNet: An Efficient Convolutional Neural Network for Image Classification

8. 应用示例产品

将 ResNet50/ResNet101 作为主干网络的 YOLOv5/v7 模型已经应用于各种产品和场景中,例如:

  • 智能安防: ResNet50/ResNet101 可以用于智能安防系统,进行实时的人脸识别、物体识别等。
  • 自动驾驶: ResNet50/ResNet101 可以用于自动驾驶系统,进行障碍物检测、车道线识别等。
  • 医学图像分析: ResNet50/ResNet101 可以用于医学图像分析,进行病灶检测、器官分割等。

9. 总结

将 ResNet50/ResNet101 作为主干网络替换 YOLOv5/v7 中原有骨干网络可以显著提高模型的精度,但同时也增加了模型的计算量。

10. 影响

ResNet 的出现对深度卷积神经网络架构设计产生了深远的影响,它证明了通过引入残差连接可以有效地提高模型的性能和鲁棒性。

11. 未来扩展

未来,可以继续探索更有效的 ResNet 变体,并将其应用于更多类型的模型和任务中。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/31947.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习】stable-diffusion-webui AUTOMATIC1111 的参数解释翻译

https://github.com/AUTOMATIC1111/stable-diffusion-webui/wiki/Command-Line-Arguments-and-Settings 参数命令值默认值描述-h, --helpNoneFalse显示帮助信息并退出–exit安装后终止–data-dirDATA_DIR./存储所有用户数据的基本路径–configCONFIGconfigs/stable-diffusion/…

易管理工厂设备日志采集工具

免费试用下载: Gitee下载 最新版本 优势: A. 开箱即用. 解压直接运行.不需额外安装. B. 批管理设备. 设备配置均在后台管理. C. 无人值守 客户端自启动,自更新. D. 稳定安全. 架构简单,内存占用小,通过授权访问.

通过python脚本采集网络流量

#!/usr/bin/python # -*- coding:utf-8 -*- psutil模块是一个跨平台的获取进程和系统应用情况(CPU,内存,磁盘,网络,传感器)的库。 该模块用于系统监控、限制进程资源和运行进程的管理等方面。 网络信息 ps…

反激开关电源输出假负载

1、为何需要假负载? 开关电源芯片的占空比最小不可能做到0%,都有一个最小导通时间,不过最小导通时间,在规格书中,不一定给出来 注意:如果没有最小导通时间,就相当于芯片都停止输出了&#xff…

29-Linux--守护进程

一.基础概念 1.守护进程:精灵进程,在后台为用户提高服务,是一个生存周期长,通常独立于控制终端并且周期性的执行任务火处理事件发生 2.ps axj:查看守护进程 3.进程组:多个进程的集合,由于管理…

Flask之模板

前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除 目录 一、模板的基本用法 1.1、创建模板 1.2、模板语法 1.3、渲染模板 二、模板辅助工具 2.1、上下文 2.2、全局对象 2.3、过滤器 2.4、测试…

小米测开二面—80min中核

小米测开二面—80min中核 3.28 无自我介绍直接开问!你的第一份实习是一个开发工作你的第二实习为什么又跑到测试了你的第一份实习遇到了哪些挑战你的逆向开发的开发目标是什么,使用了什么工具你最终开发落地是用在了什么方面上,比如机器人路…

什么是云主机?

云主机是新一代的主机租借服务,它整合了高性能服务器与优质网络带宽,有用处理了传统主机租借价格偏高、服务品良莠不齐等缺陷,可全面满意中小企业、个人站长用户对主机租借服务低本钱,高牢靠,易办理的需求。   关于大…

C语言入门系列:可迁移的数据类型

文章目录 1,精确宽度类型(exact-width integer type)2,最小宽度类型(minimum width type)3,最快的最小宽度类型(fast minimum width type)4,可以保存指针的整数类型。5, …

编译 CanMV 固件

前言 上一章节中已经搭建好了基于 CanMV 的 C 开发环境,这么一来便可以进行基于 C 语言和 FreeRTOS 的应用开发或者编译基于 MicroPython 语法的应用开发方式所需的 CanMV 固件,本 章就将带领读者体验一下 CanMV 固件的编译流程。 本章分为如下几个小节&…

为什么print语句被Python3遗弃?

在开发和维护python项目的时候发现经常有print语句报错,原因是python3放弃了print语句 print 语句 早就被列在了不可靠的语言特性列表中,例如 Guido 的“Python 之悔”(Python Regrets)演讲【1】,并计划在 Python 300…

Python期末复习:基础+数据结构

合法的标识符定义规则 以字母或下划线开头: 标识符必须以字母(大写或小写)或下划线 _ 开头。 后续字符可以是字母、数字或下划线: 后续字符可以是字母(大写或小写)、数字(0-9&#xff09…

Unity 从0开始编写一个技能编辑器_02_Buff系统的Handler

BuffHandler可以是用于处理角色身上buff的Mono类,任何具备跟Buff交互的角色,都要携带这个BuffHandler脚本。如果你的Buff有额外的处理机制,比如互斥Buff(如:免疫负面效果的霸体),需要在AddBuff方…

Anthropic AI模型Claude 3.5 Sonnet在Amazon Bedrock上正式可用

Claude 3.5 Sonnet是Anthropic最先进的Claude系列AI模型的新成员,比Claude 3 Opus更智能且价格只有其五分之一 北京——2024年6月21日 亚马逊云科技宣布,Anthropic最新、最强大的模型Claude 3.5 Sonnet现已在Amazon Bedrock上正式可用,该模型…

增强-MIGO物料消耗需要将物料描述写到会计凭证的摘要里面

财务比较闲提的需求,有些物料消耗需要将物料描述写到会计凭证的摘要里面, 找了一下增强点,随便搞了一下,可以了。

20240622 每日AI必读资讯

🤖力压GPT-4o!新王Claude 3.5 Sonnet来了,直接免费可用 - 新模型在推理、知识和编码能力评估方面超越了以前的版本和竞争对手GPT 4o模型,同时其运行速度是Claude 3 Opus的两倍。 - 该模型可在http://Claude.ai和Claude iOS应用上…

Spring Bean 生命周期详解

Spring Bean 生命周期详解 在 Spring 框架中,Bean 的生命周期由 Spring 容器全权管理。了解和掌握 Bean 的生命周期对于使用 Spring 开发稳定且高效的应用程序至关重要。本文将详细介绍 Spring Bean 生命周期的五个主要阶段:实例化、属性注入、初始化、…

如何用vscode编写一个GO语言的入门代码

本章教程,主要介绍如何在VSCODE中,运行GO语言的入门代码。 一、准备一个GO语言代码 一个很简单的代码,用GO语言在控制台打印输出:Hello, World! package mainimport "fmt"func main() {fmt.Println("Hello, World!") }二、安装GO语言SDK 下载地址:

云服务与低代码开发的结合:重塑现代软件开发模式

随着数字化转型的深入推进,越来越多的企业开始将业务迁移到云端,以实现更高的灵活性、可靠性和成本效益。云服务已经成为企业数字化战略的重要组成部分。与此同时,低代码开发作为一种新兴的编程模式,也逐渐受到企业的关注。那么&a…

keepalive+nginx高可用架构

keepalivenginx架构 一.配置真实服务器web1和web2 1.关闭防火墙,并在真实服务器下载http服务 [rootlocalhost ~]# systemctl stop firewalld.service [rootlocalhost ~]# setenforce 0 [rootlocalhost ~]# yum install httpd -y 2.分别在web1和web2上制作网页…