Skip to content

[TNNLS 2023] This is official implementation of "PlaneSeg: Building a Plug-in for Boosting Planar Region Segmentation"

Notifications You must be signed in to change notification settings

nku-zhichengzhang/PlaneSeg

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PlaneSeg: Building a Plug-in for Boosting Planar Region Segmentation [TNNLS2023]

Zhicheng Zhang, Song Chen, Zichuan Wang, and Jufeng Yang

PyTorch Conference License

This is the official implementation of our TNNLS 2023 paper.

Publication

PlaneSeg: Building a Plug-in for Boosting Planar Region Segmentation
Zhicheng Zhang, Song Chen, Zichuan Wang, Jufeng Yang
IEEE Transactions on Neural Networks and Learning Systems (TNNLS).
[Paper] [PDF]

Abstract

Existing methods in planar region segmentation suffer the problems of vague boundaries and failure to detect small-sized regions. To address these, this study presents an end-to-end framework, named PlaneSeg, which can be easily integrated into various plane segmentation models. Specifically, PlaneSeg contains three modules, namely the edge feature extraction module, the multi-scale module, and the resolution-adaptation module. First, the edge feature extraction module produces edge-aware feature maps for finer segmentation boundaries. The learned edge information acts as a constraint to mitigate inaccurate boundaries. Second, the multi-scale module combines feature maps of different layers to harvest spatial and semantic information from planar objects. The multiformity of object information can help recognize small-sized objects to produce more accurate segmentation results. Third, the resolution-adaptation module fuses the feature maps produced by the two aforementioned modules. For this module, a pair-wise feature fusion is adopted to resample the dropped pixels and extract more detailed features. Extensive experiments demonstrate that PlaneSeg outperforms other state-of-the-art approaches on three downstream tasks, including plane segmentation, 3D plane reconstruction, and depth prediction.

Running

You can easily train and evaluate the model by running the script below.

Installation: Please clone the repository, prepare enviroment, and compile corresponding packages.

  1. Clone repository
git clone https://github.com/nku-zhichengzhang/PlaneSeg.git
  1. Create an Anaconda environment and install the dependencies
conda create --name ps
conda activate ps
conda install -y pytorch=0.4.1
conda install pip
pip install -r requirements.txt
  1. compile .cu files. Details can be refered in PlaneRCNN.
nvcc -c -o nms_kernel.cu.o nms_kernel.cu -x cu -Xcompiler -fPIC -arch=[arch]
cd ../../
python build.py
cd ../


cd roialign/roi_align/src/cuda/
nvcc -c -o crop_and_resize_kernel.cu.o crop_and_resize_kernel.cu -x cu -Xcompiler -fPIC -arch=[arch]
cd ../../
python build.py
cd ../../

Datasets: The used datasets are provided in the homepage of ScanNet and NYUv2. Preparation of each dataset is as same as PlaneRCNN.

Hyperparameter: You can adjust more details such as epoch, batch size, etc. Please refer to options.py and config.py.

Training: We prepare the shell to run the training process.

python scripts/run_shell_train.py

Evaluation:

To evaluate the performance, please run:

python scripts/run_shell_test.py

To count the parameters of model, please run:

python eval_flop_param.py

To test the running time, please run:

python eval_fps_ours.py

Visualization: We provide the code for re-implementing experimental results in our paper.

  1. Segmentation results: run evaluate_PlaneSeg.py and extract the images with the name of {idx}_segmentation_0_final.png.
  1. Depth Prediction: run evaluate_PlaneSeg.py and extract the npy files with the name of {idx}_segmentation_0_final.png. Then, the npy files can be visualized as the script of npy2png.py.
  1. 3D plane Reconstruction: run vis_3d_plane_rec.py and extract the ply files with the name of {idx}_model_0_final.ply. Then, the ply files can be visualized via open3d as the script of ply2png.py.
  1. Feature Visualization: run vis_feature.py.

Citation

If you find this repo useful in your project or research, please consider citing the relevant publication.

Bibtex Citation

@ARTICLE{Zhang2023PlaneSeg,
  author={Zhang, Zhicheng and Chen, Song and Wang, Zichuan and Yang, Jufeng},
  journal={IEEE Transactions on Neural Networks and Learning Systems}, 
  title={PlaneSeg: Building a Plug-In for Boosting Planar Region Segmentation}, 
  year={2023},
  volume={},
  number={},
  pages={1-15},
  }

About

[TNNLS 2023] This is official implementation of "PlaneSeg: Building a Plug-in for Boosting Planar Region Segmentation"

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published