retinanet.py 2.0 KB
Newer Older
B
Blake 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

from __future__ import absolute_import
from __future__ import division
from __future__ import print_function

from ppdet.core.workspace import register, create
from .meta_arch import BaseArch
import paddle

__all__ = ['RetinaNet']

F
Feng Ni 已提交
25

B
Blake 已提交
26 27 28 29
@register
class RetinaNet(BaseArch):
    __category__ = 'architecture'

F
Feng Ni 已提交
30
    def __init__(self, backbone, neck, head):
B
Blake 已提交
31 32 33 34 35 36 37 38
        super(RetinaNet, self).__init__()
        self.backbone = backbone
        self.neck = neck
        self.head = head

    @classmethod
    def from_config(cls, cfg, *args, **kwargs):
        backbone = create(cfg['backbone'])
F
Feng Ni 已提交
39

B
Blake 已提交
40 41
        kwargs = {'input_shape': backbone.out_shape}
        neck = create(cfg['neck'], **kwargs)
F
Feng Ni 已提交
42 43 44 45

        kwargs = {'input_shape': neck.out_shape}
        head = create(cfg['head'], **kwargs)

B
Blake 已提交
46 47 48
        return {
            'backbone': backbone,
            'neck': neck,
F
Feng Ni 已提交
49 50
            'head': head,
        }
B
Blake 已提交
51 52 53 54

    def _forward(self):
        body_feats = self.backbone(self.inputs)
        neck_feats = self.neck(body_feats)
F
Feng Ni 已提交
55 56 57 58 59 60 61 62

        if self.training:
            return self.head(neck_feats, self.inputs)
        else:
            head_outs = self.head(neck_feats)
            bbox, bbox_num = self.head.post_process(
                head_outs, self.inputs['im_shape'], self.inputs['scale_factor'])
            return {'bbox': bbox, 'bbox_num': bbox_num}
B
Blake 已提交
63 64

    def get_loss(self):
F
Feng Ni 已提交
65
        return self._forward()
B
Blake 已提交
66 67

    def get_pred(self):
F
Feng Ni 已提交
68
        return self._forward()