User guide
Circles
POST: /get_etdrs
Description
Builds the ETDRS circle (6mm diameter circle with 3 groups of segments: 1 central (1mm zone), 4 segments (1-3mm zone), 4 segments (3-6mm zone)) for the retinal layers thickness map.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
layers_thickness_maps
|
list
|
layers thickness maps. Has shape of [num_slices, slice_width]. |
required |
used_layers
|
list
|
list of layers which would be encountered in ETDRS circle calculation. Layers available: ["rnfl", "gcl", "ipl", "inl", "opl", "onl", "elm", "mz", "ez", "os", "rpe"] |
required |
statistics
|
list
|
Statistics which should be calculated for each segment. Statistics available: ["mean", "std"] |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
statistics |
dict
|
statistics per each segment in format:
|
POST: /get_gcc_circle
Description
Builds the GCC circle (6mm diameter circle with 2 groups of segments: 1 central (1mm zone), 6 segments (1-6mm zone)) for the retinal layers thickness map.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
layers_thickness_maps
|
list
|
layers thickness maps. Usually has shape of [num_slices, slice_width]. |
required |
used_layers
|
list
|
list of layers which would be encountered in ETDRS circle calculation. Layers available: ["rnfl", "gcl", "ipl", "inl", "opl", "onl", "elm", "mz", "ez", "os", "rpe"] |
required |
statistics
|
list
|
Statistics which should be calculated for each segment. Statistics available: ["mean", "std"] |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
statistics |
dict
|
statistics per each segment in format:
|
Fovea center, fovea and nerve zones
POST: /extract_center_n_fovea
Full pipeline with fovea zone extraction and center detection.
Works in the following way:
-
Tries to find the fovea zone and the center within it. If successful, returns the result.
-
If previous step fails, tries to find the center in the whole examination by finding the most probable point to be the center. If found point fits the 6mm circle, returns the result. The fovea zone is considered to be within 1mm from the center. Landmarks are not returned in this case.
-
If previous step fails, tries to locate the probable center with respect to the nerve zone center (4.5 mm left/right from nerve zone center). Slice number is n/2. If found point fits the 6mm circle, returns the result. The fovea zone is considered to be within 1mm from the center. Landmarks are not returned in this case.
-
Else returns "not_found" with [w/2, n/2] as the center of the examination.
Args:
center_probabilities (list) -- "is_center" model output, probabilities that given slices contain center
fovea_probabilities (list) -- "is_fovea" model_output, probabilities that the given slices contain fovea pit
indices (list) -- list of slice indices for which the coordinate belongs (to preserve the order of slices in the examination)
coordinates (list) -- landamrk_coordinates
landmark_probabilities (list) -- landmark_existance_prob
fovea_existence_threshold (float, Optional) -- threshold for fovea zone existence, default 0.5
fovea_landmark_existence_threshold (float, Optional) -- threshold for landmark existence, default 0.35
fovea_min_number_of_sequential_slices (int, Optional) -- minimum number of sequential slices to consider the fovea zone, default 2
fovea_connectivity_level (int, Optional) -- connectivity level for the fovea zone, default 3
nerve_zone (dict, Optional) -- result of the nerve zone extraction from extract_nerve_zone_landmarks
num_slices (int) -- number of slices in exam
pixel_image_height (int) -- pixel height of a single B-scan.
pixel_image_width (int) -- pixel width of a single B-scan (also pixel width of the exam in en-face view).
slice_thickness (float) -- slice thickness in mm
pixel_spacing_column (float) -- pixel spacing column from DICOM metadata
exam_width_mm (int) -- examination width in mm from DICOM metadata
exam_height_mm (int) -- examination height in mm from DICOM metadata
eps (float, Optional) -- epsilon, default 0.05
nerve_scan_size_threshold (float, Optional) -- starting from which scan size we need to use nerve based center search logic. Defaults to 9 mm.
scan_protocol (str) -- scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D".
Returns:
| Name | Type | Description |
|---|---|---|
JSON |
dict
|
the most probable point to be a center of the examination in the following format:
|
POST: /extract_nerve_zone_landmarks
Nerve zone detection.
Optional parameters are made to make fast changes possible, already set by ML team by default.
Args:
nerve_probabilities (list) -- "has_nerve" model output, probabilities that given slices contain nerve zone
indices (list) -- list of slice indices for which the coordinate belongs (to preserve the order of slices in the examination)
coordinates (list) -- landamrk_coordinates
landmark_probabilities (list) -- landmark_existance_prob
nerve_existence_threshold (float, Optional) -- threshold for nerve zone existence, default 0.3
nerve_confidence_threshold (float, Optional) -- threshold for nerve zone confidence, default 0.65
nerve_landmark_existence_threshold (float, Optional) -- threshold for landmark existence, default 0.3
nerve_min_number_of_sequential_slices (int, Optional) -- minimum number of sequential slices to consider the nerve zone, default 2
nerve_connectivity_level (int, Optional) -- connectivity level for the nerve zone, default 3
Returns:
| Name | Type | Description |
|---|---|---|
JSON |
dict
|
the most probable point to be a center of the examination in the following format:
|
Glaucoma
POST: /get_two_segment_circle
Description
Calculates superior and inferior thicknesses of the retina by its layers. Returns Superior and Inferior parts thicknesses in µm.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_map
|
dict
|
layers thickness map (returned from /get_thickness_map) |
required |
layers
|
list
|
layers to examine (optional, [“rnfl”, “gcl”, “ipl”] by default) |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict: superior and inferior thicknesses of the retina in µm
|
POST: /get_four_segment_circle
Description
Calculates thickness statistics for each element of four segment glaucoma circle.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_map
|
dict
|
layers thickness map (returned from /get_thickness_map) |
required |
layers
|
list
|
layers to examine (optional, [“rnfl”, “gcl”, “ipl”] by default) |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
statistics_to_get
|
list
|
Statistics which should be calculated for each segment. Statistics available: ["mean", "std"]. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
statistics |
dict
|
statistics per each segment in µm |
POST: /get_full_exam_glaucoma_ppaa_matrix
Description
Calculates PPAA matrix for superior and inferior retina parts for full zone of retina.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_map
|
dict
|
layers thickness map (returned from /get_thickness_map) |
required |
layers
|
list, optional, default=[“rnfl”, “gcl”, “ipl”]
|
layers to examine |
required |
metadata
|
dict
|
separate field in json, containing the parameters below:
|
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict in the following format:
|
POST: /get_mmzone_glaucoma_ppaa_matrix
Description
Calculates PPAA matrix for superior and inferior retina parts for defined zone of retina.
More detailed description here: https://media.heidelbergengineering.com/uploads/Products-Downloads/99172-001_SPECTRALIS_Brochure_Posterior-Pole-Insert_EN.pdf
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_map
|
dict
|
layers thickness map (returned from /get_thickness_map) |
required |
layers
|
list, optional, default=[“rnfl”, “gcl”, “ipl”]
|
layers to examine |
required |
zone_of_search
|
float, optional, default=6.0
|
retina zone region in mm which will be used to build the PPAA |
required |
metadata
|
dict
|
separate field in json, containing the parameters below:
|
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict in the following format:
|
POST: /get_glaucoma_stage
Description
Calculates the probable stage of glaucoma.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_s
|
float
|
superior part thickness in µm (from /get_two_segment_circle) |
required |
thickness_i
|
float
|
inferior part thickness in µm (from /get_two_segment_circle) |
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict in the following format:
|
POST: /get_glaucoma_distance_to_normal
Description
Calculates the examination “distance” from normal in terms of glaucoma. 0 means healthy retina, 1 -- glaucoma. Needed for green-yellow-red slider on glaucoma page.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
thickness_s
|
float
|
superior part thickness in µm (from /get_two_segment_circle) |
required |
thickness_i
|
float
|
inferior part thickness in µm (from /get_two_segment_circle) |
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict in the following format:
|
Measurements
POST: /get_linear_calculations
Description
Calculates linear measurements for the pathologies in a single slice of examination.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_segm_instances_per_bscan
|
list
|
List of outputs from pathology segmentation model, containing segmentation instances for every pathology for a single slice in the following format:
|
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
linear_measurements |
list <dict>
|
[list of dicts for every instance in pathologies list] |
POST: /get_distance_between_two_points
Description
Calculates distance between two points on a slice of examination.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
point_from
|
list
|
[x, y] coordinate of point 1 |
required |
point_to
|
list
|
[x, y] coordinate of point 2 |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
distance |
float
|
distance in real units, mm |
POST: /get_bscan_area_calculations_by_polygon
Description
Calculates areas of pathologies per slice.
Example
Input: a list of segmentation instances per one slice:
[
{'points': [...], 'className': 'pathology_name_1'},
{'points': [...], 'className': 'pathology_name_2'},
{'points': [...], 'className': 'pathology_name_1'}
]
Output: a list of areas that correspond to segmentations instances:
[
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_segm_instances_per_bscan
|
list
|
list of pathology segmentation instances per one bscan. [{'points': [...], 'className': ..., ...}, ...] -- list of segmentations per slice |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float, optional, default=None
|
Pixel spacing row from DICOM metadata. Necessary for slice view area calculations. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
areas |
dict[list]
|
areas for each pathology segmentation instance in mm^2 in the following format: { "areas": [float, float, ...] } |
POST: /get_bscan_area_calculations_by_mask
Description
Calculates areas of pathologies per slice.
Example
Input: a list of segmentation instances per one slice:
[
{'points': [...], 'className': 'pathology_name_1'},
{'points': [...], 'className': 'pathology_name_2'},
{'points': [...], 'className': 'pathology_name_1'}
]
Output: a list of areas that correspond to segmentations instances:
[
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_segm_instances_per_bscan
|
list
|
list of pathology segmentation instances per one bscan. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float, optional, default=None
|
Pixel spacing row from DICOM metadata. Necessary for slice view area calculations. |
required |
pixel_image_height
|
int
|
pixel height of a single B-scan. |
required |
pixel_image_width
|
int
|
pixel width of a single B-scan. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
areas |
dict[list]
|
areas for each pathology segmentation instance in mm^2 in the following format: { "areas": [float, float, ...] } |
POST: /get_en_face_area_calculations
Description
Calculates areas of pathologies in en-face view.
Example
Input: a list of segmentation instances per one slice:
[
{'points': [...], 'className': 'pathology_name_1'},
{'points': [...], 'className': 'pathology_name_2'},
{'points': [...], 'className': 'pathology_name_1'}
]
Output: a list of areas that correspond to segmentations instances:
[
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
pathology thickness maps from /get_thickness_map endpoint. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. Necessary for en-face view area calculations. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
areas |
dict
|
areas for each pathology segmentation instance in mm^2 in the following format: { "areas": { "pathology_name_1": float, ... "pathology_name_n": float } } |
POST: /get_volume_calculations
Description
Calculates pathology volume by en-face view thickness map.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
volumes |
dict
|
dict of calculated volumes for each pathology in mm3 in the following format: { "volumes": { "pathology_name_1": float, ... "pathology_name_n": float } } |
Pathology specific
POST: /get_pathology_volume_etdrs_calculations
Description
Calculates the ETDRS circle based on pathology volume, for levels of the ETDRS circle.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps. |
required |
is_cumulative
|
bool
|
whether to calculate ETDRS values in cumulative mode (1mm / 1mm + 3mm / 1mm + 3mm + 6mm zones values). |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
volumes |
dict
|
volumes per each segment in format in mm^3:
|
POST: /get_pathology_area_etdrs_calculations
Description
Calculates the ETDRS circle based on pathology area, for levels of the ETDRS circle.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
is_cumulative
|
bool
|
whether to calculate ETDRS values in cumulative mode (1mm / 1mm + 3mm / 1mm + 3mm + 6mm zones values). |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
areas |
dict
|
areas per each segment in format in mm^2:
|
POST: /get_pathology_volume_etdrs_calculations_zone
Description
Calculates the ETDRS circle based on pathology volume, per ETDRS segment.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
volumes |
dict
|
volumes per each segment in format in mm^3:
|
POST: /get_pathology_area_etdrs_calculations_zone
Description
Calculates the ETDRS circle based on pathology area, per ETDRS segment.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
areas |
dict
|
areas per each segment in format in mm^2:
|
POST: /get_maximal_pathology_slice_index_from_thm
Description
Calculates the maximal presence on the thickness map for each pathology. Returns the slice index with the maximal presence.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
dict
|
dict of pathologies thickness maps in pixel units. |
required |
exam_center_coordinate_xz
|
list
|
The center coordinates [x, y] for cropping. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
Returns:
| Name | Type | Description |
|---|---|---|
max_pathologies |
dict
|
maximal presence of pathologies in format:
|
Analyzers
POST: /get_pathology_amount
Description
Calculates number of drusen on examination. Allowed pathology classes:
-
hard_drusen
-
soft_drusen
-
confluent_drusen
-
drusen
Request Body
pathology_thickness_maps (dict): dict of pathologies thickness maps from /get_pathology_thickness_map endpoint
Response
A JSON object with amount of pathologies instances in the following format:
{
"pathology_name_1": int,
...
"pathology_name_n": int
}
Thickness map
POST: /get_layer_thickness_map
Description
Builds the thickness map given the retinal layers segmentation model results. Returns thickness_map and one of statuses: "OK": thickness_map is created successfully and fits into the zone of interest "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE": thickness_map is created successfully, but zone of interest is bigger than scanning zone
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
- segmentation_instances
|
list
|
list of outputs from retinal layers segmentation model, containing segmentation instances for every slice (length of the list is equal to the amount of scans in examination).
|
required |
- distance_method
|
str, default="axial"
|
"axial" (faster, finds distance between layer borders within a column) or "min_dist" (slower, finds the shortest distance between the layer borders per each column). |
required |
- zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
- run_resolution
|
int
|
resolution of the image to which the input image should be resized. Default is 512. |
required |
Metadata from DICOM that contains
|
|
required | |
- pixel_image_height
|
int
|
pixel height of a single B-scan. |
required |
- pixel_image_width
|
int
|
pixel width of a single B-scan (also pixel width of the exam in en-face view). |
required |
- pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
- slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
- scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
- slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
- pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
- exam_center_coordinate_xz
|
list
|
coordinates of central scan. Should be a list of 2 elements [scan_x_coordinate, central_slice_number]. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
JSON |
dict
|
thickness maps for each segmentation class specified in segmentation_instances in pixel/real units in the following format: { "thickness_maps": { "class_1": [num_slices, pixel_image_width], ... "class_n": [num_slices, pixel_image_width], }, "status": "OK" / "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE" / "NO_THICKNESS_MAPS" } |
POST: /get_pathology_thickness_map
Description
Builds the thickness map given the pathology segmentation model results. Returns thickness_map and one of statuses: "OK": thickness_map is created successfully and fits into the zone of interest "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE": thickness_map is created successfully, but zone of interest is bigger than scanning zone
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
- segmentation_instances
|
list
|
list of outputs from pathology segmentation model, containing segmentation instances for every slice (length of the list is equal to the amount of scans in examination).
|
required |
- used_segmentation_classes
|
list
|
list of segmentation classes to be used for thickness map calculation. By default, calculates thickness maps for all segmentation classes found in instances. |
required |
- use_real_units
|
bool
|
whether to use real units in thickness map calculation. if False -- pixel units are used. |
required |
- distance_method
|
str, default="axial"
|
"axial" (faster, finds distance between layer borders within a column) or "min_dist" (slower, finds the shortest distance between the layer borders per each column). |
required |
- zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
- run_resolution
|
int
|
resolution of the image to which the input image should be resized. Default is 512. |
required |
Metadata from DICOM that contains
|
|
required | |
- pixel_image_height
|
int
|
pixel height of a single B-scan. |
required |
- pixel_image_width
|
int
|
pixel width of a single B-scan (also pixel width of the exam in en-face view). |
required |
- pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
- pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. Should be specified if use_real_units==True. |
required |
- slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
- scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
- slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
- pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
- exam_center_coordinate_xz
|
list
|
coordinates of central scan. Should be a list of 2 elements [scan_x_coordinate, central_slice_number]. |
required |
Returns:
| Name | Type | Description |
|---|---|---|
JSON |
dict
|
thickness maps for each segmentation class specified in segmentation_instances in pixel/real units in the following format: { "thickness_maps": { "class_1": [num_slices, pixel_image_width], ... "class_n": [num_slices, pixel_image_width], }, "status": "OK" / "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE" / "NO_THICKNESS_MAPS" } |
GA measurements
POST: /get_ga_thickness_map
Description
Finds the overlap between the given pathologies (given their thickness maps) that make up the GA region.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
pathology_thickness_maps
|
list
|
list of pathologies thickness maps | the shape is (num_pathologies, num_slices, exam_width) |
required |
Returns:
| Name | Type | Description |
|---|---|---|
ga_thickness_map |
dict
|
overlap between pathologies that make up the GA region:
|
POST: /get_ga_circle_overlap_ratios
Description
Calculates percentage of the circle area covered by GA. The ratio is calculated for 1, 3 and 6 mm circles.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
ga_thickness_map
|
list
|
GA thickness map from get_ga_thickness_map | the shape is (num_slices, exam_width) |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Type | Description |
|---|---|
dict
|
percentage of the area of each circle covered by GA:
|
POST: /get_ga_distance_to_fovea_center
Description
Finds minimal distance from GA region to fovea center.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
ga_thickness_map
|
list
|
GA thickness map from get_ga_thickness_map | the shape is (num_slices, exam_width) |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
distance_to_fovea_center |
float
|
distance from GA region to fovea center in mm |
nearest_point |
list
|
coordinates of the point which is nearest to the GA region { "distance_to_fovea_center": float, "nearest_point": list } |
ODN analysis
POST: /extract_neuroretinal_rim_circles
Description
Extracts neuroretinal rim (disc and cup) from optic disc nerve in px. Processes geometry for each slice using landmarks of bruch's membrane opening and ILM layer for further circles extraction.
Length of nerve_landmarks_list, nerve_slices and ilm_list should be the same. Results in nerve_landmarks_list and ilm_list should correspond to the order in nerve_slices. If ilm cannot be extracted from the model, empy list should be sent for this idx.
disc and cup contain coordinates of polygon points. Cup polygon may be empty in case of excavation absence, minimal amount of points for further processing is 4.
disc and cup are returned both in mm and in px for visualization. Polygons for visualization are created based on scanning zone size and scalling factor. It is done to reduse artifacts due to small resolutions.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
nerve_landmarks_list
|
list
|
list of nerve landmarks from landmark (fovea) model. |
required |
nerve_slices
|
list
|
list of slices where nerve is present from landmark (fovea) model. |
required |
ilm_list
|
list
|
list of ILM layers from retinal layer segmentation model. |
required |
pixel_spacing_row
|
float
|
Pixel spacing row from DICOM metadata. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
ellipse_preprocessing
|
bool, optional, default=True
|
If preprocessing via ellipse fitting is on or raw circles should be returned. |
required |
fill_absent_slices
|
bool, optional, default=True
|
If preprocessing via absent slices filling is on or raw circles will be returned. |
required |
smooth_circles
|
bool, optional, default=True
|
if disc and cup polygons smoothing should be used. |
required |
d_mm
|
(float, optional, 150 * 0.001)
|
distance for raising a parallel line in geometry processing. 150µm is used. |
required |
scaling_factor_visualization
|
(float, optional, 100.0)
|
what scaling will be used for pixel extraction, scaling is done based on scanning zone size. |
required |
img_width
|
int
|
width of the image |
required |
num_slices
|
int
|
amount of slices in the examination |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict: disc and cup that form a neuroretinal rim.
|
POST: /analyze_odn
Description
Analyzes optic disc based on neuroretinal rim's disc and cup. Linear, area calculations are conducted for disc, cup and rim. DDLS (disc damage likelyhood scale) analysis is performed for glaucoma stage assessment. DDLS analysis can be processed only if excavation is present, otherwise only disc parameters will be returned.
All calculated parameters are returned in mm/mm2. All points/lists of points for visualization are returned in px.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
disc
|
list
|
list of points for disc, extracted from extract_neuroretinal_rim_circles in mm. |
required |
cup
|
list
|
list of points for cup, extracted from extract_neuroretinal_rim_circles in mm. |
required |
scaling_factor_visualization
|
(float, optional, 100.0)
|
what scaling will be used for pixel extraction, scaling is done based on scanning zone size. |
required |
Returns:
| Type | Description |
|---|---|
|
JSON dict:
|
Vessel Map
GET: /get_vessel_map
Description
Creates a vessel map / fundus-like image from examination sequential images.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
input_bucket
|
str
|
Bucket name where examinations are stored. |
required |
input_location
|
str
|
Location in the input_bucket of the examination. |
required |
input_bucket_cloud
|
str, optional, default="gcp"
|
Cloud provider where the input_bucket is located. Can be either "gcp" or "azure_uae". |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
inpaint_artifacts
|
bool, optional, default=True
|
If artifacts inpainting should be used. |
required |
scaling_factor_visualization
|
(float, optional, 100.0)
|
what scaling will be used for vessel map, scaling is done based on scanning zone size. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
vessel_map |
str
|
base64 image of shape (scanning zone width x scaling_factor_visualization, scanning zone height x scaling_factor_visualization) |
GET: /get_vessel_map_img_space
Description
Creates a vessel map / fundus-like image from examination sequential images. Returns vessel map in image space (img width x num_slices) and one of statuses: "OK": vessel map is created successfully and fits into the zone of interest "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE": vessel map is created successfully, but zone of interest is bigger than scanning zone
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
input_bucket
|
str
|
Bucket name where examinations are stored. |
required |
input_location
|
str
|
Location in the input_bucket of the examination. |
required |
input_bucket_cloud
|
str, optional, default="gcp"
|
Cloud provider where the input_bucket is located. Can be either "gcp" or "azure_uae". |
required |
inpaint_artifacts
|
bool, optional, default=True
|
If artifacts inpainting should be used. |
required |
scaling_factor_visualization
|
(float, optional, 100.0)
|
what scaling will be used for vessel map, scaling is done based on scanning zone size. |
required |
zone_of_interest
|
float
|
Zone that will be cropped from the center of the thickness map. Default is 6.0 mm. |
required |
center_coordinates
|
list
|
coordinates of central scan. Should be a list of 2 elements [scan_x_coordinate, central_slice_number]. |
required |
pixel_spacing_column
|
float
|
Pixel spacing column from DICOM metadata. |
required |
slice_thickness
|
float
|
Slice thickness from DICOM metadata. |
required |
scan_protocol
|
str
|
scanning protocol of the examination. Can be "HORIZONTAL_3D", "VERTICAL_3D". |
required |
slice_direction
|
str
|
slice direction of the examination. Can be "TOP_BOTTOM", "BOTTOM_TOP" for HORIZONTAL_3D protocol or "LEFT_RIGHT", "RIGHT_LEFT" for VERTICAL_3D protocol |
required |
pixel_direction
|
str
|
pixel direction of the examination. Can be "LEFT_RIGHT", "RIGHT_LEFT" for HORIZONTAL_3D protocol or "TOP_BOTTOM", "BOTTOM_TOP" for VERTICAL_3D protocol |
required |
Returns:
| Name | Type | Description |
|---|---|---|
vessel_map |
list
|
2D list of vessel map in image space (img width x num_slices) |
status |
"OK" / "ZONE_OF_INTEREST_OUT_OF_SCAN_ZONE" |