lyft_dataset.py 3.6 KB
Newer Older
dingchang's avatar
dingchang committed
1
# Copyright (c) OpenMMLab. All rights reserved.
VVsssssk's avatar
VVsssssk committed
2
from typing import Dict, List
3

wangtai's avatar
wangtai committed
4
5
import numpy as np

6
from mmdet3d.registry import DATASETS
zhangshilong's avatar
zhangshilong committed
7
from mmdet3d.structures import LiDARInstance3DBoxes
jshilong's avatar
jshilong committed
8
from .det3d_dataset import Det3DDataset
wangtai's avatar
wangtai committed
9
10
11


@DATASETS.register_module()
jshilong's avatar
jshilong committed
12
class LyftDataset(Det3DDataset):
wangtai's avatar
wangtai committed
13
    r"""Lyft Dataset.
wangtai's avatar
wangtai committed
14
15
16
17

    This class serves as the API for experiments on the Lyft Dataset.

    Please refer to
18
    `<https://www.kaggle.com/c/3d-object-detection-for-autonomous-vehicles/data>`_
zhangwenwei's avatar
zhangwenwei committed
19
    for data downloading.
wangtai's avatar
wangtai committed
20
21

    Args:
VVsssssk's avatar
VVsssssk committed
22
        data_root (str): Path of dataset root.
wangtai's avatar
wangtai committed
23
24
25
26
27
        ann_file (str): Path of annotation file.
        pipeline (list[dict], optional): Pipeline used for data processing.
            Defaults to None.
        modality (dict, optional): Modality to specify the sensor data used
            as input. Defaults to None.
VVsssssk's avatar
VVsssssk committed
28
        box_type_3d (str): Type of 3D box of this dataset.
wangtai's avatar
wangtai committed
29
30
31
32
            Based on the `box_type_3d`, the dataset will encapsulate the box
            to its original format then converted them to `box_type_3d`.
            Defaults to 'LiDAR' in this dataset. Available options includes

wangtai's avatar
wangtai committed
33
34
35
            - 'LiDAR': Box in LiDAR coordinates.
            - 'Depth': Box in depth coordinates, usually for indoor dataset.
            - 'Camera': Box in camera coordinates.
VVsssssk's avatar
VVsssssk committed
36
        filter_empty_gt (bool): Whether to filter empty GT.
wangtai's avatar
wangtai committed
37
            Defaults to True.
VVsssssk's avatar
VVsssssk committed
38
        test_mode (bool): Whether the dataset is in test mode.
wangtai's avatar
wangtai committed
39
            Defaults to False.
VVsssssk's avatar
VVsssssk committed
40
41
42
43
44
45
    """

    METAINFO = {
        'CLASSES':
        ('car', 'truck', 'bus', 'emergency_vehicle', 'other_vehicle',
         'motorcycle', 'bicycle', 'pedestrian', 'animal')
wangtai's avatar
wangtai committed
46
47
48
    }

    def __init__(self,
VVsssssk's avatar
VVsssssk committed
49
50
51
52
53
54
55
                 data_root: str,
                 ann_file: str,
                 pipeline: List[dict] = None,
                 modality: Dict = dict(use_camera=False, use_lidar=True),
                 box_type_3d: str = 'LiDAR',
                 filter_empty_gt: bool = True,
                 test_mode: bool = False,
56
                 **kwargs):
VVsssssk's avatar
VVsssssk committed
57
        assert box_type_3d.lower() in ['lidar']
wangtai's avatar
wangtai committed
58
59
60
61
62
63
64
        super().__init__(
            data_root=data_root,
            ann_file=ann_file,
            pipeline=pipeline,
            modality=modality,
            box_type_3d=box_type_3d,
            filter_empty_gt=filter_empty_gt,
65
66
            test_mode=test_mode,
            **kwargs)
wangtai's avatar
wangtai committed
67

VVsssssk's avatar
VVsssssk committed
68
    def parse_ann_info(self, info: dict) -> dict:
wangtai's avatar
wangtai committed
69
70
71
        """Get annotation info according to the given index.

        Args:
VVsssssk's avatar
VVsssssk committed
72
            info (dict): Data information of single data sample.
wangtai's avatar
wangtai committed
73
74

        Returns:
VVsssssk's avatar
VVsssssk committed
75
            dict: annotation information consists of the following keys:
wangtai's avatar
wangtai committed
76

77
                - gt_bboxes_3d (:obj:`LiDARInstance3DBoxes`):
wangtai's avatar
wangtai committed
78
                    3D ground truth bboxes.
VVsssssk's avatar
VVsssssk committed
79
                - gt_labels_3d (np.ndarray): Labels of 3D ground truths.
wangtai's avatar
wangtai committed
80
        """
VVsssssk's avatar
VVsssssk committed
81
82
83
84
85
86
87
88
89
90
91
        ann_info = super().parse_ann_info(info)
        if ann_info is None:
            # empty instance
            anns_results = dict()
            anns_results['gt_bboxes_3d'] = np.zeros((0, 7), dtype=np.float32)
            anns_results['gt_labels_3d'] = np.zeros(0, dtype=np.int64)
            return anns_results
        gt_bboxes_3d = ann_info['gt_bboxes_3d']
        gt_labels_3d = ann_info['gt_labels_3d']

        # the nuscenes box center is [0.5, 0.5, 0.5], we change it to be
wangtai's avatar
wangtai committed
92
93
94
95
96
97
98
        # the same as KITTI (0.5, 0.5, 0)
        gt_bboxes_3d = LiDARInstance3DBoxes(
            gt_bboxes_3d,
            box_dim=gt_bboxes_3d.shape[-1],
            origin=(0.5, 0.5, 0.5)).convert_to(self.box_mode_3d)

        anns_results = dict(
VVsssssk's avatar
VVsssssk committed
99
            gt_bboxes_3d=gt_bboxes_3d, gt_labels_3d=gt_labels_3d)
wangtai's avatar
wangtai committed
100
        return anns_results