This project is about a placozoa that has been cut in its center.
To install Python and the required dependencies we strongly recommend to use conda, mamba or pipenv.
Conda can be installed multiple ways. There is no recommendations about how to but one can read there for a likely exhaustive list on ways to install conda.
Note that Anaconda is not necessarily recommended, miniconda might be a better alternative.
Moreover, it is advised to start jupyter notebooks from a shell/terminal/prompt to be able to better see the error messages.
Once conda is installed (or your favorite environment manager), you can create and activate your environment:
conda create -n placozoa
conda activate placozoa
Then, there is a setup.py
file with the basic dependencies present within this
repository. It means that you can easily install all the likely necessary
dependencies using pip. It might be necessary to install it first:
conda install pip
Then, it is possible to install the dependencies, from the placozoa-tracking folder the following way:
pip install .
Here is the list of dependencies that will be installed:
- numpy : basic library for array manipulation
- matplotlib : basic library to plot figures
- scipy : one of the basic libraries for image analysis (
ndimage
) - scikit-image : one of the basic libraries for image analysis
- scikit-learn : one of the basic libraries for data analysis
- tifffile : library to read and write tiff images
- ipython : interactive python terminal
- jupyter : python notebook
- napari : 3D image visualizer
Understanding better Placozoans wound healing
The objectives are likely in order of difficulty but they can be done in any.
It is not expected, whatsoever, for all the objectives to be completed.
- Detecting and tracking the placozoan throughout the whole movie #2
- Quantitatively characterising the shape of the placozoan over time #3
- Detecting and tracking the wound throughout the whole movie #4
- Quantitatively characterising the shape of the wound over time #5
- Building a napari plugin for the detection and tracking #6
- Computing and quantifying the cell flows within the placozoan #7
- Putting in relation placozoan and wound shape with cell flows #8
You can find the roadmap for the project as an issue there.
You should try to follow the objectives but the order is not important (though some milestones are dependent on others).
→ #2
→ #4
#2 → #3
#4 → #5
#2 | #4 → #6
→ #7
(#3 | #4) & #7 → #8
Legend:
- #x → #y: #x needs to be completed before #y can be started
- #x | #y: #x or #y needs to be completed
- #x & #y: #x and #y needs to be completed
This pipeline is under an open-source license BY-NC (can be reused, modified, for no commercial purpose, with attribution of the authors when used for publication). Code Authors: Alice Gros, Clément Caporal, Gesa Loof, Amirhossein Esmaeili, Dominika Guttenova, Louise Dagher
The following analysis have been developed:
- Shape segmentation (contouring the Trichoplax shape or its ablation wound shape): 3 differents strategies have been investigated. They require the original movie as tif as input. They generate a tif file of the segmented shape (= binary mask).
- A deep learning model has been trained on hand-made labelled bright-field trichoplax movie. The needed input file is a tif file with one channel correspond to the bright-field channel and one channel to the labels (Layer 1, the Trichoplax, Layer 2, the background). This kind of labelling can be done in Napari, before starting the training.
- Otsu's method: The code performs automatic thresholding to separate pixels into two classes of foreground & background. This threshold is determined by by maximizing inter-class variance. A suitable candidate for creating shape masks of microscopic images of cells
- Segmentation using morphsnakes: Finding outer edge of the animal using the morphsnakes algorithm for contour finding by comparing intensity averages inside and outside of a region.
-
Preprocessing of the wound: This code extract the wound shape from the Trichoplax mask (given as tif input) and generates a new tif mask only for the wound. /!\ Running this part is necessary before doing the shape features analysis for the wound.
-
Shape features analysis: This code analyzes the object mask (either the Trichoplax or its wound) and compute shape features. Some of the features are computed from the region props Python module: you have to specify them in the 'props' list. Others can be added in the func_features.py, or new cell in the notebook. The output is a dataframe containing all the properties, saved as csv.
/!\ This part needs to be run twice if you want to analyse the Trichoplax shape and its wound shape; Don't forget to change mask filename input and dataframe name output ;) -
Plot generated shape data: load the two previous csv files (Trichoplax and wound dataframes). It generates examples of analysis: area overtime, convexity, eccentricity, orientation angle, ...
-
Investigate flows within the Trichoplax: To understand the collective cell movements after laser ablation.
This code generates the velocity fields of pixels within the Trichoplax, from the global displacement of pixels between one timepoint to another. The wanted time window for the analysis (delta t), as well as the index of starting timepoint, the raw image name, folder for saving, should be specified as input. The output is a sequence of png images, that you can afterwhat load in FIJI and convert to gif file. This code could be improved by saving the coordinates of the vectors.
-
Segmentationn of Trichoplax lipid-containing cells