【YOLOv8改进 - 特征融合NECK】Slim-neck:目标检测新范式,既轻量又涨点

news/2024/9/24 18:01:39

YOLO目标检测创新改进与实战案例专栏

专栏目录: YOLO有效改进系列及项目实战目录 包含卷积,主干 注意力,检测头等创新机制 以及 各种目标检测分割项目实战案例

专栏链接: YOLO基础解析+创新改进+实战案例

介绍

image-20240622102155148

摘要

目标检测是计算机视觉中的一项重要下游任务。对于车载边缘计算平台来说,巨大的模型难以满足实时检测的要求,而由大量深度可分离卷积层构建的轻量化模型无法达到足够的准确性。我们引入了一种新的轻量级卷积技术,GSConv,以减轻模型的重量但保持准确性。GSConv 在模型的准确性和速度之间实现了出色的平衡。我们还提供了一种设计范式,称为 slim-neck,以实现检测器更高的计算成本效益。我们的方法在超过二十组比较实验中得到了稳健验证。特别是,通过我们的方法改进后的检测器在与原始版本相比时取得了最先进的结果(例如,在 Tesla T4 GPU 上以约 100FPS 的速度在 SODA10M 数据集上达到 70.9% mAP0.5)。代码可在 https://github.com/alanli1997/slim-neck-by-gsconv 获得。

文章链接

论文地址:论文地址

代码地址:代码地址

基本原理

Slim-Neck是一种用于目标检测器架构的设计范式,旨在通过引入轻量级卷积技术GSConv来实现在维持准确性的同时满足实时检测需求。Slim-Neck的设计理念是在保持准确性的同时提高检测器的计算成本效益。GSConv是一种通用的卷积方法,旨在减少计算复杂性,降低推理时间,并保持模型的准确性。

Slim-Neck的设计原理包括以下几个关键点:

  1. GSConv:GSConv是Slim-Neck中的关键技术,它通过减少冗余信息和压缩不必要的重复信息来降低计算复杂性。GSConv在颈部阶段处理连接的特征图,这时特征图已经变得足够纤细,通道维度达到最大,宽度和高度维度达到最小,从而使得转换更加适度。
  2. 纤细颈部设计:Slim-Neck通过设计纤细的颈部结构来降低检测器的计算复杂性和推理时间,同时保持准确性。这种设计受到了DensNet、VoVNet和CSPNet等方法的启发,旨在提高CNNs的学习能力。
  3. 结构设计:Slim-Neck的结构设计旨在降低计算复杂性,同时保持准确性。通过合理设计的结构,Slim-Neck能够在保持准确性的同时提高计算效率,特别适用于轻量级检测器,如YOLOv3/v4-tiny。

image-20240622102251617

yolov8 代码引入


class GSConvns(GSConv):# GSConv with a normative-shuffle https://github.com/AlanLi1997/slim-neck-by-gsconvdef __init__(self, c1, c2, k=1, s=1, g=1, act=True):super().__init__(c1, c2, k=1, s=1, g=1, act=True)c_ = c2 // 2self.shuf = nn.Conv2d(c_ * 2, c2, 1, 1, 0, bias=False)def forward(self, x):x1 = self.cv1(x)x2 = torch.cat((x1, self.cv2(x1)), 1)# normative-shuffle, TRT supportedreturn nn.ReLU(self.shuf(x2))class GSBottleneck(nn.Module):# GS Bottleneck https://github.com/AlanLi1997/slim-neck-by-gsconvdef __init__(self, c1, c2, k=3, s=1, e=0.5):super().__init__()c_ = int(c2*e)# for lightingself.conv_lighting = nn.Sequential(GSConv(c1, c_, 1, 1),GSConv(c_, c2, 3, 1, act=False))self.shortcut = Conv(c1, c2, 1, 1, act=False)def forward(self, x):return self.conv_lighting(x) + self.shortcut(x)class DWConv(Conv):# Depth-wise convolution classdef __init__(self, c1, c2, k=1, s=1, act=True):  # ch_in, ch_out, kernel, stride, padding, groupssuper().__init__(c1, c2, k, s, g=math.gcd(c1, c2), act=act)class GSBottleneckC(GSBottleneck):# cheap GS Bottleneck https://github.com/AlanLi1997/slim-neck-by-gsconvdef __init__(self, c1, c2, k=3, s=1):super().__init__(c1, c2, k, s)self.shortcut = DWConv(c1, c2, k, s, act=False)class VoVGSCSP(nn.Module):# VoVGSCSP module with GSBottleneckdef __init__(self, c1, c2, n=1, shortcut=True, g=1, e=0.5):super().__init__()c_ = int(c2 * e)  # hidden channelsself.cv1 = Conv(c1, c_, 1, 1)self.cv2 = Conv(c1, c_, 1, 1)# self.gc1 = GSConv(c_, c_, 1, 1)# self.gc2 = GSConv(c_, c_, 1, 1)# self.gsb = GSBottleneck(c_, c_, 1, 1)self.gsb = nn.Sequential(*(GSBottleneck(c_, c_, e=1.0) for _ in range(n)))self.res = Conv(c_, c_, 3, 1, act=False)self.cv3 = Conv(2 * c_, c2, 1)  #def forward(self, x):x1 = self.gsb(self.cv1(x))y = self.cv2(x)return self.cv3(torch.cat((y, x1), dim=1))class VoVGSCSPC(VoVGSCSP):# cheap VoVGSCSP module with GSBottleneckdef __init__(self, c1, c2, n=1, shortcut=True, g=1, e=0.5):super().__init__(c1, c2)c_ = int(c2 * 0.5)  # hidden channelsself.gsb = GSBottleneckC(c_, c_, 1, 1)

task与yaml配置

详见:https://blog.csdn.net/shangyanaf/article/details/139878671

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

使用某雷加速器后,无法链接网络

本人情况:在使用某雷加速器后,再次开机连接网络(校园网),可以连接,但没有弹窗或不可使用该网络! (只有再次打开该加速器网络才可用) ①点击下放搜索栏,输入:cmd②点击“以管理员身份打开” ③输入“netsh winsock reset” ④根据要求重启电脑(如果出现异常可以再次重…

ASCII 表

ASCII 表ASCII 表 https://www.runoob.com/w3cnote/ascii.html网站:http://shibowl.topgithub:https://github.com/hanbinjxnc博客园:https://www.cnblogs.com/hool 博客:https://blog.shibowl.top淘宝店:https://boxunwl.taobao.com/ 作者:世博 2019年4月28日

记一次https通讯调试过程

情况说明:和服务端https交互时,用域名的方式会有正常的应答,用指定IP的方式则提示异常。 代码抛出异常如下:javax.net.ssl.SSLHandshakeException:Remote host closed connection during handshake at com.sun.net.ssl.internal.ssl.SSLSocketImpl.readRecord(SSLSocketImp…

【YOLOv8改进 - 特征融合NECK】 HS-FPN :用于处理多尺度特征融合的网络结构,降低参数

摘要 在标准的医院血液检测中,传统过程需要医生使用显微镜从患者的血液显微图像中手动分离白细胞。然后,这些分离出的白细胞通过自动白细胞分类器进行分类,以确定血液样本中不同类型白细胞的比例和数量,从而辅助疾病诊断。这种方法不仅耗时费力,而且由于图像质量和环境条件…

VM Ware虚拟机设置静态IP(NAT模式)

设置VM Ware虚拟机静态IP 解决步骤 1. 确保VM Ware相关服务正常启用 “此电脑”-->右击“管理”,在服务中看VM Ware的相关服务是否已经开启,确保已开启。2. 设置VM Ware虚拟网络编辑器 在VM Ware 顶部菜单栏 --> “编辑” --> “虚拟网络编辑器”3. 编辑虚拟机设置4…

dotnet 6 破坏性改动 仅引用程序集输出路径变更

在 dotnet 5 开始,可以设置 ProduceReferenceAssembly 为 true 让项目构建时输出仅引用程序集。仅引用程序集是仅导出项目的公开成员定义,而不包含具体的实现的代码逻辑。只用来被其他项目引用,体积很小,但不用来作为最终发布文件在此前的如下博客里面已经告诉大家如何创建…

又跳槽!3年java经验offer收割机的面试心得

中厂->阿里->字节,成都->杭州->成都 系列文章目录和关于我 0.前言 笔者在不足两年经验的时候从成都一家金融科技中厂跳槽到杭州阿里淘天集团,又于今年5月份从杭州淘天跳槽到成都字节。自认为自己在面试这方面有一点心得,处于记录和分享的目的便有了此文,此文纯…

Git的安装及使用

官网:Git for Windows 点击下载安装。右击鼠标会出现GUI和Bash 选择git bash here 配置全局用户名和邮箱(gitee)git config --global user.name "你的名字" git config --global user.email 你的邮箱 查看配置git config user.name git config –list 配置 SSH…