Skip to content

ZuckermanBrain/cryoCARE_T2T

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cryo-CARE_Preview

Cryo-CARE: Content-Aware Image Restoration for Cryo-Transmission Electron Microscopy Data

Tim-Oliver Buchholz1, Mareike Jordan, Gaia Pigino, Florian Jug
1[email protected]

Multiple approaches to use deep learning for image restoration have recently been proposed. Training such approaches requires well registered pairs of high and low quality images. While this is easily achievable for many imaging modalities, e.g. fluorescence light microscopy, for others it is not. Cryo-transmission electron microscopy (cryo-TEM) could profoundly benefit from improved denoising methods, unfortunately it is one of the latter. Here we show how recent advances in network training for image restoration tasks, i.e. denoising, can be applied to cryo-TEM data. We describe our proposed method and show how it can be applied to single cryo-TEM projections and whole cryo-tomographic image volumes. Our proposed restoration method dramatically increases contrast in cryo-TEM images, which improves the interpretability of the acquired data. Furthermore we show that automated downstream processing on restored image data, demonstrated on a dense segmentation task, leads to improved results.

Publications:

This is the implementation of the Tomo2Tomo denoising scheme for direct-detector movie acquisitions.

Usage

Prerequisits:

  • NVIDIA GPU with driver >= 430.40

Installation with Singularity

First step is to clone this github repository.

Then the simplest way to run the examples is to use the Singularity container. Singularity allows us to provied you with a fully configured environment, which has all needed packages and dependecies installed. But it requires you to install Singularity on your system:

Once you have installed Singularity you can either build the container yourself with the following commands:

  1. Change direcotry into the cloned repository:
    $ cd cryoCARE_T2T
  2. Run the Singularity build:
    $ sudo singularity build cryoCARE_v0.1.1.simg cryoCARE.Singularity

If you don't have sudo rights you can also download the built Singularity container from here.

MotionCor2

Due to licensing we can not ship MotionCor2 directly with the singularity container. You have to download MotionCor2 v1.3.0 CUDA-10.1 from here and place it in cryoCARE_T2T/example.

Note: It is important to get the CUDA-10.1 version, since we specifically installed CUDA-10.1 in the singularity container.

Example Data

We would like to thank Mareike Jordan from the Pigino Lab at MPI-CBG for the example data.

The data can be downloaded here.

Once the data is downloaded unpack it into cryoCARE_T2T/example/data/.

You should now have the following directory tree:

cryo_CARE_T2T
|   └─── example
|           └─── data
|           |       └─── Tomo110
|           |               └─── frames
|           |               └─── imod
|           |--- MotionCor2 v1.3.0 CUDA-10.1

Run the Singularity Image

To start a jupyter notebook from the singularity image run this command:
$ singularity run --nv -B user:/run/user -B example/:/notebooks -B example/data/:/data cryoCARE_v0.1.1.simg

This will display a link to the running jupyter server. Open this link in a browser and you will be able to run the five example notebooks in 'cryoCARE_simg/example':

  • 01_Split_Frames.ipynb: This notebook aligns and splits the movie frames into even/odd halves.
  • 02_Tomogram_Reconstruction.ipynb: This notebook reconstructs the two (even/odd) tomograms based on a previous IMOD-reconstruction.
  • 03_Training_Data_Generation.ipynb: This notebook is used to extract training and validation data.
  • 04_Train_cryoCARE_Network.ipynb: This notebook shows how a cryo-CARE network is trained.
  • 05_Predict_cryoCARE.ipynb: The last notebook is used to apply a trained model to tomographic data.

Manual Installation

You can also install the packages on your own:

Note: If you run it without the Singularity container you probably have to adjust the paths inside the jupyter notebooks.


How to cite:

@inproceedings{buchholz2019cryo,
  title={Cryo-CARE: content-aware image restoration for cryo-transmission electron microscopy data},
  author={Buchholz, Tim-Oliver and Jordan, Mareike and Pigino, Gaia and Jug, Florian},
  booktitle={2019 IEEE 16th International Symposium on Biomedical Imaging (ISBI 2019)},
  pages={502--506},
  year={2019},
  organization={IEEE}
}

@article{buchholz2019content,
  title={Content-aware image restoration for electron microscopy.},
  author={Buchholz, Tim-Oliver and Krull, Alexander and Shahidi, R{\'e}za and Pigino, Gaia and J{\'e}kely, G{\'a}sp{\'a}r and Jug, Florian},
  journal={Methods in cell biology},
  volume={152},
  pages={277--289},
  year={2019}
}

About

Singularity image for cryo-CARE

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Jupyter Notebook 99.6%
  • Python 0.4%