Deep learning-enabled image analysis of the yeast full life cycle
Project description
YeastVision
Installation
Local installation (< 2 minutes)
System requirements
This package supports Linux, Windows and Mac OS. Mac Os should be later than Yosemite. This system has been heavily tested on Linux and Mac OS machines, and less thoroughly on Windows.
Instructions
If you have an older yeastvision
environment you should remove it with conda env remove -n yeastvision
before creating a new one.
Yeastvision is ready to go for cpu-usage as soon as it downloaded. GPU-usage requires some additional steps after download. To download:
- Install an Anaconda distribution of Python. Note you might need to use an anaconda prompt if you did not add anaconda to the path.
- Open an anaconda prompt/command prompt
- Create a new environment with
conda create --name yeastvision python=3.10.0
. - Activate this new environment by running
conda activate yeastvision
- Run
python -m pip install yeastvision
to download our package plus all dependencies - Download the weights online.
- Run
install-weights
in the same directory as the yeastvision_weights.zip file
You should upgrade yeastvision (package here) periodically as it is still in development. To do so, run the following in the environment:
python -m pip install yeastvision --upgrade
Using YeastVision with Nvidia GPU
Again, enusre your yeastvision conda environment is active for the following commands.
To use your NVIDIA GPU with python, you will first need to install the NVIDIA driver for your GPU, check out this website to download it. Ensure it is downloaded and your GPU is detected by running nvidia-smi
in the terminal.
Yeastvision relies on two machine-learning frameworks: tensorflow
and pytorch
. We will need to configure both of these packages for gpu usage
PyTorch
First, we need to remove the CPU version of torch:
pip uninstall torch
And the cpu version of torchvision:
pip uninstall torchvision
Now install torch
and torchvision
for CUDA version 11.3 (Ensure that your nvidia drivers are up to date for version 11.3 by running nvidia-smi
and check that a version >=11.3 is displayed in the top right corner of the output table).
conda install pytorch==1.12.0 torchvision==0.13.0 cudatoolkit=11.3 -c pytorch
After install you can check conda list
for pytorch
, and its version info should have cuXX.X
, not cpu
.
Tensorflow
All we need to do here is install the cuDNN package for tensorflow gpu usage
conda install cudnn=8.1.0
Common Installation Problems
You may receive the following error upon upgrading torch
and torchvision
:
AttributeError: partially initialized module 'charset_normalizer' has no attribute 'md__mypyc' (most likely due to a circular import)
This is solved by upgrading the charselt_normalizer package with the following command:
pip install --force-reinstall charset-normalizer==3.1.0
If you get a version error for numpy
, run the following commands:
pip uninstall numpy; pip install numpy==1.24
Run yeastvision locally
The quickest way to start is to open the GUI from a command line terminal. Activate the correct conda environment, then run:
yeastvision
To begin, drag and drop a directory containing images, flourescence channels, and masks into the GUI.
A single directory represents an experiment and will be added to a drop down at the top of the GUI after being loaded either through drag and drop, or the file dropdown.
Multiple directories can be added, and you can toggle through experiments as you analyze them in the GUI.
As you utilize GUI features, all GUI-generated labels and images will be stored in the experiment directory as .npz files. Deleting these files will result in a loss of this GUI-generated data.
Directory Conventions: Ensure the GUI can parse your data
Yeastvision is hardcoded to recognize several standard conventions when loading an experiment directory:
- A directory must contain images to be analyzed but does not have to contain masks
- A single file within the directory should contain a single image only.
- All channel and mask types should be present in the same number of time points.
Naming: Files should be named accordingly to their channel and mask type:
- Each data type in the directory should have a standard id to identify it.
- The id should directly follow the file extension
- Any image that acts as a label should have
_mask
in the id. - Ensure that distinct channels have distinct ids.
Here is an example of an experiment with two time points, two channels, and two pre-generated labels, sorted by name:
im001_channel1.tif, im001_channel2.tif, im001_mask1.tif, im1_mask002.tif, im002_channel1.tif, im002_channel2.tif, im002_mask1.tif, im002_mask2.tif
Keyboard Shortcuts
Command | Function |
---|---|
up/down | scroll through channnels |
cntrl + up/down | Scroll through labels |
right/left arrows | scroll through timeseries |
cntrl + right/left | scroll through timeseries by 3 |
O | outline Drawing |
B | brush Drawing |
E | eraser |
. | increment brush size |
, | decrecement brush size |
Delete/Backspace | Delete Selected Cell |
c | show current label contours |
f | toggle probability (if present) |
space bar | toggle mask display |
p | show plot window |
Troubleshooting: Common Problems
Problem | Solution |
---|---|
Cannot scroll through images/masks on the display | Click on the display to bring focus back to this widget |
Loaded images without masks but cannot draw | An existing label must be present to draw: Add a blank label with File -> Add Blank Label |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.