-
Notifications
You must be signed in to change notification settings - Fork 25
OpenIGTLink US messaging proposal
Christian Askeland edited this page Dec 10, 2015
·
22 revisions
This page is part of http://wiki.na-mic.org/Wiki/index.php/2016_Winter_Project_Week:TrackedUltrasoundStandardization.
The status can be organized as a xml document, and can thus be embedded into any text field in any message. XML also provides an easy system for optional and extension parameters. Each DOM-element can contain a reserved extension element. Here custom properties can be added without interfering with the required/optional properties.
The following are properties for a server residing on an ultrasound scanner. The structure is given in pseudocode, but the intended format is XML.
Parameters are either required, optional or extension:
- required: Defined by standard. Must be present in order to comply with standard.
- optional: Defined by standard. Might be present, if available from scanner and implemented.
- extension: not part of the standard, but added by vendor.
- Available_applications { list of names } (list of applications/presets available on the scanner)
- Application_name { name }
- Available_Probes { device_id list } ( List of all probes currently attached to the scanner.)
-
Available_Streams { device_id list } (these are an exhaustive list of all stream types that can be of interest from a scanner. Only those supported by the scanner are given. The scalar variants contain raw data, while the RGB/Gray versions are suitable for direct screen display. LUTs can be available when using the raw variants.)
- Display, (RGB)
- US_B-Mode (Gray)
- US_B-Mode-Raw (Scalar)
- US_Color-Doppler (RGB)
- US_Color-Doppler-Velocity (Scalar)
- US_Power-Doppler (RGB)
- US_Elastography (RGB)
- US_Elastography (Scalar)
- US_R0 (Scalar)
- US_R1 (Scalar)
- US_RF (Scalar)
- US_IQ (Complex)
-
Probe: {device_id_0} (one probe entry for each probe)
- probe parameters: Name, Center freq, focus pt, pitch, geometry model..?,
-
Stream: {device_id} (one stream entry for each stream)
- Image Format: {RGB, Gray, Complex, Scalar}. If Scalar, a color table might be available (in a separate field)
-
Probe sector: (A description handling 2D/3D sector/curvilinear/linear probes. Handles most cases, mask handles the rest. TODO: add figure. )
- origin {x,y} (position of sector arc center in image space)
- depth start (start offset from origin)
- depth stop (end offset from origin)
- azimuth (shape in the azimuth plane)
- type{linear, sector}
- width{angle/width}
- tilt {angle, optional}
- elevation (shape in the elevation plane, optional, NA for 2D probes)
- width{angle/width}
- type{linear, sector}
- tilt {angle, optional}
- exact: bool. If false, must use Mask stream to get exact geometry
- mask {device_id, optional}: a device_id that can be used to GET an IMAGE containing a mask describing the sector.
- Color table {device_id, optional} If given, points to a device_id that can be used to GET a COLORT, can be applied on scalar image values.
- optional parameters (name-value pairs, specified by description and value def (unit etc) examples given)
- frequency
- harmonic {y/n}
- focus points {array}
- pitch
- nyquist velocity
- packet size
- averaging window
- extension parameters (same as optional, but user-defined, nonstandard)