Skip to content

Cytomine software. Segmentation by computer vision using an adaptive threshold on a sample

License

Notifications You must be signed in to change notification settings

Cytomine-ULiege/S_Segment-CV-AdaptThres-Sample

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cytomine software - Segment-CV-AdaptThres-Sample

Cytomine (https://cytomine.org) app developed by ULiège Cytomine Research team (https://uliege.cytomine.org) for segmentation of samples using Computer Vision (CV) Adaptive Thresholding.

This implementation follows Cytomine (=v3.0) external app conventions based on container technology.

  • Summary: It applies a thresholding algorithm to a thumbnail of a whole image (downloaded from Cytomine-Core) and upload detected geometries to Cytomine-Core (in a userjob layer)

To launch such an analysis, a user first specifies a Cytomine term identifier. The app will then apply the algorithm to specified images in the project. If not specified, all Cytomine images belonging to the current project. Detected objects are labeled with the term identifier.

  • Typical application: Detect sample regions before applying other algorithms (e.g. segmentation).

  • Based on: Adaptive Thresholding (https://docs.opencv.org/3.4/d7/d4d/tutorial_py_thresholding.html) but code can be easily adapted to other thresholding algorithms.

  • Example on CMU-1 open image with the Image Area Percentile Threshold parameter to 3. AdaptThreshold

  • Parameters:

    • cytomine_host, cytomine_public_key, cytomine_private_key, cytomine_id_project and cytomine_id_software are parameters needed for all Cytomine external apps. They will allow the app to be run on the Cytomine instance (determined with its host), connect and communicate with the instance (with the key pair). An app is always run into a project (cytomine_id_project) and to be run, the app must be previously declared to the plateform (cytomine_id_software).
    • cytomine_id_images : The image identifiers on which the app is run. If not specified, all images in the project will be considered.
    • cytomine_id_predicted_term : The detected components will be associated to a term corresponding to the given id.
    • max_image_size : During the run, the analyzed images will be resized if the width or the height are larger than the corresponding value of this parameter. Default value is 2048. Be careful that if you allow bigger image size, the download will take more time and, for high value, timeout can occur.
    • image_area_perc_threshold : The detected component with an area less than a specific value (calculated as a percentil of the image area) will not be kept. Default value is 5%. Modify this value to be able to kept smaller object. In the previous CMU-1 exemple, the input value was 3 to catch the smaller two Region Of Interest.
    • threshold_blocksize and threshold_constant are used as parameter of the adaptiveThreshold function of OpenCV
    • erode_iterations is the number of erosion applied to an image and dilate_iterations is the number of dilation applied to an image after the erosion step. Find more about eroding and dilating on the OpenCV documentation
    • Finally, you can modify the log_level by setting one of these values 'DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL' or unset.

Copyright 2010-2022 University of Liège, Belgium, https://uliege.cytomine.org