对mmdetection代码设计的简单理解及代码修改

代码的整体结构及每部分含义网络上已有很多资料,这里不再赘述。但网上很少见到对mmdetection代码设计模式的讲解,所以记录一下自己的理解,及快速修改代码的方式吧(以faster-rcnn为例)。

为了更简单的理解mmdetection的设计,我打算从修改rpn proposal的采样代码说起。rpn proposal的采样目的是在一堆anchor中选择其中一部分,作为proposal,在rpn网络中用于回归bbox及正负例的分类。因此先看rpn在整个faster-rcnn流程中所处的位置:它在mmdet->models->detectors->two_stage.py中。
在这里插入图片描述

图1
two_stage.py代表的并不是faster-rcnn,而是一个二阶段网络的训练框架。这个二阶段网络可以是cascade_rcnn,double_head_rcnn等,由于它们都是二阶段网络,因此把它们共性的部分抽取出来,写成了two_stage.py这个文件,当具体到要使用faster-rcnn时,再对two_stage.py加上faster-rcnn的配置。增加方法是在配置文件faster_rcnn_r50_fpn_1x_lvis.py(以下简称cfg文件)中,model的type设置为’FasterRCNN’。但是这个设置是怎么起作用的呢?

先看mmdet->models->detectors->faster_rcnn.py的头文件:

from ..registry import DETECTORS
from .two_stage import TwoStageDetector

这里导入了TwoStageDetector包,而TwoStageDetector正是定义在two_stage.py中的类。
再看FasterRCNN类:

@DETECTORS.register_module
class FasterRCNN(TwoStageDetector):

FasterRCNN类继承了TwoStageDetector,那就拥有了TwoStageDetector的全部属性,并且配置遵循FasterRCNN类。

再回过头看看mmdet->models->detectors->faster_rcnn.py中detectors这个文件夹。文件夹下有__init__.py文件,

__all__ = [
    'BaseDetector', 'SingleStageDetector', 'TwoStageDetector', 'RPN',
    'FastRCNN', 'FasterRCNN', 'MaskRCNN', 'CascadeRCNN', 'HybridTaskCascade',
    'DoubleHeadRCNN', 'RetinaNet', 'FCOS', 'GridRCNN', 'MaskScoringRCNN',
    'RepPointsDetector', 'FOVEA', 'GroupSoftmax', 'DCM'
]

包含了’TwoStageDetector’和’FasterRCNN’两个类。

至此对mmdetection代码设计做一个小小的总结。mmdetection先把模型抽象成一个共性结构two_stage.py,然后通过cfg文件中的字段给这个共性结构增加相应的属性,使之变成一个具体的模型,如faster-rcnn。增加相应属性的方式是:为这个属性单独写一个类,并且继承这个共性结构。为了让这个属性得以调用,还需修改当前文件夹下__init__.py文件。mmdetection这种设计非常方便,如果需要修改共性结构,则直接改two_stage.py,若要增加属性直接写一个文件,这样代码结构就十分清晰,书写方便。

除了模型代码是按上述方式设计,模型中每个模块的设计方式类似,就不举例了。

现在可以开始修改rpn proposal的采样代码了。
先看原始rpn proposal采样在cfg文件中的样子:
在这里插入图片描述

图2

在train_cfg->rpn->sampler中,类型设置为type = ‘RandomSampler’。根据需求选择mmdet->core->bbox->samplers中相应的采样器,修改这个type字段即可。

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
mmdetection代码修改可以通过以下步骤完成: 1. 首先,你可以根据自己的需求,修改mmdetection中的共性结构文件two_stage.py。这个文件抽象了模型的共性结构,并提供了一些基本的属性和方法。 2. 接下来,你可以通过修改cfg文件中的字段来增加模型的具体属性。比如,如果你想要修改faster-rcnn模型,可以在cfg文件中相应的字段中增加属性。 3. 为了增加属性,你需要创建一个新的类,并继承共性结构two_stage.py。在这个类中,你可以定义新的属性和方法,以满足你的需求。 4. 为了让新的属性得以调用,你还需要修改当前文件夹下的__init__.py文件。在__init__.py文件中,你可以将新的类添加到__all__列表中。 通过以上步骤,你可以很方便地对mmdetection进行代码修改。如果你需要修改共性结构,直接修改two_stage.py文件即可。如果你需要增加属性,只需创建一个新的类并继承共性结构,然后在__init__.py文件中添加该类即可。这样的设计使得代码结构清晰,方便书写。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [对mmdetection代码设计简单理解代码修改](https://blog.csdn.net/chenxi1900/article/details/122590855)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值