当前位置:   article > 正文

yolov5增加小目标检测层

小目标检测层



一,model文件解释

yolov5的模型配置文件如下:

  1. # parameters
  2. nc: 80 # number of classes
  3. depth_multiple: 1.0 # model depth multiple
  4. width_multiple: 1.0 # layer channel multiple
  5. # anchors
  6. anchors:
  7. - [10,13, 16,30, 33,23] # P3/8
  8. - [30,61, 62,45, 59,119] # P4/16
  9. - [116,90, 156,198, 373,326] # P5/32
  10. # YOLOv5 backbone
  11. backbone:
  12. # [from, number, module, args]
  13. [[-1, 1, Focus, [64, 3]], # 0-P1/2
  14. [-1, 1, Conv, [128, 3, 2]], # 1-P2/4
  15. [-1, 3, BottleneckCSP, [128]],
  16. [-1, 1, Conv, [256, 3, 2]], # 3-P3/8
  17. [-1, 9, BottleneckCSP, [256]],
  18. [-1, 1, Conv, [512, 3, 2]], # 5-P4/16
  19. [-1, 9, BottleneckCSP, [512]],
  20. [-1, 1, Conv, [1024, 3, 2]], # 7-P5/32
  21. [-1, 1, SPP, [1024, [5, 9, 13]]],
  22. [-1, 3, BottleneckCSP, [1024, False]], # 9
  23. ]
  24. # YOLOv5 head
  25. head:
  26. [[-1, 1, Conv, [512, 1, 1]],
  27. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  28. [[-1, 6], 1, Concat, [1]], # cat backbone P4
  29. [-1, 3, BottleneckCSP, [512, False]], # 13
  30. [-1, 1, Conv, [256, 1, 1]],
  31. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  32. [[-1, 4], 1, Concat, [1]], # cat backbone P3
  33. [-1, 3, BottleneckCSP, [256, False]], # 17 (P3/8-small)
  34. [-1, 1, Conv, [256, 3, 2]],
  35. [[-1, 14], 1, Concat, [1]], # cat head P4
  36. [-1, 3, BottleneckCSP, [512, False]], # 20 (P4/16-medium)
  37. [-1, 1, Conv, [512, 3, 2]],
  38. [[-1, 10], 1, Concat, [1]], # cat head P5
  39. [-1, 3, BottleneckCSP, [1024, False]], # 23 (P5/32-large)
  40. [[17, 20, 23], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
  41. ]

1.类别数和模型深度宽度控制

  1. # parameters
  2. nc: 80 # number of classes
  3. depth_multiple: 1.0 # model depth multiple
  4. width_multiple: 1.0 # layer channel multiple

nc:代表类别数
depth_multiple:模型深度参数
width_multiple:模型宽度参数
其中模型深度宽度控制,是通过上面两个参数,作用于BottleneckCSP。
2.初始Anchor参数

  1. # anchors
  2. anchors:
  3. - [10,13, 16,30, 33,23] # P3/8
  4. - [30,61, 62,45, 59,119] # P4/16
  5. - [116,90, 156,198, 373,326] # P5/32

原始模型,只有三个检测层,因此对应三组初始化Anchor值。当输入图像尺寸为640X640时,# P3/8 对应的检测层大小为80X80大小,可以用来检测大小在8X8以上的目标。# P4/16对应的检测层大小为40X40大小,可以用来检测大小在16X16以上的目标。# P5/32对应的检测层大小为20X20大小,可以用来检测32X32以上的目标。
3.骨干网络

  1. # YOLOv5 backbone
  2. backbone:
  3. # [from, number, module, args]
  4. [[-1, 1, Focus, [64, 3]], # 0-P1/2
  5. [-1, 1, Conv, [128, 3, 2]], # 1-P2/4
  6. [-1, 3, BottleneckCSP, [128]],
  7. [-1, 1, Conv, [256, 3, 2]], # 3-P3/8
  8. [-1, 9, BottleneckCSP, [256]],
  9. [-1, 1, Conv, [512, 3, 2]], # 5-P4/16
  10. [-1, 9, BottleneckCSP, [512]],
  11. [-1, 1, Conv, [1024, 3, 2]], # 7-P5/32
  12. [-1, 1, SPP, [1024, [5, 9, 13]]],
  13. [-1, 3, BottleneckCSP, [1024, False]], # 9
  14. ]

这一段配置主要是为了提取图像特征
4.检测头部

  1. # YOLOv5 head
  2. head:
  3. [[-1, 1, Conv, [512, 1, 1]],
  4. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  5. [[-1, 6], 1, Concat, [1]], # cat backbone P4
  6. [-1, 3, BottleneckCSP, [512, False]], # 13
  7. [-1, 1, Conv, [256, 1, 1]],
  8. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  9. [[-1, 4], 1, Concat, [1]], # cat backbone P3
  10. [-1, 3, BottleneckCSP, [256, False]], # 17 (P3/8-small)
  11. [-1, 1, Conv, [256, 3, 2]],
  12. [[-1, 14], 1, Concat, [1]], # cat head P4
  13. [-1, 3, BottleneckCSP, [512, False]], # 20 (P4/16-medium)
  14. [-1, 1, Conv, [512, 3, 2]],
  15. [[-1, 10], 1, Concat, [1]], # cat head P5
  16. [-1, 3, BottleneckCSP, [1024, False]], # 23 (P5/32-large)
  17. [[17, 20, 23], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
  18. ]

这一段配置,实际上包括了两个部分,即颈部(Neck)和Prediction,在颈部,主要利用类似FPN+PAN的方式。对骨干网络提取到的特征,进行多尺度融合处理。再送入检测层。
在yolov3中,该阶段只用到了FPN融合,FPN是一种自顶向下传达强语义特征的网络,即一个正金字塔形结构,融合的特征图越来越小。在yolov5中,除了使用FPN结构对特征进行融合,还使用到了PAN结构,PAN与FPN网络正好相反,是一个倒金字塔结构,自底向上传达强定位特征。两者相互结合。



二,增加小目标的配置文件

  1. # parameters
  2. nc: 1 # number of classes
  3. depth_multiple: 1.0 # model depth multiple
  4. width_multiple: 1.0 # layer channel multiple
  5. # anchors
  6. anchors:
  7. - [5,6, 8,14, 15,11] #4
  8. - [10,13, 16,30, 33,23] # P3/8
  9. - [30,61, 62,45, 59,119] # P4/16
  10. - [116,90, 156,198, 373,326] # P5/32
  11. # YOLOv5 backbone
  12. backbone:
  13. # [from, number, module, args]
  14. [[-1, 1, Focus, [64, 3]], # 0-P1/2
  15. [-1, 1, Conv, [128, 3, 2]], # 1-P2/4
  16. [-1, 3, BottleneckCSP, [128]], #160*160
  17. [-1, 1, Conv, [256, 3, 2]], # 3-P3/8
  18. [-1, 9, BottleneckCSP, [256]], #80*80
  19. [-1, 1, Conv, [512, 3, 2]], # 5-P4/16
  20. [-1, 9, BottleneckCSP, [512]], #40*40
  21. [-1, 1, Conv, [1024, 3, 2]], # 7-P5/32
  22. [-1, 1, SPP, [1024, [5, 9, 13]]],
  23. [-1, 3, BottleneckCSP, [1024, False]], # 9 20*20
  24. ]
  25. # YOLOv5 head
  26. head:
  27. [[-1, 1, Conv, [512, 1, 1]], #20*20
  28. [-1, 1, nn.Upsample, [None, 2, 'nearest']], #40*40
  29. [[-1, 6], 1, Concat, [1]], # cat backbone P4 40*40
  30. [-1, 3, BottleneckCSP, [512, False]], # 13 40*40
  31. [-1, 1, Conv, [512, 1, 1]], #40*40
  32. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  33. [[-1, 4], 1, Concat, [1]], # cat backbone P3 80*80
  34. [-1, 3, BottleneckCSP, [512, False]], # 17 (P3/8-small) 80*80
  35. [-1, 1, Conv, [256, 1, 1]], #18 80*80
  36. [-1, 1, nn.Upsample, [None, 2, 'nearest']], #19 160*160
  37. [[-1, 2], 1, Concat, [1]], #20 cat backbone p2 160*160
  38. [-1, 3, BottleneckCSP, [256, False]], #21 160*160
  39. [-1, 1, Conv, [256, 3, 2]], #22 80*80
  40. [[-1, 18], 1, Concat, [1]], #23 80*80
  41. [-1, 3, BottleneckCSP, [256, False]], #24 80*80
  42. [-1, 1, Conv, [256, 3, 2]], #25 40*40
  43. [[-1, 14], 1, Concat, [1]], # 26 cat head P4 40*40
  44. [-1, 3, BottleneckCSP, [512, False]], # 27 (P4/16-medium) 40*40
  45. [-1, 1, Conv, [512, 3, 2]], #28 20*20
  46. [[-1, 10], 1, Concat, [1]], #29 cat head P5 #20*20
  47. [-1, 3, BottleneckCSP, [1024, False]], # 30 (P5/32-large) 20*20
  48. [[21, 24, 27, 30], 1, Detect, [nc, anchors]], # Detect(p2, P3, P4, P5)
  49. ]

可以看到,主要对两个地方进行了修改
1.初始Anchor设置

  1. # anchors
  2. anchors:
  3. - [5,6, 8,14, 15,11] #4
  4. - [10,13, 16,30, 33,23] # P3/8
  5. - [30,61, 62,45, 59,119] # P4/16
  6. - [116,90, 156,198, 373,326] # P5/32

这里的修改,主要是增加了一组Anchor;在这里没什么要求,只要数值小一点就行
2.检测头部

  1. # YOLOv5 head
  2. head:
  3. [[-1, 1, Conv, [512, 1, 1]], #20*20
  4. [-1, 1, nn.Upsample, [None, 2, 'nearest']], #40*40
  5. [[-1, 6], 1, Concat, [1]], # cat backbone P4 40*40
  6. [-1, 3, BottleneckCSP, [512, False]], # 13 40*40
  7. [-1, 1, Conv, [512, 1, 1]], #40*40
  8. [-1, 1, nn.Upsample, [None, 2, 'nearest']],
  9. [[-1, 4], 1, Concat, [1]], # cat backbone P3 80*80
  10. [-1, 3, BottleneckCSP, [512, False]], # 17 (P3/8-small) 80*80
  11. [-1, 1, Conv, [256, 1, 1]], #18 80*80
  12. [-1, 1, nn.Upsample, [None, 2, 'nearest']], #19 160*160
  13. [[-1, 2], 1, Concat, [1]], #20 cat backbone p2 160*160
  14. [-1, 3, BottleneckCSP, [256, False]], #21 160*160
  15. [-1, 1, Conv, [256, 3, 2]], #22 80*80
  16. [[-1, 18], 1, Concat, [1]], #23 80*80
  17. [-1, 3, BottleneckCSP, [256, False]], #24 80*80
  18. [-1, 1, Conv, [256, 3, 2]], #25 40*40
  19. [[-1, 14], 1, Concat, [1]], # 26 cat head P4 40*40
  20. [-1, 3, BottleneckCSP, [512, False]], # 27 (P4/16-medium) 40*40
  21. [-1, 1, Conv, [512, 3, 2]], #28 20*20
  22. [[-1, 10], 1, Concat, [1]], #29 cat head P5 #20*20
  23. [-1, 3, BottleneckCSP, [1024, False]], # 30 (P5/32-large) 20*20
  24. [[21, 24, 27, 30], 1, Detect, [nc, anchors]], # Detect(p2, P3, P4, P5)
  25. ]

在这一部分,主要增加了几个操作层,在第17层后,继续对特征图进行上采样等处理,使得特征图继续扩大,同时在第20层时,将获取到的大小为160X160的特征图与骨干网络中第2层特征图进行concat融合,以此获取更大的特征图进行小目标检测。
在第31层,即检测层,增加小目标检测层,一共使用四层[21, 24, 27, 30]进行检测。
在增加检测层后,带来的问题就是计算量增加,导致推理检测速度降低。不过对于小目标,确实有很好的改善。



三,检测效果

解释:为了测试性能,将一张包含众多文本目标的图像,复制四份,拼接成一张大图,原始图像尺寸达到7503X5588。输入测试网络尺寸为640X640大小。

增加小目标检测层后,对于小目标具有更好的检测效果!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/579007
推荐阅读
相关标签
  

闽ICP备14008679号