Skip to content

LabTrivedi/MOrgAna

Repository files navigation

morgana

MOrgAna

Welcome to MOrgAna (Machine-learning based Organoids Analysis) to segment and analyse 2D multi-channel images of organoids, as described in the paper:

Nicola Gritti, Jia Le Lim, Kerim Anlaş, David Oriola, Mallica Pandya, Germaine Aalderink, Guillermo Martinez Ara, Vikas Trivedi. MOrgAna: accessible quantitative analysis of organoids with machine learning. Development (2021) 148 (18): dev199611. https://doi.org/10.1242/dev.199611

Overview

MOrgAna accepts images acquired by diverse devices such as high content screening devices, confocal microscopes and simple benchtop stereo-microscopes, trains a segmentation network based on a few manually created binary mask for the generation of addition masks of unseen images, and produces quantitative plots based on morphological and fluorescence parameters based on the input images and generated masks.

overview

Installation

The MOrgAna software has been tested with Python 3.6 and above. To install Python, we recommend using the software Anaconda. Anaconda provides a Python distribution for Windows, Linux, and MacOS, and contains most of the pacakges used by MOrgAna.

Users can also choose to create a Conda environment using the environment_morgana.yml file found in the repository:morgana/environment_morgana.yml. To create the environment and activate it, set working directory in the MOrgAna folder and run the command conda env create -f environment_morgana.yml in terminal (MacOS) or command prompt(windows).

If problems were encountered due to package incompatibility, we recommend the use of conda or pip to perform an update of the python package.

Optional: To use deep machine learning in generation of masks, please first install TensorFlow 2 with GPU support. The tensorflow package can be installed with the command pip install tensorflow in terminal (MacOS) or command prompt(windows). Otherwise, please follow the official instructions for installation of tensorflow here.

To download the software, run pip install morgana in terminal (MacOS) or command prompt(windows).

Using the software

This software is able to A) generate binary masks of organoids based on their bright-field images and with this mask, extract morphological information, generate a midline and a meshgrid. B) Provide analysis of fluorescence signals along the generated midline and enable quick and easy visual comparisons between conditions.

To run MOrgAna, run python -m morgana in terminal (MacOS) or command prompt(windows).

front_page

For advance python users looking to analyse multiple image folders at once, please refer to the jupyter notebook morgana/Examples/MOrgAna_workflow_for_advance_python_users.ipynb.

A) Generate or Import Masks Tab

Each tif file in image folder should contain only one organoid with the brightfield channel as the starting image of each tif. Input tif files for MOrgAna can be generated from individual tif images with the use of the IJ macro morgana/Examples/IJ_macro/transform_into_stacks.ijm. Instructions for the use of the macro can be found in morgana/Examples/IJ_macro/README_transform_into_stacks.txt.

Creating binary masks

  1. Manually create a model folder that contains a trainingset sub-folder. Select a few representative images (~5% of all images) and copy them into this sub-folder. If binary masks of this training set have already been created, place them in the same folder and name them as ..._GT.tif. E.g. 20190509_01B_dmso.tif and 20190509_01B_dmso_GT.tif.

  2. Run the segmentation app. Click Specify model folder and select the model folder created. If binary masks are missing, please manually annotate for each image by clicking on the image in the pop up window to create a boundary around your object of interest or right click on red dots to remove selection.

binary_mask

  1. Select Use Multi Layer Perceptrons if Tensorflow and CUDA have been successfully installed and if you would like to use deep learning to generate additional binary masks.

Users can choose to adjust the following parameters of the model by clicking Show/Hide params

  • Sigmas: length scales (in pixels) used to generate the gaussian blurs of the input image
  • Downscaling: number of pixels used to resize the input image. This is mainly done to reduce computation time, and a value of 500 is found to be enough in most applications.
  • Edge size: number of pixels used on the border of the mask to generate the edge of the organoid.
  • Pixel% extraction: percentage of pixels of the input image to be considered. 0: no pixels, 1: all pixels
  • Extraction bias: percentage of pixels extracted from the bright region of the mask. This parameter is useful when inputted gastruloids are particularly small and there is a huge bias in extracting background pixels.
  • Features: 'ilastik' or 'daisy'. In addition to the ilastik features (gaussian blur, laplacian of gaussian, difference of gaussian and gradient), daisy will compute many texture features from the inptu image. This gives more features to train on, but will slow down the training and prediction of new masks.
  1. Once done, hit the Train model button. This may take some time ☕. Once completed, the message ##### Model saved! will be seen on the terminal(MacOS) or command prompt(windows). If a model has previously been generated, select the model folder and the user can skip step 3 & 4 and jump to step 5. For models trained with Multi Layer Perceptrons, tick the option before selection of model folder.

  2. To generate binary masks of new images, select the folder containing images in Specify image folder and click Generate masks. Once completed, the message All images done! will be displayed on the terminal(MacOS) or command prompt(windows). If you would like an overview of all masks generated, click on Save overview image of masks and save the pop-up image.

  3. Click on Inspect masks. This will generate a overview of binary masks overlayed with their respective brightfield images. The mask generated with the watershed algorithm is shown in blue while the red mask is generated with the classifier algorithm.

manual_selection_mask

  1. The other panel will allow the user to chose, for every image, the final mask type: 'ignore' (do not include selected image and mask), 'classifier' (red), 'watershed' (blue), 'manual' (manually create mask). Clicking Show/Hide more parameters will enable the user to change parameters such as downsampling, thinning and smoothing used in the generation of the final mask. Optional: select Compute full meshgrid to generate a meshgrid for straightening of organoid for later quantification. If disabled, meshgrid will automatically be generated later if required.

  2. Next, Compute all masks will generate the final masks for every input image and save them into the result_segmentation subfolder. If 'manual' is selected, the user will be prompted to generate the manual mask on a separate window. As a rule of thumb, the classifier algorithm works most of the times.

Import external masks

  1. If binary masks of all images have already been generated, select Import external masks. This will reveal a new page. This feature allows import of images with multiple objects of interest.

import_external_masks

  1. Specify image and mask folder with the Specify image folder and Specify mask folder buttons. Masks should be labeled as name of its respective image + file identifier. E.g. if the identifier is _GT: Image 20190509_01B_dmso.tif and its mask 20190509_01B_dmso_GT.tif. Please ensure that masks and images are in different folders.

  2. Select Include objects at border of images if all partial images at edges of images are to be included.

  3. Import Masks and Images will create a mask and a image for each object detected in imported images and masks.

B) Quantification

Click on the Quantification tab to enable morphological and fluorescence quantification with previously generated masks.

quantification_tab

  1. Using the Select new dataset button, import all image folders previously generated or imported in the Generate or Import Masks tab into the preferred groups. Each group can refer to one condition or one timepoint. For groups spanning multiple timepoints, users may select the Timelapse data option. More groups can be created by clicking Add New Group at the top. If there is only one group, Groups can be disabled at the top after selection of dataset.

  2. After importing all selected image folders, there are several options available below:

extended_quantification_tab

  • Visualization quantification: creates an overview of all meshgrids and composite images

  • Morphology quantification: Analysis of the following morphological parameters calculated using the unprocessed mask (without straightening) or the straighted mask (straighted using the generated midline). For more information on parameters, refer to scikit-image or Sánchez-Corrales, Y. E. et al. (2018).

    • area
    • eccentricity: ratio of the focal distance over the major axis length; value of 0 as shape approaches a circle.
    • major_axis_length
    • minor_axis_length
    • equivalent_diameter: diameter of a circle with the same area as the region.
    • perimeter
    • euler_number
    • extent
    • orientation
    • locoefa_coeff (indication of complexity of shape; refer to Sánchez-Corrales, Y. E. et al. (2018))
    • Use all parameters: will display 10 graphs, each a quantification of the above parameters.

    Clicking Visualize Morphological Parameter (s) will display one or more of the following windows:

area

In this window, you can edit the quantification of morphological parameters by selecting the type of normalization and background subtraction. Users can also edit the graph shown by changing Pixel size/Scaler, Dimensionality, Plot type and Colormap with the options of removing groups, addition of legend or removal or raw data points on the graph. To view changes, click on Apply Settings after making the desired changes to options shown. Compute statistics shows P-values obtained from T-test, with the option of saving the p-values in a excel sheet. Users can also choose to save all resulting quantification values with the Save Data as xlsx button at the bottom. Square buttons at the top of the window can also be used to adjust the resulting graph with default options provided by matplotlib.

  • Fluorescence quantification: Quantification of fluorescence in the chosen channel with respect to space with the selection of Antero-Posterior profile, Left-Right profile, Radial profile, Angular profile or simply with the average fluorescence intensity. Compute graph will display one such panel shown below:

APprofile

Users can choose to adjust method of quantification by changing Background subtraction type, Y axis normalization or selection of X axis normalization. If a spatial profile was chosen, the orientation of the profile can be signal-based. Users can similarly edit the colours of the graph with the Colormap, edit the X and Y axis labels, choose not to plot unwanted groups, include legends or remove raw data points from the graph shown. After altering the options, click on `Apply Settings` to view the changes. Default options of graphs by matplotib can also be changed with the square buttons at the top of the window.

Supplementary information

Each subfolder containing the final masks also contains a segmentation_params.csv file generated during mask generation with the following information selected during creation of binary masks:

  • filename
  • chosen_mask: classifier (c), watershed (w), manual (m), ignore (i)
  • down_shape
  • thinning
  • smoothing

All morphological properties of organoids are computed when required and saved as ..._morpho_params.json into the same subfolder as the final masks (result_segmentation)

These include:

  • 'input_file'
  • 'mask_file'
  • 'centroid'
  • 'slice'
  • 'area'
  • 'eccentricity' (perfect circle:0, elongated ellipse:~1)
  • 'major_axis_length'
  • 'minor_axis_length'
  • 'equivalent_diameter'
  • 'perimeter'
  • 'anchor_points_midline'
  • 'N_points_midline'
  • 'x_tup'
  • 'y_tup'
  • 'midline'
  • 'tangent'
  • 'meshgrid_width'
  • 'meshgrid'

The _morpho_straight_params.json is computed when required and saved into the same subfolder as the final masks (result_segmentation). It contains the following infomation:

  • area
  • eccentricity
  • major_axis_length
  • minor_axis_length
  • equivalent_diameter
  • perimeter
  • euler_number
  • extent
  • orientation
  • locoefa_coeff (indication of complexity of shape)

The average fluorescence intensities, and those along the Antero-Posterior, Left-Right, Radial and Angular profile of organoids are computed when required and saved as ..._fluo_intensity.json into the same subfolder as the final masks (result_segmentation).