当前位置:   article > 正文

【mmsegmentation】踩坑指南----config中的loss_weight调整_mmseg 类别loss加权 class_loss

mmseg 类别loss加权 class_loss

最近在试mmseg项目中各种模型的参数调整实验,关注到一个class_weight参数,按照官网说明,这个参数是可以调节样本不平衡带来的拟合问题,提升算法精度的一个手段。一般实现在config文件中的decode_head中,默认所有类别样本的class_weight权重是一样的。下面就以例子来进行说明。

../configs/_base_/models/ann_r50-d8.py

  1. # model settings
  2. norm_cfg = dict(type='SyncBN', requires_grad=True)
  3. model = dict(
  4. type='EncoderDecoder',
  5. pretrained='open-mmlab://resnet50_v1c',
  6. backbone=dict(
  7. type='ResNetV1c',
  8. depth=50,
  9. num_stages=4,
  10. out_indices=(0, 1, 2, 3),
  11. dilations=(1, 1, 2, 4),
  12. strides=(1, 2, 1, 1),
  13. norm_cfg=norm_cfg,
  14. norm_eval=False,
  15. style='pytorch',
  16. contract_dilation=True),
  17. decode_head=dict(
  18. type='ANNHead',
  19. in_channels=[1024, 2048],
  20. in_index=[2, 3],
  21. channels=512,
  22. project_channels=256,
  23. query_scales=(1, ),
  24. key_pool_scales=(1, 3, 6, 8),
  25. dropout_ratio=0.1,
  26. num_classes=19,
  27. norm_cfg=norm_cfg,
  28. align_corners=False,
  29. loss_decode=dict(
  30. type='CrossEntropyLoss', use_sigmoid=False, loss_weight=1.0)),
  31. auxiliary_head=dict(
  32. type='FCNHead',
  33. in_channels=1024,
  34. in_index=2,
  35. channels=256,
  36. num_convs=1,
  37. concat_input=False,
  38. dropout_ratio=0.1,
  39. num_classes=19,
  40. norm_cfg=norm_cfg,
  41. align_corners=False,
  42. loss_decode=dict(
  43. type='CrossEntropyLoss', use_sigmoid=False, loss_weight=0.4)),
  44. # model training and testing settings
  45. train_cfg=dict(),
  46. test_cfg=dict(mode='whole'))

可以看到,默认的numclass=19,即表示19类中每类样本的class_weight贡献值是相等的。

根据样本数量来 更改loss_weight的权重:假如num_classes=9,且样本分布不平衡,为下图所示这样:

即可根据样本分布来合理调整类别损失权重,样本数量越少,就增加其class_weight权重,反之样本量越大,其class_weight权重就随之减少,但是不能增加或减少的太多,会导致模型训练不收敛。不仅没有提升模型性能,反而降低了。

更改class_weight为:

  1. decode_head=dict(
  2. type='ANNHead',
  3. in_channels=[1024, 2048],
  4. in_index=[2, 3],
  5. channels=512,
  6. project_channels=256,
  7. query_scales=(1, ),
  8. key_pool_scales=(1, 3, 6, 8),
  9. dropout_ratio=0.1,
  10. num_classes=9,
  11. norm_cfg=norm_cfg,
  12. align_corners=False,
  13. loss_decode=dict(
  14. type='CrossEntropyLoss', use_sigmoid=False, loss_weight=1.0,
  15. class_weight=[
  16. 0.8373, 0.918, 1.166, 0.9539, 1.1766, 0.1869, 0.9954, 1.1489,1.0152
  17. ])),

修改class_weight的结果前后对比(红色为修改后)

 

整理不易,欢迎一键三连!!!

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