"vscode:/vscode.git/clone" did not exist on "b9665e9b2fa6b5ea0f4702cc766f9977a99d76cf"
multi_modality_demo.py 2.34 KB
Newer Older
dingchang's avatar
dingchang committed
1
# Copyright (c) OpenMMLab. All rights reserved.
2
3
from argparse import ArgumentParser

ZCMax's avatar
ZCMax committed
4
import mmcv
5

ZCMax's avatar
ZCMax committed
6
7
8
from mmdet3d.apis import inference_multi_modality_detector, init_model
from mmdet3d.registry import VISUALIZERS
from mmdet3d.utils import register_all_modules
9

ZCMax's avatar
ZCMax committed
10
11

def parse_args():
12
13
    parser = ArgumentParser()
    parser.add_argument('pcd', help='Point cloud file')
14
    parser.add_argument('img', help='image file')
15
16
17
18
19
    parser.add_argument('ann', help='ann file')
    parser.add_argument('config', help='Config file')
    parser.add_argument('checkpoint', help='Checkpoint file')
    parser.add_argument(
        '--device', default='cuda:0', help='Device used for inference')
20
21
22
23
24
    parser.add_argument(
        '--cam-type',
        type=str,
        default='CAM_FRONT',
        help='choose camera type to inference')
25
26
27
28
    parser.add_argument(
        '--score-thr', type=float, default=0.0, help='bbox score threshold')
    parser.add_argument(
        '--out-dir', type=str, default='demo', help='dir to save results')
29
    parser.add_argument(
Zongbao Feng's avatar
Zongbao Feng committed
30
31
32
        '--show',
        action='store_true',
        help='show online visualization results')
33
34
35
    parser.add_argument(
        '--snapshot',
        action='store_true',
Zongbao Feng's avatar
Zongbao Feng committed
36
        help='whether to save online visualization results')
37
    args = parser.parse_args()
ZCMax's avatar
ZCMax committed
38
39
40
41
    return args


def main(args):
42
    # register all modules in mmdet3d into the registries
ZCMax's avatar
ZCMax committed
43
    register_all_modules()
44
45

    # build the model from a config file and a checkpoint file
46
    model = init_model(args.config, args.checkpoint, device=args.device)
ZCMax's avatar
ZCMax committed
47
48
49

    # init visualizer
    visualizer = VISUALIZERS.build(model.cfg.visualizer)
ChaimZhu's avatar
ChaimZhu committed
50
    visualizer.dataset_meta = model.dataset_meta
ZCMax's avatar
ZCMax committed
51
52

    # test a single image and point cloud sample
53
54
55
    result, data = inference_multi_modality_detector(model, args.pcd, args.img,
                                                     args.ann, args.cam_type)
    points = data['inputs']['points']
ZCMax's avatar
ZCMax committed
56
57
58
    img = mmcv.imread(args.img)
    img = mmcv.imconvert(img, 'bgr', 'rgb')
    data_input = dict(points=points, img=img)
59

60
    # show the results
ZCMax's avatar
ZCMax committed
61
62
63
64
65
66
    visualizer.add_datasample(
        'result',
        data_input,
        pred_sample=result,
        show=True,
        wait_time=0,
67
        out_file=args.out_dir,
ZCMax's avatar
ZCMax committed
68
69
        pred_score_thr=args.score_thr,
        vis_task='multi_modality-det')
70
71
72


if __name__ == '__main__':
ZCMax's avatar
ZCMax committed
73
74
    args = parse_args()
    main(args)