Skip to content

takashh/unet

 
 

Repository files navigation

Implementation of deep learning framework -- Unet, using Keras

The architecture was inspired by U-Net: Convolutional Networks for Biomedical Image Segmentation.


Overview

Data

Provided data you can download the train and test data from this server. you can also find data in the data folder.

Pre-processing

The images are 3-D volume tiff, you should transfer the stacks into images first. The data for training contains 30 512*512 images, which are far not enough to feed a deep learning neural network. To do data augumentation, an image deformation method was used, which was implemented in C++ using opencv.

Model

img/u-net-architecture.png

This deep neural network is implemented with Keras functional API, which makes it extremely easy to experiment with different interesting architectures.

Output from the network is a 512*512 which represents mask that should be learned. Sigmoid activation function makes sure that mask pixels are in [0, 1] range.

Training

The model is trained for 10 epochs.

After 10 epochs, calculated accuracy is about 0.97.

Loss function for the training is basically just a binary crossentropy


How to use

Dependencies

This tutorial depends on the following libraries:

  • Tensorflow
  • Keras >= 1.0
  • libtiff(optional)

Also, this code should be compatible with Python versions 2.7-3.5.

You can also set up a virtual enviroment and run your code from there:

  • Create virtual enviroment folder: virtualenv -p python3 venv
  • Activate your virtual enviroment: source vev/bin/activate
  • Install packages needed in enviroment: pip3 install -r requirements.txt
  • Check installed packages: pip3 freeze

Prepare the data

First transfer 3D volume tiff to 30 512*512 images.

To feed the unet, data augmentation is necessary.

An image deformation method is used, the code is

availabel in this repository.

Define the model

  • Check out get_unet() in unet.py to modify the model, optimizer and loss function.

Train the model and generate masks for test images

  • Run python3 unet.py to train the model.

After this script finishes, in imgs_mask_test.npy masks for corresponding images in imgs_test.npy should be generated. I suggest you examine these masks for getting further insight of your model's performance.

Results

Use the trained model to do segmentation on test images, the result is statisfactory.

img/0test.png

img/0label.png

Folder structure

  • ./data: Contains sample data which can be used to test unet.
  • ./deform: Contains 3 folders which are used when running your program. Images in ./deform/train and ./deform/label are used to train your network. After building your model images from ./deform/test are used as inputs to produce results.
  • ./npydata: Contains the .npy files generated from .tif images from our deform folder.
  • ./results: Outputs from our unet are saved in this folder.

From clone to your first results

  • After cloning this project the first step is loading up the deform folder with the data you want to use to build and test your model. There is a sample dataset in the ./data folder.

  • python3 data.py to generate .npy files from your input data. This should produce 3 files in your ./npydata folder.

  • python3 unet.py to build your model. This should create a unet.hdf5 file which is your model and can be loaded in your future programs. It also generates the results from the test dataset.

  • Additionally you can use python3 test_predict.py to generate results for different test sets.

About Keras

Keras is a minimalist, highly modular neural networks library, written in Python and capable of running on top of either TensorFlow or Theano. It was developed with a focus on enabling fast experimentation. Being able to go from idea to result with the least possible delay is key to doing good research.

Use Keras if you need a deep learning library that:

allows for easy and fast prototyping (through total modularity, minimalism, and extensibility). supports both convolutional networks and recurrent networks, as well as combinations of the two. supports arbitrary connectivity schemes (including multi-input and multi-output training). runs seamlessly on CPU and GPU. Read the documentation Keras.io

Keras is compatible with: Python 2.7-3.5.

About

unet for image segmentation

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%