Difference between revisions of "VICCE"

From IACL
Jump to navigation Jump to search
(Link fix.)
 
(22 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<meta name="title" content="VICCE"/>
+
<!-- <meta name="title" content="VICCE"/> -->
 
{{h2|Variational Intensity Cross Channel Encoder for Unsupervised Vessel Segmentation on OCT Angiography (VICCE)}}
 
{{h2|Variational Intensity Cross Channel Encoder for Unsupervised Vessel Segmentation on OCT Angiography (VICCE)}}
  
Line 6: Line 6:
 
*{{pub|author = Y. Liu, L. Zuo, A. Carass, Y. He, A. Filippatou, S.D. Solomon, S. Saidha, P.A. Calabresi, and J.L. Prince | title = [http://iacl.jhu.edu/~yihao/papers/SPIE-2020-VICCE.pdf Variational intensity cross channel encoder for unsupervised vessel segmentation on OCT angiography] | conf = spie2020 | doi = 10.1117/12.2549967| pdf = /~yihao/papers/SPIE-2020-VICCE.pdf}}
 
*{{pub|author = Y. Liu, L. Zuo, A. Carass, Y. He, A. Filippatou, S.D. Solomon, S. Saidha, P.A. Calabresi, and J.L. Prince | title = [http://iacl.jhu.edu/~yihao/papers/SPIE-2020-VICCE.pdf Variational intensity cross channel encoder for unsupervised vessel segmentation on OCT angiography] | conf = spie2020 | doi = 10.1117/12.2549967| pdf = /~yihao/papers/SPIE-2020-VICCE.pdf}}
  
{{h3|Software}}
+
{|align="center" style="width:75%; border:2px #e99095 solid; background:#ffffff; text-align:left;"
 +
|-
 +
| colspan="2" align="center" | '''VICCE'''
 +
|-
 +
| {{iacl|~yihao/VICCE/vicce.zip|Source code}}
 +
| 10kB
 +
|-
 +
| {{iacl|~yihao/VICCE/pretrained_models.zip|Pretrained model}}
 +
| 80.2MB
 +
|-
 +
| {{iacl|~yihao/VICCE/gpl-3.0.txt|License (GPL v3.0)}}
 +
| 35kB
 +
|-
 +
|}
  
::Coming soon.
+
{{h3|Instructions}}
  
 +
{{h4|Prepare data}}
 +
The data loader requires pairs of Spectralis and Cirrus scans as input. Name the Spectralis scan as "H.png" stand for Heidelberg and the Cirrus scan as "Z.png" for Zeiss, also provide a mask image "M.png" to outline the common field of view of the Spectralis scan and Cirrus scan. Those three images are stored in subfolder inside "data/train/" and "data/val/". The directory structure of the whole preject is as follows:
  
{{h3|Instructions}}
+
    ├──datasets
 +
    │    ├──__init__.py
 +
    │    └── vicce_dataset.py
 +
    ├──train.py
 +
    ├──evaluate.py
 +
    ├──params.json
 +
    ├──pytorch_env.yml
 +
    ├──model
 +
    │    ├──__init__.py
 +
    │    ├──sampling.py
 +
    │    ├──unet.py
 +
    │    └──vicce_model.py
 +
    |
 +
    ├──utils
 +
    │    ├──__init__.py
 +
    │    └──utils.py
 +
    |   
 +
    └──data
 +
        ├──train
 +
        |  └──subject_*
 +
        |        ├── H.png
 +
        |        ├── Z.png
 +
        |        └── M.png
 +
        └──val
 +
            └──subject_*
 +
                  ├── H.png
 +
                  ├── Z.png
 +
                  └── M.png
 +
{{h4|Install packages}}
 +
To install the required packages, run <code>conda env create --name pytorch --file=pytorch_env.yml</code>
  
::Coming soon. If you have questions regarding the method or software, please contact [https://iacl.jhu.edu/index.php/Yihao/ Yihao Liu]
+
{{h4|Training/Evaluation}}
 +
*If you have prepared registered pairs of Spectralis and Cirrus scans in "data/train/", you can use <code>python train.py --output vicce</code> to train VICCE for your own data. It will load hyper parameters from "params.json" and store checkpoints into folder "checkpoints/vicce/".
  
{{h4|Prepare data}}
+
*To test images using existing models, run <code>python evaluate.py --output vicce</code> This will load parameters from "checkpoints/vicce/". This step also assume both "H.png" and "Z.png", as well as "M.png" exists in "data/val/*/", you might need to create dummy images for the data loader to work properly.
The data loader requires pairs of Spectralis and Cirrus scans as input. Name the Spectralis scan as "H.png" stand for Heidelberg and the Cirrus scan as "Z.png" for Zeiss, also provide a mask image "M.png" to outline the common field of view of the Spectralis scan and Cirrus scan. Those three images are stored in subfolder inside "data/train/" and "data/val/". The directory structure of the whole preject is as follows:
 
  
 +
{{h4|Use pretrained model}}
 +
Create a folders "checkpoints/pretrained/" in the root directory. Download the pretrained models and put them in the created folder. Prepare your testing image and run <code>python evaluate.py --output pretrained</code> to specify to use the pretrained model.
  
├── datasets
+
If you have questions regarding the method or software, please contact [[Yihao|Yihao Liu]].
│      ├──__init__.py
 
│      └── vicce_dataset.py
 
├── train.py
 
├── evaluate.py
 
├── params.json
 
├── pytorch_env.yml
 
├── model
 
│    ├──__init__.py
 
│    ├──sampling.py
 
│    ├──unet.py
 
│    └──vicce_model.py
 
|
 
├── utils
 
│    ├──__init__.py
 
│    └──utils.py
 
|   
 
└── data
 
      ├──train
 
      |  └──subject_*
 
      |         ├── H.png
 
      |        ├── Z.png
 
      |        └── M.png
 
      └──val
 
          └──subject_*
 
                ├── H.png
 
                ├── Z.png
 
                └── M.png
 

Latest revision as of 01:47, 24 September 2022

Variational Intensity Cross Channel Encoder for Unsupervised Vessel Segmentation on OCT Angiography (VICCE)

Variational intensity cross channel encoder is an vessel segmentation algorithm for 2D OCT angiography images. The associated publication is:

VICCE
Source code 10kB
Pretrained model 80.2MB
License (GPL v3.0) 35kB

Instructions

Prepare data

The data loader requires pairs of Spectralis and Cirrus scans as input. Name the Spectralis scan as "H.png" stand for Heidelberg and the Cirrus scan as "Z.png" for Zeiss, also provide a mask image "M.png" to outline the common field of view of the Spectralis scan and Cirrus scan. Those three images are stored in subfolder inside "data/train/" and "data/val/". The directory structure of the whole preject is as follows:

   ├──datasets
   │     ├──__init__.py
   │     └── vicce_dataset.py
   ├──train.py
   ├──evaluate.py
   ├──params.json
   ├──pytorch_env.yml
   ├──model
   │    ├──__init__.py
   │    ├──sampling.py
   │    ├──unet.py
   │    └──vicce_model.py
   |
   ├──utils
   │    ├──__init__.py
   │    └──utils.py 
   |    
   └──data
        ├──train
        |   └──subject_*
        |         ├── H.png
        |         ├── Z.png
        |         └── M.png
        └──val
            └──subject_*
                  ├── H.png
                  ├── Z.png
                  └── M.png

Install packages

To install the required packages, run conda env create --name pytorch --file=pytorch_env.yml

Training/Evaluation

  • If you have prepared registered pairs of Spectralis and Cirrus scans in "data/train/", you can use python train.py --output vicce to train VICCE for your own data. It will load hyper parameters from "params.json" and store checkpoints into folder "checkpoints/vicce/".
  • To test images using existing models, run python evaluate.py --output vicce This will load parameters from "checkpoints/vicce/". This step also assume both "H.png" and "Z.png", as well as "M.png" exists in "data/val/*/", you might need to create dummy images for the data loader to work properly.

Use pretrained model

Create a folders "checkpoints/pretrained/" in the root directory. Download the pretrained models and put them in the created folder. Prepare your testing image and run python evaluate.py --output pretrained to specify to use the pretrained model.

If you have questions regarding the method or software, please contact Yihao Liu.