Shortcuts

Waymo Dataset

This page provides specific tutorials about the usage of MMDetection3D for Waymo dataset.

Prepare dataset

Before preparing Waymo dataset, if you only installed requirements in requirements/build.txt and requirements/runtime.txt before, please install the official package for this dataset at first by running

pip install waymo-open-dataset-tf-2-6-0

or

pip install -r requirements/optional.txt

Like the general way to prepare dataset, it is recommended to symlink the dataset root to $MMDETECTION3D/data. Due to the original Waymo data format is based on tfrecord, we need to preprocess the raw data for convenient usage in the training and evaluation procedure. Our approach is to convert them into KITTI format.

The folder structure should be organized as follows before our processing.

mmdetection3d
├── mmdet3d
├── tools
├── configs
├── data
│   ├── waymo
│   │   ├── waymo_format
│   │   │   ├── training
│   │   │   ├── validation
│   │   │   ├── testing
│   │   │   ├── gt.bin
│   │   │   ├── cam_gt.bin
│   │   │   ├── fov_gt.bin
│   │   ├── kitti_format
│   │   │   ├── ImageSets

You can download Waymo open dataset V1.4 HERE and its data split HERE. Then put tfrecord files into corresponding folders in data/waymo/waymo_format/ and put the data split txt files into data/waymo/kitti_format/ImageSets. Download ground truth bin files for validation set HERE and put it into data/waymo/waymo_format/. A tip is that you can use gsutil to download the large-scale dataset with commands. You can take this tool as an example for more details. Subsequently, prepare Waymo data by running

# TF_CPP_MIN_LOG_LEVEL=3 will disable all logging output from TensorFlow.
# The number of `--workers` depends on the maximum number of cores in your CPU.
TF_CPP_MIN_LOG_LEVEL=3 python tools/create_data.py waymo --root-path ./data/waymo --out-dir ./data/waymo --workers 128 --extra-tag waymo --version v1.4

Note that if your local disk does not have enough space for saving converted data, you can change the --out-dir to anywhere else. Just remember to create folders and prepare data there in advance and link them back to data/waymo/kitti_format after the data conversion.

After the data conversion, the folder structure and info files should be organized as below.

mmdetection3d
├── mmdet3d
├── tools
├── configs
├── data
│   ├── waymo
│   │   ├── waymo_format
│   │   │   ├── training
│   │   │   ├── validation
│   │   │   ├── testing
│   │   │   ├── gt.bin
│   │   │   ├── cam_gt.bin
│   │   │   ├── fov_gt.bin
│   │   ├── kitti_format
│   │   │   ├── ImageSets
│   │   │   ├── training
│   │   │   │   ├── image_0
│   │   │   │   ├── image_1
│   │   │   │   ├── image_2
│   │   │   │   ├── image_3
│   │   │   │   ├── image_4
│   │   │   │   ├── velodyne
│   │   │   ├── testing
│   │   │   │   ├── (the same as training)
│   │   │   ├── waymo_gt_database
│   │   │   ├── waymo_infos_trainval.pkl
│   │   │   ├── waymo_infos_train.pkl
│   │   │   ├── waymo_infos_val.pkl
│   │   │   ├── waymo_infos_test.pkl
│   │   │   ├── waymo_dbinfos_train.pkl

  • kitti_format/training/image_{0-4}/{a}{bbb}{ccc}.jpg Here because there are several cameras, we store the corresponding images. We use a coding way {a}{bbb}{ccc} to name the data for each frame, where a is the prefix for different split (0 for training, 1 for validation and 2 for testing), bbb for segment index and ccc for frame index. You can easily locate the required frame according to this naming rule. We gather the data for training and validation together as KITTI and store the indices for different set in the ImageSet files.

  • kitti_format/training/velodyne/{a}{bbb}{ccc}.bin point cloud data for each frame.

  • kitti_format/waymo_gt_database/xxx_{Car/Pedestrian/Cyclist}_x.bin. point cloud data included in each 3D bounding box of the training dataset. These point clouds will be used in data augmentation e.g. ObjectSample. xxx is the index of training samples and x is the index of objects in this frame.

  • kitti_format/waymo_infos_train.pkl. training dataset information, a dict contains two keys: metainfo and data_list.metainfo contains the basic information for the dataset itself, such as dataset, version and info_version, while data_list is a list of dict, each dict (hereinafter referred to as info) contains all the detailed information of single sample as follows:

    • info[‘sample_idx’]: The index of this sample in the whole dataset.

    • info[‘ego2global’]: The transformation matrix from the ego vehicle to global coordinates. (4x4 list).

    • info[‘timestamp’]: Timestamp of the sample data.

    • info[‘context_name’]: The context name of sample indices which *.tfrecord segment it extracted from.

    • info[‘lidar_points’]: A dict containing all the information related to the lidar points.

      • info[‘lidar_points’][‘lidar_path’]: The filename of the lidar point cloud data.

      • info[‘lidar_points’][‘num_pts_feats’]: The feature dimension of point.

    • info[‘lidar_sweeps’]: A list contains sweeps information of lidar

      • info[‘lidar_sweeps’][i][‘lidar_points’][‘lidar_path’]: The lidar data path of i-th sweep.

      • info[‘lidar_sweeps’][i][‘ego2global’]: The transformation matrix from the ego vehicle to global coordinates. (4x4 list)

      • info[‘lidar_sweeps’][i][‘timestamp’]: Timestamp of the sweep data.

    • info[‘images’]: A dict contains five keys corresponding to each camera: 'CAM_FRONT', 'CAM_FRONT_RIGHT', 'CAM_FRONT_LEFT', 'CAM_SIDE_LEFT', 'CAM_SIDE_RIGHT'. Each dict contains all data information related to corresponding camera.

      • info[‘images’][‘CAM_XXX’][‘img_path’]: The filename of the image.

      • info[‘images’][‘CAM_XXX’][‘height’]: The height of the image.

      • info[‘images’][‘CAM_XXX’][‘width’]: The width of the image.

      • info[‘images’][‘CAM_XXX’][‘cam2img’]: The transformation matrix recording the intrinsic parameters when projecting 3D points to each image plane. (4x4 list)

      • info[‘images’][‘CAM_XXX’][‘lidar2cam’]: The transformation matrix from lidar sensor to this camera. (4x4 list)

      • info[‘images’][‘CAM_XXX’][‘lidar2img’]: The transformation matrix from lidar sensor to each image plane. (4x4 list)

    • info[‘image_sweeps’]: A list containing sweeps information of images.

      • info[‘image_sweeps’][i][‘images’][‘CAM_XXX’][‘img_path’]: The image path of i-th sweep.

      • info[‘image_sweeps’][i][‘ego2global’]: The transformation matrix from the ego vehicle to global coordinates. (4x4 list)

      • info[‘image_sweeps’][i][‘timestamp’]: Timestamp of the sweep data.

    • info[‘instances’]: It is a list of dict. Each dict contains all annotation information of single instance. For the i-th instance:

      • info[‘instances’][i][‘bbox_3d’]: List of 7 numbers representing the 3D bounding box of the instance, in (x, y, z, l, w, h, yaw) order.

      • info[‘instances’][i][‘bbox’]: List of 4 numbers representing the 2D bounding box of the instance, in (x1, y1, x2, y2) order. (some instances may not have a corresponding 2D bounding box)

      • info[‘instances’][i][‘bbox_label_3d’]: A int indicating the label of instance and the -1 indicating ignore.

      • info[‘instances’][i][‘bbox_label’]: A int indicating the label of instance and the -1 indicating ignore.

      • info[‘instances’][i][‘num_lidar_pts’]: Number of lidar points included in each 3D bounding box.

      • info[‘instances’][i][‘camera_id’]: The index of the most visible camera for this instance.

      • info[‘instances’][i][‘group_id’]: The index of this instance in this sample.

    • info[‘cam_sync_instances’]: It is a list of dict. Each dict contains all annotation information of single instance. Its format is same with [‘instances’]. However, [‘cam_sync_instances’] is only for multi-view camera-based 3D Object Detection task.

    • info[‘cam_instances’]: It is a dict containing keys 'CAM_FRONT', 'CAM_FRONT_RIGHT', 'CAM_FRONT_LEFT', 'CAM_SIDE_LEFT', 'CAM_SIDE_RIGHT'. For monocular camera-based 3D Object Detection task, we split 3D annotations of the whole scenes according to the camera they belong to. For the i-th instance:

      • info[‘cam_instances’][‘CAM_XXX’][i][‘bbox_3d’]: List of 7 numbers representing the 3D bounding box of the instance, in (x, y, z, l, h, w, yaw) order.

      • info[‘cam_instances’][‘CAM_XXX’][i][‘bbox’]: 2D bounding box annotation (exterior rectangle of the projected 3D box), a list arrange as [x1, y1, x2, y2].

      • info[‘cam_instances’][‘CAM_XXX’][i][‘bbox_label_3d’]: Label of instance.

      • info[‘cam_instances’][‘CAM_XXX’][i][‘bbox_label’]: Label of instance.

      • info[‘cam_instances’][‘CAM_XXX’][i][‘center_2d’]: Projected center location on the image, a list has shape (2,).

      • info[‘cam_instances’][‘CAM_XXX’][i][‘depth’]: The depth of projected center.

Training

Considering there are many similar frames in the original dataset, we can basically use a subset to train our model primarily. In our preliminary baselines, we load one frame every five frames, and thanks to our hyper parameters settings and data augmentation, we obtain a better result compared with the performance given in the original dataset paper. For more details about the configuration and performance, please refer to README.md in the configs/pointpillars/. A more complete benchmark based on other settings and methods is coming soon.

Evaluation

For evaluation on Waymo, please follow the instruction to build the binary file compute_detection_metrics_main for metrics computation and put it into mmdet3d/core/evaluation/waymo_utils/. Basically, you can follow the commands below to install bazel and build the file.

# download the code and enter the base directory
git clone https://github.com/waymo-research/waymo-open-dataset.git waymo-od
# git clone https://github.com/Abyssaledge/waymo-open-dataset-master waymo-od # if you want to use faster multi-thread version.
cd waymo-od
git checkout remotes/origin/master

# use the Bazel build system
sudo apt-get install --assume-yes pkg-config zip g++ zlib1g-dev unzip python3 python3-pip
BAZEL_VERSION=3.1.0
wget https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VERSION}/bazel-${BAZEL_VERSION}-installer-linux-x86_64.sh
sudo bash bazel-${BAZEL_VERSION}-installer-linux-x86_64.sh
sudo apt install build-essential

# configure .bazelrc
./configure.sh
# delete previous bazel outputs and reset internal caches
bazel clean

bazel build waymo_open_dataset/metrics/tools/compute_detection_metrics_main
cp bazel-bin/waymo_open_dataset/metrics/tools/compute_detection_metrics_main ../mmdetection3d/mmdet3d/evaluation/functional/waymo_utils/

Then you can evaluate your models on Waymo. An example to evaluate PointPillars on Waymo with 8 GPUs with Waymo metrics is as follows.

./tools/dist_test.sh configs/pointpillars/pointpillars_hv_secfpn_sbn-all_16xb2-2x_waymo-3d-car.py checkpoints/hv_pointpillars_secfpn_sbn-2x16_2x_waymo-3d-car_latest.pth

pklfile_prefix should be set in test_evaluator of configuration if the bin file is needed to be generated, so you can add --cfg-options "test_evaluator.pklfile_prefix=xxxx" in the end of command if you want do it.

Notice:

  1. Sometimes when using bazel to build compute_detection_metrics_main, an error 'round' is not a member of 'std' may appear. We just need to remove the std:: before round in that file.

  2. Considering it takes a little long time to evaluate once, we recommend to evaluate only once at the end of model training.

  3. To use TensorFlow with CUDA 9, it is recommended to compile it from source. Apart from official tutorials, you can refer to this link for possibly suitable precompiled packages and useful information for compiling it from source.

Testing and make a submission

An example to test PointPillars on Waymo with 8 GPUs, generate the bin files and make a submission to the leaderboard.

submission_prefix should be set in test_evaluator of configuration before you run the test command if you want to generate the bin files and make a submission to the leaderboard..

After generating the bin file, you can simply build the binary file create_submission and use them to create a submission file by following the instruction. Basically, here are some example commands.

cd ../waymo-od/
bazel build waymo_open_dataset/metrics/tools/create_submission
cp bazel-bin/waymo_open_dataset/metrics/tools/create_submission ../mmdetection3d/mmdet3d/core/evaluation/waymo_utils/
vim waymo_open_dataset/metrics/tools/submission.txtpb  # set the metadata information
cp waymo_open_dataset/metrics/tools/submission.txtpb ../mmdetection3d/mmdet3d/evaluation/functional/waymo_utils/

cd ../mmdetection3d
# suppose the result bin is in `results/waymo-car/submission`
mmdet3d/core/evaluation/waymo_utils/create_submission  --input_filenames='results/waymo-car/kitti_results_test.bin' --output_filename='results/waymo-car/submission/model' --submission_filename='mmdet3d/evaluation/functional/waymo_utils/submission.txtpb'

tar cvf results/waymo-car/submission/my_model.tar results/waymo-car/submission/my_model/
gzip results/waymo-car/submission/my_model.tar

For evaluation on the validation set with the eval server, you can also use the same way to generate a submission. Make sure you change the fields in submission.txtpb before running the command above.

Read the Docs v: stable
Versions
latest
stable
v1.4.0
v1.3.0
v1.2.0
v1.1.1
v1.1.0
v1.0.0rc1
v1.0.0rc0
v0.18.1
v0.18.0
v0.17.3
v0.17.2
v0.17.1
v0.17.0
v0.16.0
v0.15.0
v0.14.0
v0.13.0
v0.12.0
v0.11.0
v0.10.0
v0.9.0
dev-1.x
dev
Downloads
epub
On Read the Docs
Project Home
Builds

Free document hosting provided by Read the Docs.