test_voxelnet.py 2.92 KB
Newer Older
1
# Copyright (c) OpenMMLab. All rights reserved.
zhangshilong's avatar
zhangshilong committed
2
3
import unittest

4
import torch
zhangshilong's avatar
zhangshilong committed
5
from mmengine import DefaultScope
6
7

from mmdet3d.registry import MODELS
8
9
from mmdet3d.testing import (create_detector_inputs, get_detector_cfg,
                             setup_seed)
jshilong's avatar
jshilong committed
10

jshilong's avatar
jshilong committed
11

zhangshilong's avatar
zhangshilong committed
12
class TestVoxelNet(unittest.TestCase):
jshilong's avatar
jshilong committed
13

zhangshilong's avatar
zhangshilong committed
14
15
    def test_voxelnet(self):
        import mmdet3d.models
jshilong's avatar
jshilong committed
16

zhangshilong's avatar
zhangshilong committed
17
18
        assert hasattr(mmdet3d.models, 'VoxelNet')
        DefaultScope.get_instance('test_voxelnet', scope_name='mmdet3d')
19
20
        setup_seed(0)
        pointpillars_cfg = get_detector_cfg(
21
            'pointpillars/pointpillars_hv_secfpn_8xb6-160e_kitti-3d-3class.py')
zhangshilong's avatar
zhangshilong committed
22
23
        model = MODELS.build(pointpillars_cfg)
        num_gt_instance = 2
24
        packed_inputs = create_detector_inputs(num_gt_instance=num_gt_instance)
25
26
27

        # TODO: Support aug_test
        # aug_data = [
28
29
        #     create_detector_inputs(num_gt_instance=num_gt_instance),
        #     create_detector_inputs(num_gt_instance=num_gt_instance + 1)
30
31
32
33
34
35
36
37
38
39
40
        # ]
        # # test_aug_test
        # metainfo = {
        #     'pcd_scale_factor': 1,
        #     'pcd_horizontal_flip': 1,
        #     'pcd_vertical_flip': 1,
        #     'box_type_3d': LiDARInstance3DBoxes
        # }
        # for item in aug_data:
        #     item['data_sample'].set_metainfo(metainfo)

zhangshilong's avatar
zhangshilong committed
41
42
43
44
        if torch.cuda.is_available():
            model = model.cuda()
            # test simple_test
            with torch.no_grad():
45
                data = model.data_preprocessor(packed_inputs, True)
zhangshilong's avatar
zhangshilong committed
46
                torch.cuda.empty_cache()
47
48
                results = model.forward(**data, mode='predict')
            self.assertEqual(len(results), 1)
zhangshilong's avatar
zhangshilong committed
49
50
51
            self.assertIn('bboxes_3d', results[0].pred_instances_3d)
            self.assertIn('scores_3d', results[0].pred_instances_3d)
            self.assertIn('labels_3d', results[0].pred_instances_3d)
52
53
54
55
56
57
58
59
60
61
62
63
64
65

            # TODO: Support aug_test
            # batch_inputs, data_samples = model.data_preprocessor(
            #     aug_data, True)
            # aug_results = model.forward(
            #     batch_inputs, data_samples, mode='predict')
            # self.assertEqual(len(results), len(data))
            # self.assertIn('bboxes_3d', aug_results[0].pred_instances_3d)
            # self.assertIn('scores_3d', aug_results[0].pred_instances_3d)
            # self.assertIn('labels_3d', aug_results[0].pred_instances_3d)
            # self.assertIn('bboxes_3d', aug_results[1].pred_instances_3d)
            # self.assertIn('scores_3d', aug_results[1].pred_instances_3d)
            # self.assertIn('labels_3d', aug_results[1].pred_instances_3d)

zhangshilong's avatar
zhangshilong committed
66
            # save the memory
jshilong's avatar
jshilong committed
67

zhangshilong's avatar
zhangshilong committed
68
            with torch.no_grad():
69
                losses = model.forward(**data, mode='loss')
zhangshilong's avatar
zhangshilong committed
70
                torch.cuda.empty_cache()
71
72
73
            self.assertGreaterEqual(losses['loss_dir'][0], 0)
            self.assertGreaterEqual(losses['loss_bbox'][0], 0)
            self.assertGreaterEqual(losses['loss_cls'][0], 0)