pcd_demo.py 1.83 KB
Newer Older
dingchang's avatar
dingchang committed
1
# Copyright (c) OpenMMLab. All rights reserved.
wuyuefeng's avatar
Demo  
wuyuefeng committed
2
3
from argparse import ArgumentParser

ZCMax's avatar
ZCMax committed
4
5
from mmdet3d.apis import inference_detector, init_model
from mmdet3d.registry import VISUALIZERS
wuyuefeng's avatar
Demo  
wuyuefeng committed
6

ZCMax's avatar
ZCMax committed
7
8

def parse_args():
wuyuefeng's avatar
Demo  
wuyuefeng committed
9
10
11
12
13
14
15
    parser = ArgumentParser()
    parser.add_argument('pcd', help='Point cloud 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')
    parser.add_argument(
16
        '--score-thr', type=float, default=0.0, help='bbox score threshold')
wuyuefeng's avatar
Demo  
wuyuefeng committed
17
18
    parser.add_argument(
        '--out-dir', type=str, default='demo', help='dir to save results')
19
    parser.add_argument(
Zongbao Feng's avatar
Zongbao Feng committed
20
21
22
        '--show',
        action='store_true',
        help='show online visualization results')
23
24
25
    parser.add_argument(
        '--snapshot',
        action='store_true',
Zongbao Feng's avatar
Zongbao Feng committed
26
        help='whether to save online visualization results')
wuyuefeng's avatar
Demo  
wuyuefeng committed
27
    args = parser.parse_args()
ZCMax's avatar
ZCMax committed
28
29
30
31
32
    return args


def main(args):
    # TODO: Support inference of point cloud numpy file.
wuyuefeng's avatar
Demo  
wuyuefeng committed
33
    # build the model from a config file and a checkpoint file
34
    model = init_model(args.config, args.checkpoint, device=args.device)
ZCMax's avatar
ZCMax committed
35
36
37

    # init visualizer
    visualizer = VISUALIZERS.build(model.cfg.visualizer)
ChaimZhu's avatar
ChaimZhu committed
38
    visualizer.dataset_meta = model.dataset_meta
ZCMax's avatar
ZCMax committed
39
40

    # test a single point cloud sample
wuyuefeng's avatar
Demo  
wuyuefeng committed
41
    result, data = inference_detector(model, args.pcd)
42
    points = data['inputs']['points']
ZCMax's avatar
ZCMax committed
43
    data_input = dict(points=points)
44

wuyuefeng's avatar
Demo  
wuyuefeng committed
45
    # show the results
ZCMax's avatar
ZCMax committed
46
47
48
    visualizer.add_datasample(
        'result',
        data_input,
49
50
        data_sample=result,
        draw_gt=False,
Xiang Xu's avatar
Xiang Xu committed
51
        show=args.show,
ZCMax's avatar
ZCMax committed
52
        wait_time=0,
53
        out_file=args.out_dir,
ZCMax's avatar
ZCMax committed
54
        pred_score_thr=args.score_thr,
55
        vis_task='lidar_det')
wuyuefeng's avatar
Demo  
wuyuefeng committed
56
57
58


if __name__ == '__main__':
ZCMax's avatar
ZCMax committed
59
60
    args = parse_args()
    main(args)