PyTorch implementation of CEMNet for ICCV'2021 paper "Sampling Network Guided Cross-Entropy Method for Unsupervised Point Cloud Registration", by Haobo Jiang, Yaqi Shen, Jin Xie, Jun Li, Jianjun Qian, and Jian Yang from PCA Lab, Nanjing University of Science and Technology, China.
This paper focuses on unsupervised deep learning for 3D point clouds registration. If you find this project useful, please cite:
@inproceedings{jiang2021sampling,
title={{S}ampling {N}etwork {G}uided {C}ross-{E}ntropy {M}ethod for {U}nsupervised {P}oint {C}loud {R}egistration},
author={Jiang, Haobo and Shen, Yaqi and Xie, Jin and Li, Jun and Qian, Jianjun and Yang, Jian},
booktitle={ICCV},
year={2021}
}
In this paper, by modeling the point cloud registration task as a Markov decision process, we propose an end-to-end deep model embedded with the cross-entropy method (CEM) for unsupervised 3D registration. Our model consists of a sampling network module and a differentiable CEM module. In our sampling network module, given a pair of point clouds, the sampling network learns a prior sampling distribution over the transformation space. The learned sampling distribution can be used as a "good" initialization of the differentiable CEM module. In our differentiable CEM module, we first propose a maximum consensus criterion based alignment metric as the reward function for the point cloud registration task. Based on the reward function, for each state, we then construct a fused score function to evaluate the sampled transformations, where we weight the current and future rewards of the transformations. Particularly, the future rewards of the sampled transforms are obtained by performing the iterative closest point (ICP) algorithm on the transformed state. Extensive experimental results demonstrate the good registration performance of our method on benchmark datasets.
Before running our code, you need to install the cemlib
and batch_svd
libraries via:
bash run.sh
(If you meet something error when install batch_svd
, please refer to torch-batch-svd.)
We generated the used dataset files modelnet40_normal_n2048.pth
, 7scene_normal_n2048.pth
and icl_nuim_normal_n2048.pth
by preprocessing the raw point clouds of ModelNet40, 7Scene and ICL-NUIM , and uploaded them to GoogleDisk. Also, you can generate them by yourself via:
cd datasets
python3 process_dataset.py
After that, you need modify the dataset paths in utils/options.py
.
We uploaded the pretrained models as below:
ModelNe40: results/modelnet40_n768_unseen0_noise0_seed123/model.pth
,
7Scene : results/scene7_n768_unseen0_noise0_seed123/model.pth
,
ICL-NUIM: results/icl_nuim_n768_unseen0_noise0_seed123/model.pth
.
We thank the authors of
for open sourcing their methods.