Skip to content

komzy/Gaze-Based-Histopathology

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Gaze Based Annotation of Histopathology Images for Training of Deep Convolutional Neural Networks

This repo contains the code and data used for our work on Gaze-based annotation of histopathology images. Table of contents is given below

Requirements

  • Tensorflow 1.15
  • Python 3.7
  • Anaconda
  • Qupath (for viewing Whole Slide Image (WSI) file)
  • MATLAB (masks to bounding box conversion)
  • Google Colab or Jupyter Notebook

Setting up Python Environment

  1. Create a conda environment and install Tensorflow:
conda create -n tensorflow1.15 python=3.7
conda activate tensorflow1.15
conda install cudatoolkit=10.0
conda install cudnn=7.6.5
pip install tensorflow-gpu==1.15
  1. Install dependencies
pip install numpy==1.19.5 lxml pillow matplotlib jupyter contextlib2 cython tf_slim pycocotools

(For windows change pycocotools to pycocotools-windows)

  1. Install the TensorFlow Object Detection API .

Dataset

Follow the steps in \Generate_Annotations to create your own dataset from gaze and hand annotations. Or simply download our dataset from the links below.

- Gaze: Images used for training and testing of gaze-based object detectors can be downloaded from here. The labels corresponding to each file in the training and test dataset can be found in "Gaze_Data/labels/train" and "Gaze_Data/labels/test" respectively.

- Hand: Images used for training and testing of object detectors on hand-labelled data can be downloaded from here. The labels corresponding to each file in the training and test dataset can be found in "Hand_Data/labels/train" and "Hand_Data/labels/test" respectively. NOTE: Hand generated labels were used for performance evaluation of both gaze-based and hand-labelled object detectors. Therefore, the contents of both the "Gaze_Data/labels/test" and the "Hand_Data/labels/test" folders are identical.

- Masks: The binary masks used for generating labels for hand and gaze-based object detectors can be downloaded from here

- Raw Gaze Data: The raw gaze data is available here. This data needs to be converted into binary masks before it can be used to train an object detector.

  1. Every eye gaze data collection session (lasted about 5-10 minutes on average) is contained in a folder named according to the date and time.
  2. "all_sessions_merged" folder contains all levels from every gaze data collection session merged together.
  3. "all_annotations_on_max_level" contains one csv file of the maximum resolution containing all gaze data points from all levels scaled to the highest resolution of the .svs image.
  4. ".svs" files are the corresponding WSI file.

Models

Training

  1. Download raw Faster RCNN Inception V2 Weights from the above link and into the /training directory.
  2. From utils use the appropriate generate_tfrecord script to generate 'train.record' and 'test.record' from your train and test sets.
  3. Paste 'train.record' and 'test.record' into the /training directory.
  4. Set the appropriate paths in training_pipeline.config
  5. Now initiate a training job by opening a new Terminal, cd inside the models/research/object_detection and run the following command:
python model_main.py  --logtostderr --model_dir=PATH_TO_BE_CONFIGURED\models\research\object_detection\training\faster_rcnn_inception_v2_coco_2018_01_28 --pipeline_config_path=PATH_TO_BE_CONFIGURED\models\research\object_detection\training\training_pipeline.config           
  1. After training has completed, export the inference graph using export_inference_graph.py in the models\research\object_detection directory

Evaluation

The Faster RCNN model was implemented in tensorflow. Evaluation.ipynb can be used to test the Faster RCNN model on the test data.

  1. Download and extract our Gaze-based and Hand-Annotated trained models. If you prefer to train your own model then you can do so by following the instructions provided in the Training section above.
  2. Paste Evaluation.ipynb and /images into models/research/object_detection/
  3. Open terminal and cd models/research/object_detection/
  4. Run Evaluation.ipynb notebook via Jupyter Notebook

The YOLO models were implemented in PyTorch and can be found in this repo.

Results

Results for all detectors can be found here. Corresponding metrics are generated by this repo using the detection results in /Text_Format directory.

Reference

This repo was used to generate the results for the following paper on Gaze-based labelling of Pathology data.

Komal Mariam, Osama Mohammed Afzal, Wajahat Hussain, Muhammad Umar Javed, Amber Kiyani, Nasir Rajpoot, Syed Ali Khurram and Hassan Aqeel Khan, "On Smart Gaze based Annotation of Histopathology Images for Training of Deep Convolutional Neural Networks", submitted to IEEE Journal of Biomedical and Health Informatics.

BibTex Reference: Available after acceptance.

About

Script Release, Training and Evaluation Pipeline

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages