Object tracking using CellProfiler
Overview
Questions:Objectives:
How to segment and track objects in fluorescence time-lapse microscopy images?
Requirements:
Segment fluorescent objects using CellProfiler in Galaxy
Track objects over multiple frames using CellProfiler in Galaxy
- Introduction to Galaxy Analyses
- Using Galaxy and Managing your Data
- Creating, Editing and Importing Galaxy Workflows: tutorial hands-on
Time estimation: 1 hourSupporting Materials:Last modification: Mar 23, 2021
Introduction
Most biological processes are dynamic and observing them over time can provide valuable insights. Combining fluorescent markers with time-lapse imaging is a common approach to collect data on dynamic cellular processes such as cell division (e.g. Neumann et al. 2010, Hériché et al. 2014). However, automated time-lapse imaging can produce large amounts of data that can be challenging to process. One of these challenges is the tracking of individual objects as it is often impossible to manually follow a large number of objects over many time points.
To demonstrate how automatic tracking can be applied in such situations, this tutorial will track dividing nuclei in a short time-lapse recording of one mitosis of a syncytial blastoderm stage Drosophila embryo expressing a GFP-histone gene that labels chromatin.
Tracking is done by first segmenting objects then linking objects between consecutive frames. Linking is done by matching objects and several criteria or matching rules are available. Here we will link objects if they significantly overlap between the current and previous frames.
tip Prerequisites
It is expected that you are already familiar with the Galaxy interface and the workflow editor. If this is not the case, we recommend you to complete the requirements listed at the start of this tutorial.
warning Important information: CellProfiler in Galaxy
The Galaxy CellProfiler Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_cellprofiler/cp_cellprofiler/3.1.9+galaxy0 tool takes two inputs: a CellProfiler pipeline and an image collection. Some pipelines created with stand-alone CellProfiler may not work with the Galaxy CellProfiler tool. Some reasons are:
- The pipeline was built with a different version of CellProfiler. The Galaxy tool currently uses CellProfiler 3.9.
- Modules used by the pipeline aren’t available in Galaxy.
- Parameters for some CellProfiler modules are limited/constrained compared to the stand-alone version, most notably:
- Parameters require manual input from the user whereas, in the stand-alone version, some modules can inherit parameter values from other modules.
- Input and output file locations are set by Galaxy and can’t be set by the user.
- Metadata extraction from file names is limited to a set of fixed patterns.
It is recommended to build a CellProfiler pipeline using the Galaxy interface if the pipeline is to be run by Galaxy.
Agenda
In this tutorial, we will cover:
Get data
This tutorial will use a time-lapse recording of nuclei progressing through mitotic anaphase during early Drosophila embryogenesis. The nuclei are labelled on chromatin with a GFP-histone marker and have been imaged every 7 seconds using a laser scanning confocal microscope with a 40X objective. The images are saved as a zip archive on Zenodo and need to be uploaded to the Galaxy server before they can be used.
hands_on Hands-on: Data upload
Create a new history for this tutorial. When you log in for the first time, an empty, unnamed history is created by default. You can simply rename it.
Tip: Creating a new history
Click the new-history icon at the top of the history panel.
If the new-history is missing:
- Click on the galaxy-gear icon (History options) on the top of the history panel
- Select the option Create New from the menu
- Import galaxy-upload the files from Zenodo or from the shared data library.
- Important: If setting the type to ‘Auto-detect’, make sure that after upload, the datatype is set to zip.
https://zenodo.org/api/files/e5d1bd5c-60a0-42e4-8f0d-a2ebc863c5d9/drosophila_sample.zip
Tip: Importing via links
- Copy the link location
Open the Galaxy Upload Manager (galaxy-upload on the top-right of the tool panel)
- Select Paste/Fetch Data
Paste the link into the text field
Press Start
- Close the window
- Rename galaxy-pencil the file to drosophila_embryo.zip
Create a CellProfiler pipeline in Galaxy
In this section, we will build a CellProfiler pipeline from scratch in Galaxy. We need to:
- Read the images and the metadata
- Convert the colour images to grayscale
- Segment the nuclei
- Extract features from the segmented nuclei
- Perform tracking
- Produce some useful output files
A pipeline is built by chaining together Galaxy tools representing CellProfiler modules and must start with the Starting modules Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_common/cp_common/3.1.9+galaxy1 tool and end with the CellProfiler Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_cellprofiler/cp_cellprofiler/3.1.9+galaxy0 tool.
details More details about the pipeline steps
- Metadata is needed to tell CellProfiler what a temporal sequence of images is and what the order of images is in the sequence.
- CellProfiler is designed to work primarily with grayscale images. Since we don’t need the colour information, we convert colour images to grayscale type.
- Segmentation means identifying the nuclei in each image. In CellProfiler, this is done by thresholding the intensity level in each image.
- When we perform tracking we’re usually interested in quantifying how some properties of the objects evolve over time. Also, sometimes we may want to do tracking by matching objects based on some property of the objects (e.g. a shape measurement). Therefore, for each segmented object, we compute some features, i.e. numerical descriptors of some properties of the object.
- Tracking will provide the information required to allow downstream data analysis tools to link the features into a multidimensional time series.
Create a new workflow
hands_on Hands-on: Creating a new workflow
Create a new workflow
Tip: Creating a new workflow
- Click Workflow on the top bar
- Click the new workflow galaxy-wf-new button
- Give it a clear and memorable name
- Clicking Save will take you directly into the workflow editor for that workflow
- Need more help? Please see the How to make a workflow subsection here
The next steps will add new tools using the workflow editor. Remember to save the workflow when done (or anytime) to not lose your input parameters.
Read the images
hands_on Hands-on: Reading images
Add Inputs → Input Dataset to the workflow
Add tool Unzip with the following parameter:
- param-select “Extract single file”:
All files
Get the metadata
comment Comment
The Starting modules tool combines four CellProfiler modules that are always used together at the start of a pipeline. These modules are:
- Images
- Metadata
- NamesAndTypes
- Groups
hands_on Hands-on: Getting metadata
Starting modules Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_common/cp_common/3.1.9+galaxy1 with the following parameters:
- Images
- “Do you want to filter only the images?”:
Select the images only
- Metadata
“Do you want to extract the metadata?”:
Yes, specify metadata
- param-repeat Insert new metadata
- “Metadata extraction method”:
Extract from file/folder names
- “Metadata source”:
File name
- “Select the pattern to extract metadata from the file name”:
field1_field2_field3
“Extract metadata from”:
Images matching a rule
- “Match the following rules”:
All
- param-repeat Insert filtering rules:
- “Select the filtering criteria”:
File
- "”operator:
Does
- “contain”:
Contain regular expression
- “match_value”:
GFPHistone
- NamesAndTypes
- “Process 3D”:
No, do not process 3D data
- “Assign a name to”:
Give images one of several names depending on the metadata
- param-repeat Insert another image:
- “Match the following rules”:
All
param-repeat Insert rule:
“Select rule criteria”:
File
- “operator”:
Does
- “contain”:
Contain regular expression
- “match_value”:
GFPHistone
- “Select the image type”:
Color image
- “Name to assign these images”:
OrigColor
- “Set intensity range from”:
Image metadata
- “Image matching method”:
Metadata
- Groups
- “Do you want to group your images?”:
Yes, group the images
- “Metadata category”:
field1
question Question
How are we capturing metadata and what type of metadata are we getting?
solution Solution
Metadata is obtained from the filenames by extracting three text fields separated by an underscore. The metadata we get is “DrosophilaEmbryo”, “GFPHistone” and numbers with leading zeros. These three fields represent respectively the sample identifier, the marker visualized in the image and the index in the time series.
question Question
How will CellProfiler form a temporal sequence?
solution Solution
Images will be grouped based on field1 which here is the sample identifier and ordered alpha-numerically (by default) which will order them by field3 (the time series index) since fields 1 and 2 are constant.
Convert the images to grayscale
hands_on Hands-on: Colour to grayscale conversion
- ColorToGray Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_color_to_gray/cp_color_to_gray/3.1.9+galaxy0 with the following parameters:
- “Select the input CellProfiler pipeline”: Connect output of Starting Modules tool to input of ColorToGray
- “Enter the name of the input image”:
OrigColor
- “Conversion method”:
Combine
- “Name the output image”:
OrigGray
- “Image type”:
RGB
- “Relative weight of the red channel”:
1
- “Relative weight of the green channel”:
1
- “Relative weight of the blue channel”:
1
Segmentation
The first step to track nuclei starts with the identification of those objects on the images.
hands_on Hands-on: Nuclei segmentation
- IdentifyPrimaryObjects Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_identify_primary_objects/cp_identify_primary_objects/3.1.9+galaxy1 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of ColorToGray tool
- “Use advanced settings?”:
Yes, use advanced settings
- “Enter the name of the input image (from NamesAndTypes)”:
OrigGray
- “Enter the name of the primary objects to be identified”:
Nuclei
- “Typical minimum diameter of objects, in pixel units (Min)”:
30
- “Typical maximum diameter of objects, in pixel units (Max)”:
9999
- “Discard objects outside diameter range?”:
Yes
- “Discard objects touching the border of the image?”:
Yes
- “Threshold strategy”:
Global
- “Thresholding method”:
Otsu
- “Two-class or three-class thresholding?”:
Three classes
- “Assign pixels in the middle intensity class to the foreground or the background?”:
Background
- Threshold smoothing scale”:
1.3488
- Threshold correction factor”:
1
- Lower bound on threshold”:
0.01
- Upper bound on threshold”:
1
- “Method to distinguish clumped objects”:
Intensity
- “Method to draw dividing lines between clumped objects”:
Intensity
- “Automatically calculate size of smoothing filter for declumping?”:
Yes
- “Automatically calculate minimum allowed distance between local maxima?”:
Yes
- “Speed up by using lower-resolution mage to find local maxima?”:
Yes
- “Fill holes in identified objects”:
After both thresholding and declumping
- “Handling of objects if excessive number of objects identified”:
Continue
Feature extraction
Once the objects of interest (nuclei) are identified, we extract features, i.e. numerical descriptors of object properties. We do this because we may be interested in analysing the evolution of these properties over time or want to use them in the tracking procedure to match objects over time.
hands_on Hands-on: Shape features
- MeasureObjectSizeShape Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_measure_object_size_shape/cp_measure_object_size_shape/3.1.9+galaxy0 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of IdentifyPrimaryObjects tool
- In “new object”:
- param-repeat “Insert new object”
- “Enter the name of the object to measure”:
Nuclei
- “Calculate the Zernike features?”:
No
hands_on Hands-on: Intensity features
- MeasureObjectIntensity Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_measure_object_intensity/cp_measure_object_intensity/3.1.9+galaxy0 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of MeasureObjectSizeShape tool
- In “new image”:
- param-repeat “Insert new image”
- “Enter the name of an image to measure”:
OrigGray
- In “new object”:
- param-repeat “Insert new object”
- “Enter the name of the objects to measure”:
Nuclei
Track nuclei
With the nuclei and the relevant features measured, we are now ready to start the tracking step!
hands_on Hands-on: Object tracking
- TrackObjects Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_track_objects/cp_track_objects/3.1.9+galaxy0 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of MeasureObjectIntensity tool
- “Enter the name of the objects to track”:
Nuclei
- “Choose a tracking method”:
Overlap
- “Maximum pixel distance to consider matches”:
50
- “Filter objects by lifetime?”:
No
- “Select display option?”:
Color and Number
- “Save color-coded image?”:
Yes
- “Name the output image”:
TrackedNuclei
Visualize results
To make sure that the tracking has gone as expected, we will have a look at the original images together with the results of the segmentation step. And we will visualize them together (in tiles) for easier comparison.
hands_on Hands-on: Visualize segmentation outcome
- OverlayOutlines Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_overlay_outlines/cp_overlay_outlines/3.1.9+galaxy0 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of TrackObjects tool
- “Display outlines on a blank image?”:
No
- “Enter the name of image on which to display outlines”:
OrigGray
- “Outline display mode”:
Color
- In “Outline”:
- param-repeat “Insert Outline”
- “Enter the name of the objects to display”:
Nuclei
- “Select outline color”: (red)
- “Name the output image”:
OutlineImage
- “How to outline”:
Inner
hands_on Hands-on: Tiling images
- Tile Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_tile/cp_tile/3.1.9+galaxy0 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of OverlayOutlines tool
- “Enter the name of an input image”:
OrigColor
- “Name the output image”:
TiledImages
- “Tile assembly method”:
Within cycles
- “Automatically calculate number of rows?”:
No
- “Final number of rows”:
1
- “Automatically calculate number of columns?”:
Yes
- “Image corner to begin tiling”:
top left
- “Direction to begin tiling”:
row
- “Use meander mode?”:
No
- In “Another image”:
- param-repeat “Insert Another image”
- “Enter the name of an additional image to tile”:
OutlineImage
- param-repeat “Insert Another image”
- “Enter the name of an additional image to tile”:
TrackedNuclei
Save the images and features
The tiled images and the features computed in previous steps are now exported to the Galaxy history ready to be analyzed.
hands_on Hands-on: Save the images
- SaveImages Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_save_images/cp_save_images/3.1.9+galaxy1 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of Tile tool
- “Select the type of image to save”:
Image
- “Saved the format to save the image(s)”:
png
- “Enter the name of the image to save”:
TiledImages
- “Select method for constructing file names”:
From image filename
- “Enter the image file name”:
OrigColor
- “Append a suffix to the image file name”:
Yes
- “Text to append to the image file name”:
_tile
- “Overwrite existing files without warning?”:
Yes
- “When to save”:
Every cycle
- “Record the file and path information to the saved image?”:
No
question Questions
What will be the file names of the output images?
solution Solution
The files will be named DrosophilaEmbryo_GFPHistone_0000_tile.png, DrosophilaEmbryo_GFPHistone_0001_tile.png …
hands_on Hands-on: Export tabular data to character-delimited text files
- ExportToSpreadsheet Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_export_to_spreadsheet/cp_export_to_spreadsheet/3.1.9+galaxy1 with the following parameters:
- param-file “Select the input CellProfiler pipeline”: output of SaveImages tool
- “Select the column delimiter”:
Comma (",")
- “Add a prefix to file names?”:
Do not add prefix to the file name
- “Overwrite existing files without warning”:
Yes
- “Add image metadata columns to your object data file”:
Yes
- “Representation of Nan/Inf”:
NaN
- “Calculate the per-image mean values for object measurements?”:
Yes
- “Calculate the per-image median values for object measurements?”:
Yes
- “Calculate the per-image standard deviation values for object measurements?”:
Yes
- “Create a GenePattern GCT file?”:
No
comment Comment
By default all measurement types are exported. This is in contrast to the stand-alone version of CellProfiler which allows choosing which measurement types to save.
Run the pipeline with CellProfiler
As mentioned in the introduction, the tool CellProfiler Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_cellprofiler/cp_cellprofiler/3.1.9+galaxy0 takes as input the pipeline that we have been assembling over this tutorial and the input data. We are now ready to finally run CellProfiler!
hands_on Hands-on: Running the pipeline with CellProfiler
- CellProfiler Tool: toolshed.g2.bx.psu.edu/repos/bgruening/cp_cellprofiler/cp_cellprofiler/3.1.9+galaxy0 with the following parameters:
- param-file “Pipeline file”: `output of ExportToSpreadsheet tool
- “Are the input images packed into a tar archive?”:
No
- param-collection “Images”: output of Unzip tool
- “Detailed logging file?”:
Yes
Run the workflow.
Tip: Running a workflow
- Click on Workflow on the top menu bar of Galaxy. You will see a list of all your workflows.
- Click on the workflow-run (Run workflow) button next to your workflow
- Configure the workflow as needed
- Click the Run Workflow button at the top-right of the screen
- You may have to refresh your history to see the queued jobs
comment Comment
If the pipeline fails, inspect the CellProfiler log file for clues about errors. A common source of errors is not providing the correct information to a module such as pointing a CellProfiler module at a non-existent dataset (e.g. with a typo in the name).
question Questions
How many nuclei have been tracked?
solution Solution
Five objects were detected but only four of these were nuclei.
question Questions
How could we get rid of tracks that don’t correspond to nuclei?
solution Solution
Objects that are not nuclei appear to be transient so one solution would be to require the tracks to have a minimal length. This can be done using the “Filter objects by lifetime” parameter of the TrackObjects module.
question Questions
Where is the data needed to plot change in nuclei eccentricity over time?
solution Solution
The data is in the csv file called Nuclei in the CellProfiler pipeline output data set.
Conclusion
We’ve run a CellProfiler pipeline on Galaxy to segment and track dividing nuclei in a Drosophila embryo. We’ve exported images to visually inspect the outcome and saved tables of computed object features in comma-separated text files for future analysis.
Key points
CellProfiler in Galaxy can be used to track objects in time-lapse microscopy images
Frequently Asked Questions
Have questions about this tutorial? Check out the tutorial FAQ page or the FAQ page for the Imaging topic to see if your question is listed there. If not, please ask your question on the GTN Gitter Channel or the Galaxy Help ForumUseful literature
Further information, including links to documentation and original publications, regarding the tools, analysis techniques and the interpretation of results described in this tutorial can be found here.
References
- Neumann, B., T. Walter, J.-K. Hériché, J. Bulkescher, H. Erfle et al., 2010 Phenotypic profiling of the human genome by time-lapse microscopy reveals cell division genes. Nature 464: 721–727. 10.1038/nature08869
- Hériché, J.-K., J. G. Lees, I. Morilla, T. Walter, B. Petrova et al., 2014 Integration of biological data by kernels on graph nodes allows prediction of new genes involved in mitotic chromosome condensation (D. G. Drubin, Ed.). Molecular Biology of the Cell 25: 2522–2536. 10.1091/mbc.e13-04-0221
Feedback
Did you use this material as an instructor? Feel free to give us feedback on how it went.
Did you use this material as a learner or student? Click the form below to leave feedback.
Citing this Tutorial
- Yi Sun, Beatriz Serrano-Solano, Jean-Karim Hériché, 2021 Object tracking using CellProfiler (Galaxy Training Materials). https://training.galaxyproject.org/training-material/topics/imaging/tutorials/object-tracking-using-cell-profiler/tutorial.html Online; accessed TODAY
- Batut et al., 2018 Community-Driven Data Analysis Training for Biology Cell Systems 10.1016/j.cels.2018.05.012
details BibTeX
@misc{imaging-object-tracking-using-cell-profiler, author = "Yi Sun and Beatriz Serrano-Solano and Jean-Karim Hériché", title = "Object tracking using CellProfiler (Galaxy Training Materials)", year = "2021", month = "03", day = "23" url = "\url{https://training.galaxyproject.org/training-material/topics/imaging/tutorials/object-tracking-using-cell-profiler/tutorial.html}", note = "[Online; accessed TODAY]" } @article{Batut_2018, doi = {10.1016/j.cels.2018.05.012}, url = {https://doi.org/10.1016%2Fj.cels.2018.05.012}, year = 2018, month = {jun}, publisher = {Elsevier {BV}}, volume = {6}, number = {6}, pages = {752--758.e1}, author = {B{\'{e}}r{\'{e}}nice Batut and Saskia Hiltemann and Andrea Bagnacani and Dannon Baker and Vivek Bhardwaj and Clemens Blank and Anthony Bretaudeau and Loraine Brillet-Gu{\'{e}}guen and Martin {\v{C}}ech and John Chilton and Dave Clements and Olivia Doppelt-Azeroual and Anika Erxleben and Mallory Ann Freeberg and Simon Gladman and Youri Hoogstrate and Hans-Rudolf Hotz and Torsten Houwaart and Pratik Jagtap and Delphine Larivi{\`{e}}re and Gildas Le Corguill{\'{e}} and Thomas Manke and Fabien Mareuil and Fidel Ram{\'{\i}}rez and Devon Ryan and Florian Christoph Sigloch and Nicola Soranzo and Joachim Wolff and Pavankumar Videm and Markus Wolfien and Aisanjiang Wubuli and Dilmurat Yusuf and James Taylor and Rolf Backofen and Anton Nekrutenko and Björn Grüning}, title = {Community-Driven Data Analysis Training for Biology}, journal = {Cell Systems} }