P2C: Self-Supervised Point Cloud Completion from Single Partial Clouds
Official PyTorch implementation of the ICCV 2023 paper
P2C: Self-Supervised Point Cloud Completion from Single Partial Clouds
Ruikai Cui, Shi Qiu, Saeed Anwar, Jiawei Liu, Chaoyue Xing, Jing Zhang, Nick Barnes
[abstract] Point cloud completion aims to recover the complete shape based on a partial observation. Existing methods require either complete point clouds or multiple partial observations of the same object for learning. In contrast to previous approaches, we present Partial2Complete (P2C), the first self-supervised framework that completes point cloud objects using training samples consisting of only a single incomplete point cloud per object. Specifically, our framework groups incomplete point clouds into local patches as input and predicts masked patches by learning prior information from different partial objects. We also propose Region-Aware Chamfer Distance to regularize shape mismatch without limiting completion capability, and devise the Normal Consistency Constraint to incorporate a local planarity assumption, encouraging the recovered shape surface to be continuous and complete. In this way, P2C no longer needs multiple observations or complete point clouds as ground truth. Instead, structural cues are learned from a category-specific dataset to complete partial point clouds of objects. We demonstrate the effectiveness of our approach on both synthetic ShapeNet data and real-world ScanNet data, showing that P2C produces comparable results to methods trained with complete shapes, and outperforms methods learned with multiple partial observations.
- Python >= 3.7
- CUDA 11.6
- Pytorch >= 1.12
- open3d>=0.9
- transforms3d
- pytorch3d
- pyyaml
- opencv-python
- tensorboardX
- tqdm
- timm==0.4.5
- scipy
Or you can setup the environment using conda
:
conda env create -n p2c
pip install -r requirements.txt
Some packages are needed to train and evaluate the model.
- Pytorch Chamfer Distance
- pointops_cuda
To build this, run the command below:
bash install.sh
By default, this script uses the --user
option, which installs packages in your home directory. However, this approach can sometimes cause a ModuleNotFoundError
when using a conda
environment. If you encounter this issue, reinstall the packages using the --global
option:
bash install.sh --global
This command will install the extensions in your conda environment location instead of your home directory, preventing the error.
- 3D-EPN dataset [
Google Drive
] [BaiduYun
] (9pc1)
Please download the dataset to ./data/EPN3D/
-
PCN dataset [
Infinite Gateway
] [BaiduYun
] (hg24) -
ScanNet dataset The original dataset should be download from the official website. Our preprocessed data is aviliable at [
Google Drive
].
The layout should look like this
├── cfgs
├── data [This is your dataroot]
│ ├── shapenet_synset_dict.json
│ ├── EPN3D
│ │ ├── category.txt
│ │ ├── EPN3D.json
│ │ ├── cabinet
│ │ │ ├── complete
│ │ │ │ ├── 1a1b62a38b2584874c62bee40dcdc539.npy
│ │ │ │ ├── ......
│ │ │ ├── partial
│ │ │ │ ├── 1a1b62a38b2584874c62bee40dcdc539__0__.npy
│ │ │ │ ├── ......
│ │ ├── car
│ │ ├── ......
│ ├── PCN
│ ├── ScanNet
To train a point cloud completion model from scratch, run:
python main.py --config ./cfgs/EPN3D_models/P2C.yaml --exp_name your_exp_name
We provide pre-trained models on the 3D-EPN dataset
[Google Drive
] [WeiYun
] [BaiduYun coming soon
]
To evaluate a pre-trained P2C model on a dataset with single GPU, run:
python main.py --test --save_pred --config ./path_to_config_file/config.yaml --ckpts .path_to_ckpt/ckpt.pth --exp_name your_exp_name
where --save_pred
specifics whether save prediction results.
To produce point cloud render results like visuals in our paper, please use the render in misc/render.py
If you find our work useful to your research, please consider citing:
@misc{cui2023p2c,
title={P2C: Self-Supervised Point Cloud Completion from Single Partial Clouds},
author={Ruikai Cui and Shi Qiu and Saeed Anwar and Jiawei Liu and Chaoyue Xing and Jing Zhang and Nick Barnes},
year={2023},
eprint={2307.14726},
archivePrefix={arXiv},
}
This code borrowed heavily from PoinTr. Thanks for their great work!