This document accompanies the higher-level descriptions found in the Algorithm SDK and the Application SDK, and provides more detailed programming information.
This document describes the following:
- JSON Metadata for Integrating Algorithms
- Datastore Python API
- REST API Provided by rt106-server
- AngularJS Services Provided by rt106-app
- AngularJS Factories Provided by rt106-app
The metadata for an integrated algorithm is documented using a JSON format in rt106SpecificAdaptorDefinisions.json. Several examples are provided in rt106-algorithm-template, simple-region-growing, and wavelet-nuclear-segmentation. Please refer to these as a starting point for your own algorithm's metadata.
Here is a description of the individual algorithm metadata fields:
- name - should be lower case, connected by dashes.
- version - can be according to your own versioning system, possibly using major_minor_patch versions e.g. v1_0_0. Underscores should be used.
- queue - concatenate name and version, separated by two underscores, e.g. "__"
- parameters - this section includes both input data and input parameters, represented in a JSON object, each tagged with the name of a parameter (or input). The parameters section also includes a required field that lists those parameters that are required by the algorithm. Those that are not required may be displayed in the user interface along with a control for the user to specify whether or not the parameter should included. Sub-fields of each parameter include:
- label -- a name that will be displayed in the user interface.
- description -- brief documentation on the parameter.
- type -- controls what type of input control is displayed, supported types include: number, boolean, text, series, (currently-displayed DICOM image series), voxelIndex (coordinates selected from current image).
- default -- starting value of the parameter if it is not edited by the user.
- results -- describes each output of the algorithm. Subfields are the same as for parameters, except there is no default field.
- result_display -- describes how output images should be displayed. NOTE: This feature is limited and experimental. It may be extended and improved based on user priorities. This is a JSON structure having the following fields:
- grid -- the shape of an image grid represented as [rows,columns].
- shape -- number of rows and columns, represented as a list of two numbers, e.g. [2,1]. NOTE: Only the values 1,2 are currently implemented.
- columns -- relative sizes of each column. Not yet implemented.
- rows -- relateive sizes of each row. Not yet implemented.
- cells -- list of descriptions of the "cells" that contain image viewers.
- row -- which row, with first one numbered zero.
- column -- which column, with first one numbered zero.
- cellType -- "image" (DICOM) or "pathologyImage"
- source -- either "context" (input) or "result" (output)
- parameter -- name of input parameter or result, defined above
- cellDisplayMode -- "background" or "overlay"
- imageProcessing optional parameter to process the image before displaying it. The only currently supported option is "toBinaryImage".
- properties -- optional parameter to set the color of a monochrome image, e.g. "properties" : { "color" : "rgb(255,51,51)" }
- controls -- optional parameter to assocate a color picker and opacity slidebar with an image, e.g.: "controls": { "opacity": "Mask Opacity: ", "color": "Mask Color: " }. The value of each element is the label to be displayed in the user interface.
- grid -- the shape of an image grid represented as [rows,columns].
- api -- not yet used
- doc -- not yet used
- classification -- hierarchical classification of the algorithm e.g. "segmentation/cellular/nuclei" Can be used in the app for filtering the algorithm list to certain types.
These functions are available for the short Python script that you need to write that marshalls data from the Rt 106 datastore to your algorithm and stores generated results back to the datastore.
The Rt 106 data API has been written with an initial focus on medical imaging / radiology data and pathology / microscopy data, but has been designed so that additional data types can be easily added later.
Rt 106 supports a common data API that is independent of storage mechanism. The initial release of Rt 106 includes a "Datastore-Local" implementation which stores data files in a local directory structure. In the future, alternate data storage mechanisms can be built, including direct storage in Amazon S3 or a PACS system.
An important concept for Rt 106 datastores is that a path is a storage location within a datastore, but the format of the path may be specific for the type of datatore. Therefore, code that calls the data API should never presume to know the structure of paths; the path should always be obtained from an API call to the datastore that returns a path.
- datastore.retrieve_series( series_path, output_dir )
- description: Retrieve the DICOM series represented by the provided path and store it (within the algorithm container) in the specified output directory.
- parameters:
- series_path: Path name where the series is stored in the datastore. (This should have been received as part of the incoming algorithm request message.)
- output_dir: Local directory within the algorithm's container where the series should be stored as a tar file.
- return value: HTTP-standard status code (i.e. 200 means OK.)
- datastore.get_upload_series_path( input_path )
- description: Given the path to a DICOM series that will be input to the algorithm, return a path where the algorithm result (another DICOM series) should be loaded.
- parameter:
- input_path: Path name where the input series is stored in the datastore.
- return value: Path name where an output DICOM series should be stored, or an error code.
- datastore.upload_series( series_path, input_dir )
- description: Write a DICOM series stored in the local container to the specified path in the datastore.
- parameters:
- series_path: Path where the series is to be uploaded to the datastore.
- input_dir: Directory in the local Docker container where the series is already located.
- return value: A JSON structure containing a response code and other information. If there is already a series in series_path, the upload will not be performed and an error is returned.
- datastore.get_pathology_primary_path( slide, region, channel )
- description: Return the storage path for the given "primary" image (i.e. acquired in lab rather than algorithm-generated), where the image is specified by slide, region, and channel.
- parameters:
- slide: name of the slide
- region: name of the region on the slide
- channel: acquisition channel, which may be a wavelength of light or a logical name, such as biomarker.
- return value: Path where the corresponding image can be stored or retrieved, or an error code.
- datastore.get_pathology_result_path( slide, region, pipelineid, execid)
- description: Return the storage path for the given result image (i.e. generated by an algorithm or manual annotation, rather than by acquisition equipment), where the image is specified by slide, region, pipelineid, and execid.
- parameters:
- slide: name of the slide
- region: name of the region on the slide
- pipelineid: name of a "pipeline" in the sense of a run of the analysis pipeline -- A set of algorithms may be run multiple times with different parameter settings. The pipeline is a name associated with a run so that results from multiple runs can be managed and compared.
- execid: name or ID of a run of one of the steps within a set of algorithms.
- return value: Path where the corresponding image can be stored or retrieved, or an error code.
- datastore.retrieve_multi_channel_pathology_image( input_path, output_dir )
- description: Retrieve all the images (multiple channels) for a given slide region.
- parameters:
- input_path: path where the region data is stored
- output_dir: local directory within the container where the downloaded images should be stashed
- return value: status code
- datastore.get_instance( path, filedir, filename, format )
- description: Retrieve a data instance from the datastore and save it in a file in the local container.
- parameters:
- path: location of the data in the Rt 106 datastore
- filedir: local directory into which to store the data file
- filename: local file into which to store the data
- format: the format of the data (e.g. 'dicom', 'tiff16', 'csv')
- return value: status code
- datastore.post_instance( path, filedir, filename, format, force )
- description: Store a file from the local container to the datastore.
- parameters:
- path: location of the data in the Rt 106 datastore to store the data
- filedir: local directory containing the data file
- filename: local file containing the data
- format: the format of the data (e.g. 'dicom', 'tiff16', 'csv')
- force: If false, trying to overwrite data that is already in the datastore returns an error. If true, overwrite is allowed without an error.
- return value: JSON structure with details, or an error code
Efforts have been made to define a stable API even for the initial release of Rt 106. Over time, we expect new API calls to be added, especially to support additional data types. Our goal is minimize changes to APIs after they have been released. If there is ever a need for drastic changes to the API, we would advance the API version to /v2, and /v1 would still be provided to support existing applications.
In the descriptions below, a term in the REST API preceded by a colon indicates that a specific name should be provided in that position. (This follows the conventions used by Node.js Express for REST calls.)
-
/v1/execution (POST)
- Description: Request an algorithm execution.
- Returns: Status of successfully receiving and queuing the request.
- Payload: JSON structure specifying the algorithm to run and its context, such as this example:
{ "analyticId": { "name":"algorithm-template--v1_0_0", "version":"v1.0.0" }, "context":{ "inputSeries":"/Patients/pat004/Primary/Imaging/studyD/spine_Anonymous360_PURE", "seedPoint":[0,0,0], "threshold":0 } }
-
/v1/executions (GET)
- Description: Query the rt106-server's in-memory list of algorithm executions.
- Returns: Array of JSON objects describing the history of algorithm executions. Each record includes the analytic name, an execution ID, time stamps for the request and completion, all the input parameters and result data. For data that is stored in the datastore (i.e. image files) the URI is listed rather than the actual file contents.
-
/v1/queryExecutionList (GET)
- Description: Tells rt106-server to restore its in-memory algorithm execution list from the database. This is typically called on system startup.
- Returns: A status string.
-
/v1/analytics/evaluation (POST)
- Description: Write the user's evaluation of an algorithm to the database.
- Payload: A JSON structure containing user feedback about an algorithm. Fields include execution ID, an evaluation value (typically a number on a scale provided to the user) and a comment string.
-
/v1/analytics (GET)
- Description: Query the list of running analytics.
- Returns: JSON dictionary where each key is an analytic name.
-
/v1/analytics/:analytic (GET)
- Description: Query for a specific algorithm by name.
- Returns: A JSON structure having the name and version of the algorithm if it exists, or an error code if it does not exist.
-
/v1/analytics/:analytic/api (GET)
- Description: Query the API for the given algorithm. NOT YET IMPLEMENTED.
-
/v1/analytics/:analytic/queue (GET)
- Description: Query the queue name used by the internal Rt 106 messaging system for the specified algorithm.
- Returns: Queue name in a JSON structure if the algorithm exists, an error code if the algorithm does not exist.
-
/v1/analytics/:analytic/parameters (GET)
- Description: Return the input data and parameters required by the algorithm.
- Returns: A JSON structure with the above if the algorithm exists, an error code if it does not.
-
/v1/analytics/:analytic/results (GET)
- Description: Return the expected results that will be returned by the algorithm (not actual results).
- Returns: A JSON structure with the above if the algorithm exists, an error code if it does not.
-
/v1/analytics/:analytic/results/display (GET)
- Description: Return the display format that will be appropriate for the algorithm execution results.
- Returns: A JSON structure with the above if the algorithm exists, an error code if it does not.
-
/v1/analytics/:analytic/documentation (GET)
- Description: Return documentation on the algorithm. NOT YET IMPLEMENTED.
-
/v1/analytics/:analytic/classification (GET)
- Description: Return the classifiction of the algorithm type, which can be used for filtering for specific types of algorithms to be displayed in the user interface.
- Returns: A JSON structure with the above if the algorithm exists, an error code if it does not.
All the datastore API calls below will return an error code if the item being requested does not exist.
These are mostly GET calls. The few calls that are POST calls are noted as such.
The API calls in the section are detailed for medical imaging, using the DICOM concepts of studies containing series which contain individual images. However, the API has been structured to allow for the later inclusion of additional patient data types.
-
/v1/datastore/patients
- Description: Returns the list of patients.
- Returns: An array of JSON objects.
-
/v1/datastore/patients/:patient
- Description: Returns the types of information available for a given patient.
- Returns: A JSON object where each key is a type of data.
-
/v1/datastore/patients/:patient/imaging/studies
- Description: Returns the list of studies for the patient.
- Returns: An array of JSON objects, each describing an imaging study.
-
/v1/datastore/patients/:patient/imaging/studies/:study/types
- Description: Returns the types of data included for a given study.
- Returns: An array of strings containing just "series" in the initial release.
-
/v1/datastore/patients/:patient/imaging/studies/:study/series
- Description: Returns the list of series (as URI paths) for the patient / study.
- Returns: An array of JSON objects, each describing an imaging series, both primary and algorithm results.
-
/v1/datastore/patients/:patient/imaging/studies/:study/primary
- Description: Returns the list of primary (acquired by device rather than algorithm-generated) for a given patient / study.
- Returns: Same as for .../series above, but only the primary series.
-
/v1/datastore/series/:series-path/instances
- Description: Returns the list of images (as URI paths) for the given series.
- Returns: A JSON structure containing both the list of file names and the list of URI paths.
-
/v1/datastore/patients/:patient/results/:pipeline/steps/:execID/imaging/studies/:study/series
- Description: Returns the URI path for uploading an algorithm-generated series.
- Returns: A JSON object containing the path string.
-
/v1/datastore/series/:series-path/:format
- Description: Downloads a series.
- Returns: A tar archive containing the series or an error code.
-
/v1/datastore/series/:series-path/:format (POST)
- Description: Upload a series.
- Returns: A JSON structure containing the path to which the series was loaded, or an error code.
-
/v1/datastore/annotation/:series-path/types
- Description: Get the types of annotations for a series.
- Returns: A JSON structure describing the type of annotation (e.g. "DICOM"), or an error code.
-
/v1/datastore/annotation/:series-path/:format
- Description: Download the annotation for a series.
- Returns: In the first release, an example, hard-coded set of annotations are returned for testing.
For these calls, the primary object is the slide. For the case of tissue microarray (TMA) experiments, there can be tissue from many patients on the same slide.
-
/v1/datastore/pathology/slides
- Description: Get the list of microscope slides.
- Returns: An array of slide names.
-
/v1/datastore/pathology/slides/:slide/types
- Description: Get the types of data included in a slide.
- Returns: An array of strings including just "regions" in the initial release.
-
/v1/datastore/pathology/slides/:slide/regions
- Description: Get the list of regions for a slide.
- Returns: An array of region names.
-
/v1/datastore/pathology/slides/:slide/regions/:region/types
- Description: Get the types of data included in a region.
- Returns: An array of strings which will include "channels" and optionally "results".
-
/v1/datastore/pathology/slides/:slide/regions/:region/channels
- Description: Get the list of channels for a given slide and a given region.
- Returns: An array of channel names.
-
/v1/datastore/pathology/slides/:slide/regions/:region/channels/:channel/types
- Description: Get the types of data for a given slide, region, and channel.
- Returns: An array of strings for the data types for the slide, region, and channel, e.g. "tiff16".
-
/v1/datastore/pathology/slides/:slide/regions/:region/channels/:channel/image
- Description: Get the image path for a given slide, region, and channel.
- Returns: An array of URI path strings. For most situations there should just be one path in the array.
-
/v1/datastore/pathology/slides/:slide/regions/:region/results
- Description: Get the list of "pipelineid" executions for a given slide and region.
- Returns: An array of named "execution IDs" or result sets.
-
/v1/datastore/pathology/slides/:slide/regions/:region/results/:pipeline/types
- Description: Get the types of results for a given "pipelineid" execution for a given slide and region.
- Returns: An array of types of things contained in execution pipelines. Returns just "steps" in the initial release.
-
/v1/datastore/pathology/slides/:slide/regions/:region/results/:pipeline/steps
- Description: Get the list of "execid" steps for a given "pipelineid" execution for a given slide and region.
- Returns: An array of named "execIDs" or named steps in the execution pipeline.
-
/v1/datastore/pathology/slides/:slide/regions/:region/results/:pipeline/steps/:execid
- Description: Get the format of the results for a given "pipelineid" execution and "execid" step for a given slide and region.
- Returns: An array of type strings, which may often have just one element, e.g. "tiff16".
-
/v1/datastore/pathology/slides/:slide/regions/:region/results/:pipeline/steps/:execid/data
- Description: Get the URI path of the result for a given "pipelineid" execution and "execid" step for a given slide and region.
- Returns: The URI path string.
Instances can be radiology images, pathology images, data files, or any other type of file.
-
/v1/datastore/instance/:instance-path/type
- Description: Get the type of an instance, e.g. "tiff", "DICOM", "csv", etc.
- Returns: JSON object containing the type string.
-
/v1/datastore/instance/:instance-path/:format
- Description: Download an instance.
- Returns: The file itself or an error code.
-
/v1/datastore/instance/:instance-path/:format (POST)
- Description: Upload an instance. If the instance already exists in the data store (even an earlier version), an error is returned.
- Returns: A JSON object including the path where the instance was uploaded, or an error code.
-
/v1/datastore/instance/:instance-path/:format/force (POST)
- Description: Upload an instance. If the instance already exists in the datastore, it is overwritten without an error.
- Returns: A JSON object including the path where the instance was uploaded, or an error code.
- /v1/health/bad (GET)
- Description: Return the list of Rt 106 components that have failed their run-time health checks.
- Returns: An array of Rt 106 component names.
- /v1/dataconvert/csvtojson/v1/pathology/datafile/:slide/:region/:branch/:channel (GET)
- Description: This is a specialized call used by some custom applications to convert CSV files to a JSON structure.
- Returns: Converted JSON data or an error code.
This services can be used within a custom application within its AngularJS controller.
The purpose of this service is to manage alarms and the internal state of Rt 106.
Display an alarm in a pop-up window.
alarmService.displayAlert( message );
Param | Type | Details |
---|---|---|
message | string | alert message to display |
Query Rt 106 for any of its components that have failed its runtime health checks. Display an alert the first time a component is reported as bad.
alarmService.scanForHealth()
(none)
The purpose of this service to support dynamically-generated result displays for an algorithm execution, based on the JSON metadata defined for that algorithm. The goal is to enable custom result displays in the user interface without the need to hard code those custom displays.
The capabilities here are just a limited start for the first Rt 106 release. The paradigm is that the result display will include up to four images arranged in a row or column (for two images) or a square (for four image).
Display the specified image (pathology image or DICOM series) in the appropriate image viewer with a given color & opacity value.
dynamicDisplayService.displayInCell( format, path, displayStructure, column, row, shape, color, opacity, imageProcessing, detections )
Param | Type | Details |
---|---|---|
format | string | "http:" or "tiff16:" |
path | string | path where image is stored in the datastore |
displayStructure | JSON | metadata about how to display the image |
column | integer (0 or 1) | which column to use (see dynamicDisplayService.setDisplayShape) |
row | integer (0 or 1) | which row to use (see dynamicDisplayService.setDisplayShape) |
shape | string | (see dynamicDisplayService.setDisplayShape) |
color | string | e.g. 'rgb(255,255,255)' |
opacity | number 0 to 1 | opacity value |
imageProcessing | string | If "toBinaryImage" the image will be binarized. More image processing operations can be added later. |
detections | list of detection points | detections will be displayed on the rendered image |
Set the result image display to be a single image, a row, a column, or a square.
dynamicDisplayService.setDisplayShape( shape )
Param | Type | Details |
---|---|---|
shape | string | '1,1' for single image |
'1,2' for two images in a row | ||
'2,1' for two images in a column | ||
'2,2' for four images in a square |
Display the image results from an algorithm execution.
dynamicDisplayService.displayResult( executionItem, displayStructure, detections )
Param | Type | Details |
---|---|---|
executionItem | JSON | metadata about the algorithm execution |
displayStructure | JSON | metadata about how to display the image |
detections | list of detection points | detections will be displayed on the rendered image |
The purpose of this service is to manage algorithm executions and to maintain the execution list of past executions.
Poll rt106-server's execution data to load rt106-app's execution list.
executionService.pollExecList( execList, ngScope )
Param | Type | Details |
---|---|---|
execList | JSON | the app's current execution list, into which the new results will be merged |
ngScope | internal AngularJS structure | internal AngularJS structure, just used here to update the scrollbar in the user interface component that displays the execution list. |
Initialize the executionService. Establish the connection between rt106-app and rt106-server, and tell rt106-server to initialize its execution list from past executions stored in the Rt 106 database.
executionService.initExecution()
(none)
Automatically fill in certain input parameter values from user interface elements, specifically for radiology applications.
- If there is a parameter of type "series" it will be filled in with the path to the currently selected DICOM series.
- If there is a parameter of type "voxelIndex" it will be filled in with the coordinates of a currently-selected probe point.
executionService.autofillRadiologyParameters( selectedParameters, selectedSeries )
Param | Type | Details |
---|---|---|
selectedParameters | JSON | metadata describing the algorithm's required parameters and their values from the user interface |
selectedSeries | string | path to currently-selected series |
Automatically fill in certain input parameter values from user interface elements, specifically for pathology applications.
- If there is a parameter named "slide" it will be filled in with the value of the slide variable.
- If there is a parameter named "region" it will be filled in with the value of the region variable.
- If there is a parameter named "channel" it will be filled in with the value of the channel variable.
- If there is a parameter named "branch" it will be filled in with the value of the selectedPipeline variable.
- If there is a parameter named "force" it will be filled in with the value of forceOverwrite.
executionService.autofillPathologyParameters( selectedParameters, selectedSlide, selectedRegion, selectedChannel, selectedPipeline, forceOverwrite )
Param | Type | Details |
---|---|---|
selectedParameters | JSON | metadata describing the algorithm's required parameters and their values from the user interface |
selectedSlide | string | currently-selected slide |
selectedRegion | string | currently-selected region |
selectedChannel | string | currently-selected channel |
selectedPipeline | string | currently-selected pipeline |
forceOverwrite | boolean | whether existing results should be overwritten |
Request an algorithm to run.
executionService.requestAlgoRun( selectedParameters, selectedAlgo )
Param | Type | Details |
---|---|---|
selectedParameters | JSON | metadata describing the algorithm's required parameters and their values from the user interface |
selectedAlgo | JSON | metadata describing the algorithm |
Get the list of slides.
pathologyService.getSlideList()
(none)
Get the list of regions for a slide.
pathologyService.getRegionList( slide )
Param | Type | Details |
---|---|---|
slide | string | name of a slide |
Get the list of channels for a region on a slide.
pathologyService.getChannelList( slide, region )
Param | Type | Details |
---|---|---|
slide | string | name of a slide |
region | string | name of region on the slide |
Get the path for querying a pathology image.
pathologyService.getPrimaryImagePath( slide, region, channel )
Param | Type | Details |
---|---|---|
slide | string | name of a slide |
region | string | name of region on the slide |
channel | string | name of a channel on a region on the slide |
Return a JSON structure describing all available algorithms including their classifications, inputs, parameters, expected results, and how result images should be displayed.
A JavaScript promise is returned.
analyticsFactory.getAnalytics().then(function(analytics) {
// save or manipulate the analytics variable
});
(none)
Get the list of patients.
A JavaScript promise is returned.
cohortFactory.getPatients().then(function(patients) {
// save or manipulate list of patients
})
.catch(function(reason){
// handle error
});
(none)
Get the list of studies for a patient.
A JavaScript promise is returned.
cohortFactory.getStudies(patient).then(function(studies) {
// save or manipulate list of studies
})
.catch(function(reason){
// handle error
});
Param | Type | Details |
---|---|---|
patient | string | name of a patient |
Get the list of series for a patient and study.
A JavaScript promise is returned.
cohortFactory.getSeries(patient, study).then(function(series) {
// save or manipulate list of series
})
.catch(function(reason){
// handle error
});
Param | Type | Details |
---|---|---|
patient | string | name of a patient |
study | string | name of a study for the patient |