修改YOLOv5的模型结构第三弹

本文详细描述了在YOLOv5模型基础上,对C2模块进行深度修改的过程,包括结构调整、代码实现、配置文件修改以及解决训练时遇到的问题,最终成功训练出新的模型版本。

上次已经做了一个对YOLOv5的魔改任务,这次继续魔改。使用的素材还是之前说到的C2模块,但这次会对模型进行范围更大的修改

任务

将原模型修改为新模型
原模型如图:
原模型
新模型如图:
新模型

任务拆解

首先分析两个模型之间的改动有哪些

  • 第4层的C3*2修改为了C2*2
  • 第6层的C3*3修改为了C3*1
  • 移除了第7层的卷积
  • 移除了第8层的C3*1

其中C2模块是由C3模块修改而来,在之前的博客中也提到过,这里贴下图
C2模块

开始修改

C2模块

首先还是要先编写一个C2模块。打开models/common.py在class C3附近新建一个我们的C2模块

class C3(nn.Module):
    # CSP Bottleneck with 3 convolutions
    def __init__(self, c1, c2, n=1, shortcut=True, g=1, e=0.5):  # ch_in, ch_out, number, shortcut, groups, expansion
        super().__init__()
        c_ = int(c2 * e)  # hidden channels
        self.cv1 = Conv(c1, c_, 1, 1)
        self.cv2 = Conv(c1, c_, 1, 1)
        self.cv3 = Conv(2 * c_, c2, 1)  # optional act=FReLU(c2)
        self.m = nn.Sequential(*(Bottleneck(c_, c_, shortcut, g, e=1.0) for _ in range(n)))

    def forward(self, x):
        return self.cv3(torch.cat((self.m(self.cv1(x)), self.cv2(x)), 1))

class C2(nn.Module):
    def __init__(self, c1, c2, n=1, shortcut=True, g=1, e=0.5):
        super().__init__()
        c_1 = c2 // 2
        c_2 = c2 - c_1
        self.cv1 = Conv(c1, c_2, 1, 1)
        self.cv2 = Conv(c1, c_1, 1, 1)
        self.m = nn.Sequential(*(Bottleneck(c_2, c_2, shortcut, g, e=1.0) for _ in range(n)))

    def forward(self, x):
        return torch.cat((self.m(self.cv1(x)), self.cv2(x)), 1)

修改yolo.py

修改yolo.py中函数parse_model中的代码,使模型支持我们刚写的C2模块

def parse_model(d, ch):  # model_dict, input_channels(3)
    # Parse a YOLOv5 model.yaml dictionary
    LOGGER.info(f"\n{
     
     '':>3}{
     
     'from':>18}{
     
     'n':>3}{
     
     'params':>10}  {
     
     'module':<40}{
     
     'arguments':<30}")
    anchors, nc, gd, gw, act = d['anchors'], d['nc'], d['depth_multiple'], d['width_multiple'], d.get('activation')
    if act:
        Conv
### YOLOv5 常见问题及解决方法 #### 环境配置问题 在安装和运行 YOLOv5 时,环境配置是最常遇到的问题之一。通常情况下,这可能涉及依赖库版本不匹配或 CUDA 配置错误等问题。为了确保顺利运行,建议按照官方文档中的说明进行环境搭建,并确认所使用的 Python 版本以及 PyTorch 和 CUDA 的兼容性[^3]。 如果仍然出现问题,可以尝试重新创建虚拟环境并严格按照以下命令安装所需依赖项: ```bash pip install -r requirements.txt ``` #### 模型加载失败 当用户尝试加载预训练权重文件时,可能会因为路径设置错误或文件损坏而导致模型无法正常加载。此时应检查权重文件是否存在且未被篡改,并验证其路径是否正确指定。另外需要注意的是,不同版本之间可能存在接口差异,因此推荐下载对应版本的官方预训练模型以减少潜在冲突[^4]。 #### 自定义数据集训练过程中的报错 对于自定义数据集而言,标注格式不符合标准往往是引发一系列错误的根本原因。具体来说,VOC 或 COCO 类型的数据集中每张图片对应的 XML 文件或者 JSON 文件里各项参数必须严格遵循相应模板;而针对 txt 文档形式存储 bounding box 信息的情况,则需保证每一行都采用如下结构表示一个物体实例的位置坐标与类别索引号:`<class_id> <x_center> <y_center> <width> <height>` ,其中心点位置及宽高均相对于整幅图像尺寸进行了归一化处理[^3]。 此外,在执行 train.py 脚本之前还需仔细核验 data.yaml 文件的内容准确性——包括但不限于 classes 字段数值设定、train/test 图片目录绝对路径书写无误等方面。 #### 运行过程中出现 DeprecationWarning 关于 np.int 替代方案提示 随着 NumPy 更新迭代推进,部分旧版函数已被标记废弃状态。例如 `np.int`, `np.float` 等通用类型名称现已分别替换为更精确表述含义的新别名如 `np.int_`, `np.float64` 。所以在实际编码调试期间一旦发现此类警告消息出,则应当及时修改源码中涉及到这些已淘汰表达方式的地方以便适应最新规范要求[^4]。 ```python import numpy as np # 修改前可能导致警告 value = np.array([1], dtype=np.int) # 推荐做法 value = np.array([1], dtype=int) # 使用内置 int 类型替代 np.int # 或者显式指明新别名 value = np.array([1], dtype=np.int_) ``` #### GUI 应用集成挑战 虽然原始 YOLOv5 并不含自带图形界面支持功能,但借助第三方工具比如 PyQt5 可实现这一扩展需求。然而在此类场景下同样会面临诸多特有的技术难点,像跨线程通信机制设计不当就容易造成 UI 卡顿现象发生等等。对此可参考相关项目案例学习经验分享资料加以克服困难[^2]。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值