Skip to content

Latest commit

 

History

History
103 lines (83 loc) · 4.08 KB

README.md

File metadata and controls

103 lines (83 loc) · 4.08 KB

This is a PyTorch implementation of 3DGCTR proposed by our paper Rethinking 3D Dense Caption and Visual Grounding in A Unified Framework through Prompt-based Localization.

0. Install

We train and evaluate our model using CUDA 11.3.

conda create -n pointcept113 python=3.8 -y
conda activate pointcept113
conda install ninja -y
# Choose version you want here: https://pytorch.org/get-started/previous-versions/
conda install pytorch==1.12.1 torchvision==0.13.1 torchaudio==0.12.1 cudatoolkit=11.3 -c pytorch -y
conda install h5py pyyaml -c anaconda -y
conda install sharedarray tensorboard tensorboardx yapf addict einops scipy plyfile termcolor timm -c conda-forge -y
conda install pytorch-cluster pytorch-scatter pytorch-sparse -c pyg -y
pip install torch-geometric

conda install pytorch-scatter -c pyg
pip install spacy
pip install https://github.com/explosion/spacy-models/releases/download/en_core_web_sm-3.3.0/en_core_web_sm-3.3.0.tar.gz

sudo apt-get install make gcc g++ -y
sudo apt-get install manpages-dev -y
pip install -U git+https://github.com/NVIDIA/MinkowskiEngine --no-deps

1. Data preparation

Please refer to 3DRefTR and Vote2Cap-DETR to download 3DVG and 3DDC datasets for training and evaluation, then set your [dataset path] in the config file.

2. Training

  • Pretrain on 3DVG
sh scripts/train.sh -p python -g 4 -d scanrefer -c ScanRefer_3DVG_pretrain -n [3DVG_NAME]
  • Joint training on 3DVG and 3DDC
sh scripts/train.sh -p python -g 4 -d scanrefer -c ScanRefer_3DVG_3DDC_joint_mle -n [JOINT_NAME]
  • SCST training on 3DDC in Single GPU
  1. First, comment out the following code in file pointcept/datasets/scanrefer_jointdc_v2c.py (on line #264):
# for joint training in MLE, not SCST/onlyDC
# if split == "train":
#     self.scan_names = SCANREFER['scene_list'][split] * 10
  1. Then run in a single GPU:
sh scripts/train.sh -p python -g 1 -d scanrefer -c ScanRefer_3DDC_scst -n [SCST_NAME]
  • If you want to train and evaluate in the Nr3D dataset, please modify some codes:
(i) Modifying nvocabs length from 3433 to 2937 in:
- line 212 in pointcept/models/default.py
- line 541 in pointcept/models/losses/vqa_losses.py

(ii) Modifying the import of  SCANREFER and ScanReferTokenizer in:
- pointcept/models/threedreftr/captioner_dcc/scst.py
- pointcept/models/threedreftr/captioner_dcc/captioner.py
- pointcept/engines/hooks/evaluator.py

3. Evaluation

You can change the tester in the config file and evaluate all the tasks and models in Single GPU:

  1. "GroundingTester" for testing the visual grounding task, run:
sh scripts/test.sh -p python -d scanrefer -n [3DVG_NAME] -w model_best

Note that if you want to test the joint training checkpoint in the VG task, you can first copy the checkpoint file (exp/scanrefer/[JOINT_NAME]/model) to the pretrain cache file (exp/scanrefer/[3DVG_NAME]/model) and rename it as model_joint.pth, then run:

sh scripts/test.sh -p python -d scanrefer -n [3DVG_NAME] -w model_joint
  1. "CaptionTester" for testing the dense caption task, run:
sh scripts/test.sh -p python -d scanrefer -n [JOINT_NAME] -w model_best

4. Visualization

You can refer to this repo for visualization.

Citation

If you find 3DGCTR useful to your research, please cite our work:

@misc{luo2024rethinking3ddensecaption,
      title={Rethinking 3D Dense Caption and Visual Grounding in A Unified Framework through Prompt-based Localization}, 
      author={Yongdong Luo and Haojia Lin and Xiawu Zheng and Yigeng Jiang and Fei Chao and Jie Hu and Guannan Jiang and Songan Zhang and Rongrong Ji},
      year={2024},
      eprint={2404.11064},
      archivePrefix={arXiv},
      primaryClass={cs.CV},
      url={https://arxiv.org/abs/2404.11064}, 
}

Acknowledgement

This repository is built on reusing codes of Pointcept. We recommend using their code repository in your research and reading the related article.