Accelerating Single Molecule Localization Microscopy with Deep Learning.
For more details, please checkout https://annapalm.pasteur.fr/
- Download and Install the ImJoy App;
- Install the ANNA-PALM plugin;
- Use it from the ImJoy plugin menu.
ANNA-PALM has the following dependencies:
- Python 3.6
- Pillow
- numpy
- scipy
- matplotlib
- scikit-image
- tensorflow==1.1.0
- imreg_dft
- pytest
The recommended way to get python3.6 is to use ANACONDA, go the website: https://www.continuum.io/downloads , and download Anaconda(Python 3.6), then install it.
The next step is to install the dependencies, mainly for tensorflow. Open a terminal, switch to the ANNA-PALM source code folder.
git clone https://github.com/imodpasteur/ANNA-PALM
cd ANNA-PALM
For a quick test running on CPU or you don't have a cuda compatible GPU, run the following command:
pip install -r requirements.txt
Or if you have an tensorflow compatible GPU, and you want to use GPU for training, run the following command:
pip install -r requirements-gpu.txt
To test your installation, you could run the following code:
cd ANNA-PALM
python run.py --workdir=./tmp_test --ngf=1 --ndf=1
Once it starts to print .
without any error, you can terminate it with CTRL-C, otherwise, it will take a long time to actually finish the training.
You can also run the following command to see all the arguments.
# for example
python run.py --help
Besides the python code, an ImageJ plugin for applying trained model can be downloaded from the Anet-ImageJ repository.
Two types of simulated images are available, simulated microtubules and nuclear pores.
You can train a new ANNA-PALM model with the following command:
python run.py --workdir=./training_simulated_exp1 --phase=train
- In order to train an ANNA-PALM model with your own data, you need to prepare your localization tables. Currently, the script requires csv tables produced with ThunderSTORM. If you don't have any data for now, you can download our microtubule data we used in the paper.
- Create a folder as your working directory(for example
training_workdir_exp1
), then create a folder namedtrain
insidetraining_workdir_exp1
. - Then, place all your csv files into the
train
folder. Optionally, you could reserve one or two files for validation purpose. In such case, you can create another folder namedtest
and place your validation csv files into it. If you have widefield images, you need to export them as .png images (16bit or 8bit grayscale), and then rename then such they will have the same name as the corresponding csv file except the .png extension. - Now run the following command to train on your data:
python run_csv.py --workdir=./training_workdir_exp1 --phase=train
With the above code, it will first render histogram images with a subset of the full frame of each csv file. The rendered images will be saved into __images__
. You need to check the files inside this folder is rendered correctly. You should be able to see images starts with A_
and B_
, they will be used as input and target image when training your A-net. If you have your widefield image placed correctly, you should also see images starts with LR_
. You should check all these images with the help of contrast stretching in ImageJ for example.
When it's done, the training will start. It will produce some interim images in the outputs
folder which you can used to check whether the training goes well. The model will be saved into __model__
after a certain epochs of training. Please also notice that If you are running on a cpu, it can be very slow.
You can also use ANNA-PALM to work with other type of images which are not localization table. In such case, follow these steps:
-
Create a folder as your working directory(for example
training_workdir_exp2
) , inside yourtraining_workdir_exp2
, you need to create a folder namedtrain
andtest
(optional). -
Then, place all your images into the
train
folder, optionally place a few images intotest
. Similar to what you would get in__images__
folder from the above example. Images must organized within subfolders, one subfolder contains files for one sample(the same field of view), labeled withA_
,B_
and/orLR_
. -
Now run the following command as in the above example:
python run_img.py --workdir=./training_workdir_exp2 --phase=train
If you want to monitor the training progress, you should use the tensorboard interface which provides plots in the browser. In order to launch that, type the following command:
cd training_workdir_exp1/__model__
tensorboard --logdir=./
Then you can open your browser, and go to http://localhost:6006 to see the loss and outputs etc. At the begining, you will only see the A-net graph. As the training goes, you will see a tab with loss curve etc.
Specify the trained model directory with load_dir
and use phase=test
to switch to testing mode.
mkdir test_workdir_exp1
python run.py --workdir=./test_workdir_exp1 --load_dir=./training_simulated_exp1 --phase=test
use load_dir
to specify the directory where your trained model is stored, and add continue_train
.
mkdir test_workdir_exp1
python run.py --workdir=./test_workdir_exp1 --load_dir=./training_simulated_exp1 --continue_train --phase=train
In order to use your trained model in the Anet-ImageJ plugin, you need to first train a model, and then run the following script to get a frozen model:
python freeze.py --workdir=./frozen_model_sim --load_dir=./results/simulated_model
- use
--load_dir
to specify the directory contains your trained model - use
--workdir
to specify where you want to save the exported directory, you will find the frozen model file namedtensorflow_model.pb
Then you can copy the .pb
file into ImageJ according to the instructions described in Anet-ImageJ.
There are two licenses for different part of the ANNA-PALM code: a MIT license
is applied to files inside the AnetLib
folder. A Non-commercial License Agreement
is applied to all other files.
Please cite our paper: Ouyang et al., Nat. Biotechnol. 2018, doi:10.1038/nbt.4106
- How to train faster? You will need tensorflow compatible GPU, and setup the corresponding drivers and pacakges.
The other option is to reduce the size of the current neural network, you can add --ngf=16 --ndf=16
to your command, or add the following options in your script:
opt.ngf = 16 # this is the base number of filters for the generator, default value: 64
opt.ndf = 16 # this is the base number of filters for the discriminator, default value: 64
-
If you are using MACOS, and encountered problem with the torch package, try to upgrade to Python3.6.1, for example: by running 'conda install python 3.6.1'
-
For more FAQs, check out: https://annapalm.pasteur.fr/#/faq .
-
If you can't find an answer, please contact us or add a github issue.