Skip to content

Latest commit

 

History

History
142 lines (121 loc) · 5.99 KB

README.md

File metadata and controls

142 lines (121 loc) · 5.99 KB

This repository contains codes for CVPR2023 paper "NeuMap: Neural Coordinate Mapping by Auto-Transdecoder for Camera Localization".

demo_vid

If you find this project useful, please cite:

@inproceedings{Tang2022NeuMap,
  title={NeuMap: Neural Coordinate Mapping by Auto-Transdecoder for Camera Localization},
  author={Shitao Tang, Sicong Tang, Andrea Tagliasacchi, Ping Tan and Yasutaka Furukawa},
  journal={arXiv preprint arXiv:2211.11177},
  year={2022}
}

The codes are based on LoFTR.

We made a mistake when evaluating GreatCourt of Cambridge. Only part of testing images are evaluated. The number in the paper is unreliable.

Installation

# For full pytorch-lightning trainer features (recommended)
conda create --name neumap python=3.8
conda activate neumap
pip install -r requirement.txt

Testing

  • We provide testing codes and pretrained models for 7scenes, Cambridge, Aachen, NAVER LABS and ScanNet. Download the pretrained models in Google Drive/Dropbox.

Data

  • The file structure should be like the following:
data
├── kapture
│   ├── train_list
│   ├── aachen1.0  
│   ├── HyundaiDepartmentStore
│   ├── GreatCourt
│   ├── chess
│   ...
├── scannet
│   ├── train_list
│   ├── train

Aachen

We provide the processed data in Google Drive/Dropbox and the label files in Google Drive/Dropbox. Please submit the corresponding pose.txt file in the result directory to this link for evaluation.

bash scripts/reproduce_test/aachen_v10.sh

7scenes

We provide the processed data in Google Drive/Dropbox and the label files in Google Drive/Dropbox.

bash scripts/reproduce_test/7scenes.sh

Cambridge

We provide the processed data in Google Drive/Dropbox and the label files in Google Drive/Dropbox.

bash scripts/reproduce_test/cambridge.sh

NAVER LAB

We provide the processed data in Google Drive/Dropbox and the label files in Google Drive/Dropbox.

bash scripts/reproduce_test/store.sh

ScanNet

We provide the testing data in Google Drive/Dropbox and the label files in Google Drive/Dropbox.

bash scripts/reproduce_test/scannet.sh

Training

Aachen

First stage training

bash scripts/reproduce_train/aachen_v10_stage1.sh

Second stage training

bash scripts/reproduce_train/aachen_v10_stage2.sh

7scenes

First stage training

bash scripts/reproduce_train/7scenes_stage1.sh

Second stage training

bash scripts/reproduce_train/7scenes_stage2.sh

Cambridge

First stage training

bash scripts/reproduce_train/cambridge_stage1.sh

Second stage training

bash scripts/reproduce_train/cambridge_stage2.sh

NAVER LAB

bash scripts/reproduce_train/store.sh

ScanNet

Train network

bash scripts/reproduce_train/scannet.sh

Finetune codes for new scenes

bash scripts/reproduce_train/scannet_code_finetune.sh

Data size

To get data size, please refer to tools/get_params.py and tools/get_params_cambridge.py.

Process data

We provide example codes to divide scenes to voxels and generate label files in tools/get_label_file.py and tools/get_query_file.py.

python tools/get_label_file.py --root data/kapture -i aachen1.0/mapping -s 15 -o aachen_debug

Generate fake query images

python tools/get_query_file.py \
    -o query_regular_15 \
    --retrieval_path data/kapture/aachen1.0/pairs-query-netvlad30.txt \
    --root data/kapture \
    --train_list_path data/kapture/train_list/aachen_debug.txt

To run custom dataset, please first use r2d2 to generate key-points and triangulate 3D points with COLMAP. Then, convert the COLMAP output files to the same format as data/kapture/aachen1.0/mapping/points.

Acknowledgement

We thank Martin Humenberger and Philippe Weinzaepfel for their codes of ESAC in NAVER LAB datasets. We thank Luwei Yang to evaluate Squeezer under different data sizes. We thank Jiahui Zhang and Jiacheng Chen for proof reading. The research is supported by NSERC Discovery Grants, NSERC Discovery Grants Accelerator Supplements, DND/NSERC Discovery Grant Supplement, and John R. Evans Leaders Fund (JELF).