Awesome
<p align="center"> <img width="420" height="320" src="figures/dis-logo-official.png"> </p> <br>Highly Accurate Dichotomous Image Segmentation (ECCV 2022)
Xuebin Qin, Hang Dai, Xiaobin Hu, Deng-Ping Fan*, Ling Shao, Luc Van Gool.
<br>This is the official repo for our newly formulated DIS task:
Project Page, Arxiv, 中文.
<br>Currently, only a few sample images of our DIS V2.0 dataset are included in this repo. The complete DIS V2.0 dataset and model have NOT been released yet! (quick response to many emails regarding to the DIS V2.0.)
We are trying our best to release that as early as possible!
Updates !!!
** (2024-Sept.-22)** Bohrium provides an free DIS demo on Bohrium Notebook.
** (2022-Aug.-17)** The optimized model for general use of our IS-Net is now released: isnet-general-use.pth
(for general use, this is NOT DIS V2.0.) from (Google Drive) or (Baidu Pan 提取码:6jh2), please feel free to try it with the newly created simple inference.py
code on your own datasets.
** (2022-Jul.-30)** Thank AK391 for the implementaiton of a Web Demo: Integrated into Huggingface Spaces 🤗 using Gradio. Try out the Web Demo . <br>
Notes for official DIS group: Currently, the released DIS deep model is the academic version that was trained with DIS V1.0, which includes very few animal, human, cars, etc. So it may not work well on these targets. We will release another version for general use and test. In addition, our DIS V2.0 will cover more categories with extremely well-annotated samples. Please stay tuned. <br>
** (2022-Jul.-17)** Our paper, code and dataset are now officially released!!! Please check our project page for more details: Project Page.<br>
** (2022-Jul.-5)** Our DIS work is now accepted by ECCV 2022, the code and dataset will be released before July 17th, 2022. Please be aware of our updates.
<br>1. Our Dichotomous Image Segmentation (DIS) Dataset
1.1 DIS dataset V1.0: DIS5K
<br>Download: Google Drive or Baidu Pan 提取码:rtgw
1.2 DIS dataset V2.0
<br>Although our DIS5K V1.0 includes samples from more than 200 categories, many categories, such as human, animals, cars and so on, in real world are not included. So the current version (v1.0) of our dataset may limit the robustness of the trained models. To build the comprehensive and large-scale highly accurate dichotomous image segmentation dataset, we are building our DIS dataset V2.0. The V2.0 will be released soon. Please stay tuned.
Samples from DIS dataset V2.0.
<br>2. APPLICATIONS of Our DIS5K Dataset
<br>3D Modeling
Image Editing
Art Design Materials
Still Image Animation
AR
3D Rendering
<br>3. Architecture of Our IS-Net
<br> <br>4. Human Correction Efforts (HCE)
<br> <br>5. Experimental Results
<br>Predicted Maps, (Google Drive), (Baidu Pan 提取码:ph1d), of Our IS-Net and Other SOTAs
Qualitative Comparisons Against SOTAs
Quantitative Comparisons Against SOTAs
<br>6. Run Our Code
<br>(1) Clone this repo
git clone https://github.com/xuebinqin/DIS.git
(2) Configuring the environment: go to the DIS/ISNet
folder and run
conda env create -f pytorch18.yml
Or you can check the requirements.txt
to configure the dependancies.
(3) activate the conda environment by
conda activate pytorch18
(4) Train:
(a) Open train_valid_inference_main.py
, set the path of your to-be-inferenced train_datasets
and valid_datasets
, e.g., valid_datasets=[dataset_vd]
<br>
(b) Set the hypar["mode"]
to "train"
<br>
(c) Create a new folder your_model_weights
in the directory saved_models
and set it as the hypar["model_path"] ="../saved_models/your_model_weights"
and make sure hypar["valid_out_dir"]
(line 668) is set to ""
, otherwise the prediction maps of the validation stage will be saved to that directory, which will slow the training speed down <br>
(d) Run
python train_valid_inference_main.py
(5) Inference
Download the pre-trained weights (for fair academic comparisons) isnet.pth
from (Google Drive) or (Baidu Pan 提取码:xbfk) OR the optimized model weights isnet-general-use.pth
(for general use) from (Google Drive) or (Baidu Pan 提取码:6jh2), and store them in saved_models/IS-Net
<br>
I. Simple inference code for your own dataset without ground truth:
(a) Open \ISNet\inference.py
and configure your input and output directories
(b) Run
python inference.py
II. Inference for dataset with/without ground truth
(a) Open train_valid_inference_main.py
, set the path of your to-be-inferenced valid_datasets
, e.g., valid_datasets=[dataset_te1, dataset_te2, dataset_te3, dataset_te4]
<br>
(b) Set the hypar["mode"]
to "valid"
<br>
(c) Set the output directory of your predicted maps, e.g., hypar["valid_out_dir"] = "../DIS5K-Results-test"
<br>
(d) Run
python train_valid_inference_main.py
(5) Use of our Human Correction Efforts(HCE) metric
Set the ground truth directory gt_root
and the prediction directory pred_root
. To reduce the time costs for computing HCE, the skeletion of the DIS5K dataset can be pre-computed and stored in gt_ske_root
. If gt_ske_root=""
, the HCE code will compute the skeleton online which usually takes a lot for time for large size ground truth. Then, run python hce_metric_main.py
. Other metrics are evaluated based on the SOCToolbox.
7. Term of Use
Our code and evaluation metric use Apache License 2.0. The Terms of use for our DIS5K dataset is provided as DIS5K-Dataset-Terms-of-Use.pdf.
<br>Acknowledgements
<br>We would like to thank Dr. Ibrahim Almakky for his helps in implementing the dataloader cache machanism of loading large-size training samples and Jiayi Zhu for his efforts in re-organizing our code and dataset.
<br>Citation
<br>@InProceedings{qin2022,
author={Xuebin Qin and Hang Dai and Xiaobin Hu and Deng-Ping Fan and Ling Shao and Luc Van Gool},
title={Highly Accurate Dichotomous Image Segmentation},
booktitle={ECCV},
year={2022}
}
<br>
Our Previous Works: U<sup>2</sup>-Net, BASNet.
<br>
@InProceedings{Qin_2020_PR,
title = {U2-Net: Going Deeper with Nested U-Structure for Salient Object Detection},
author = {Qin, Xuebin and Zhang, Zichen and Huang, Chenyang and Dehghan, Masood and Zaiane, Osmar and Jagersand, Martin},
journal = {Pattern Recognition},
volume = {106},
pages = {107404},
year = {2020}
}
@InProceedings{Qin_2019_CVPR,
author = {Qin, Xuebin and Zhang, Zichen and Huang, Chenyang and Gao, Chao and Dehghan, Masood and Jagersand, Martin},
title = {BASNet: Boundary-Aware Salient Object Detection},
booktitle = {The IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
month = {June},
year = {2019}
}
@article{qin2021boundary,
title={Boundary-aware segmentation network for mobile and web applications},
author={Qin, Xuebin and Fan, Deng-Ping and Huang, Chenyang and Diagne, Cyril and Zhang, Zichen and Sant'Anna, Adri{\`a} Cabeza and Suarez, Albert and Jagersand, Martin and Shao, Ling},
journal={arXiv preprint arXiv:2101.04704},
year={2021}
}