Awesome
PointNetVLAD: Deep Point Cloud Based Retrieval for Large-Scale Place Recognition
PointNetVLAD: Deep Point Cloud Based Retrieval for Large-Scale Place Recognition CVPR 2018, Salt Lake City, USA
Mikaela Angelina Uy and Gim Hee Lee
National University of Singapore
Introduction
The PointNetVLAD is a deep network that addresses the problem of large-scale place recognition through point cloud based retrieval. The arXiv version of PointNetVLAD can be found here.
@inproceedings{uy2018pointnetvlad,
title={PointNetVLAD: Deep Point Cloud Based Retrieval for Large-Scale Place Recognition},
author={Uy, Mikaela Angelina and Lee, Gim Hee},
booktitle={The IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
year={2018}
}
Benchmark Datasets
The benchmark datasets introdruced in this work can be downloaded here.
- All submaps are in binary file format
- Ground truth GPS coordinate of the submaps are found in the corresponding csv files for each run
- Filename of the submaps are their timestamps which is consistent with the timestamps in the csv files
- Use CSV files to define positive and negative point clouds
- All submaps are preprocessed with the road removed and downsampled to 4096 points
Oxford Dataset
- 45 sets in total of full and partial runs
- Used both full and partial runs for training but only used full runs for testing/inference
- Training submaps are found in the folder "pointcloud_20m_10overlap/" and its corresponding csv file is "pointcloud_locations_20m_10overlap.csv"
- Training submaps are not mutually disjoint per run
- Each training submap ~20m of car trajectory and subsequent submaps are ~10m apart
- Test/Inference submaps found in the folder "pointcloud_20m/" and its corresponding csv file is "pointcloud_locations_20m.csv"
- Test/Inference submaps are mutually disjoint
NUS (Inhouse) Datasets
- Each inhouse dataset has 5 runs
- Training submaps are found in the folder "pointcloud_25m_10/" and its corresponding csv file is "pointcloud_centroids_10.csv"
- Test/Infenrence submaps are found in the folder "pointcloud_25m_25/" and its corresponding csv file is "pointcloud_centroids_25.csv"
- Training submaps are not mutually disjoint per run but test submaps are
KITTI Odometry Datasets (and Ford Campus Datasets)
- 00-10 sequences, 00 02 05 06 07 08 have loop closures
- Using submap_generation/KITTI/gen_gt_submap.py to generate submaps; Notice that Z axis of the 08 sequence has the wrong ground truth value. We use the LOAM result on 08 instead.
- Using submap_generation/KITTI/gen_gt.py to generate triplets(query, pos, negs)
- Using gen_KITTI_vec_ref.py to get features with pretrained refined model provided by author
- Using gen_KITTI_vec.py to get features with re-training model on KITTI
- Modify loading_pointclouds_kitti.py to change strategy (drop0 drop30 drop90 fov100 drop0_rotate)
- Using train_pointnetvlad_kitti.py to train the model on KITTI with 1-fold strategy
Download our experiments results on KITTI and Ford (training logs, models) from google-drive
Project Code
Pre-requisites
- Python
- CUDA
- Tensorflow
- Scipy
- Pandas
- Sklearn
Code was tested using Python 3 on Tensorflow 1.4.0 with CUDA 8.0
sudo apt-get install python3-pip python3-dev python-virtualenv
virtualenv --system-site-packages -p python3 ~/tensorflow
source ~/tensorflow/bin/activate
easy_install -U pip
pip3 install --upgrade tensorflow-gpu==1.4.0
pip install scipy, pandas, sklearn
Dataset set-up
Download the zip file of the benchmark datasets found here. Extract the folder on the same directory as the project code. Thus, on that directory you must have two folders: 1) benchmark_datasets/ and 2) pointnetvlad/
Generate pickle files
We store the positive and negative point clouds to each anchor on pickle files that are used in our training and evaluation codes. The files only need to be generated once. The generation of these files may take a few minutes.
cd generating_queries/
# For training tuples in our baseline network
python generate_training_tuples_baseline.py
# For training tuples in our refined network
python generate_training_tuples_refine.py
# For network evaluation
python generate_test_sets.py
Model Training and Evaluation
To train our network, run the following command:
python train_pointnetvlad.py
To evaluate the model, run the following command:
python evaluate.py
Pre-trained Models
The pre-trained models for both the baseline and refined networks can be downloaded here
Submap generation
Added the rough MATLAB code that was used for submap generation upon requests. Some functions are gotten from the toolbox of Oxford Robotcar.
Some clarification: The voxel grid filter was used to downsample the cloud to 4096, which was done by selecting a leaf size that initially downsamples the cloud close to 4096 points, after which we randomly add points to make the cloud have exactly 4096 points. Please feel free to send me an email for any further questions.
License
This repository is released under MIT License (see LICENSE file for details).