Skip to content

Multi-similarity based Hyperrelation Network for Few-Shot Segmentation

Notifications You must be signed in to change notification settings

Alex-ShiLei/MSHNet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Multi-Simlarity Based Hyperrelation Network for Few-Shot Segmentation

This is the implementation of the paper "Multi-Simlarity Based Hyperrealation Network for Few-Shot Segmentation for Few-Shot Segmentation".

Implemented on Python 3.7 and Pytorch 1.8. The main structure of the network is as follows:

The following figure shows our proposed Symmetric Merging Block (SMB):

Requirements

  • Python 3.7
  • PyTorch 1.8
  • cuda 11.1
  • opencv 4.3
  • tensorboard 1.14

Preparing Few-Shot Segmentation Datasets

Download following datasets:

1. PASCAL-5i

Download PASCAL VOC2012 devkit (train/val data):

wget http://host.robots.ox.ac.uk/pascal/VOC/voc2012/VOCtrainval_11-May-2012.tar

Download PASCAL VOC2012 SDS extended mask annotations from [Google Drive]. It was created by Juhong Min et al.

2. COCO-20i

Download COCO2014 train/val images and annotations:

wget http://images.cocodataset.org/zips/train2014.zip
wget http://images.cocodataset.org/zips/val2014.zip
wget http://images.cocodataset.org/annotations/annotations_trainval2014.zip

The Dataset directory is the folder where you put the Dataset. The Dataset directory structure is as follows:

── Dataset/
    ├── VOC2012/            # PASCAL VOC2012 devkit
    │   ├── Annotations/
    │   ├── ImageSets/
    │   ├── ...
    │   └── SegmentationClassAug/
    ├── COCO2014/           
       ├── annotations/
       │   └── ..some json files..
       ├── train2014/
       └── val2014/

Training

1. PASCAL-5i

Set parameters in file train.py and run the following command: python train.py

2. COCO-20i

Set parameters in file train.py and run the following command: python train_coco.py

Testing

Pretrained models are available on our [Baidu Netdisk].

Set the parameters in test.py and execute: python test.py

Visualization

  • To visualize mask predictions, add command line argument --visualize: (prediction results will be saved under vis/ directory)
  python test.py '...other arguments...' --visualize  

Single Similarity

To train and test for single similarity, change the mshnet in F file to mshtnet_cor or mshnet_pt

Example qualitative results (5-shot and 1-shot):

Acknowledgment

Thanks to Juhong Min, Dahyun Kang and Minsu Ch for their contributions, much of our code is based on their shared HSNet.

BibTeX

If you use this code for your research, please consider citing:

@InProceedings{
    title={Multi-Simlarity Based Hyperrelation Network for Few-Shot Segmentation},
    author={Xiangwen Shi, Shaobing Zhang, Miao Cheng, Lian He, Zhe Cui, Xianghong Tang},
}

About

Multi-similarity based Hyperrelation Network for Few-Shot Segmentation

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages