Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
minLevel1
maxLevel6
outlinefalse
typelist
printablefalse

Overview

...

The seca analytics 125

...

Seca Analytics 125 is a cloud-based software used for storing body composition details of subjects.

Device Interface

Description on how device is interfaced through ClinSpark. This should be examples of screens to invoke, functional screen descriptions, etc. This should also include any Study/Subject Requirements needed to properly use the device within ClinSpark.

Installation

Directions on installing the device software. Include any System Requirements for hardware (firmware, memory, etc), Agent Version, SparkPlug, mobile firmware versions, etc.

Configuration Options

List all configuration options and Device Parameters within ClinSpark.

...

Inputs

Describe how the interface (Agent, Mobile, SparkPlug, etc) interacts with device output to convert to ClinSpark inputs ie JSON → Object IDs and data, etc. Include the file types and any other pertinent info to the process ie directories, etc.

Describe any User Inputs needed for process to be invoked ie Study, Form, Subject Setup, etc.

Outputs

Describe the output to ClinSpark once the device captures data. This should include output file types ie. JSON converted to XML/PDF, etc.

Describe the interface process to grab the output files. This should include directories in which files are saved, etc.

Describe how the Clinspark application/client uses the output files and populates data/forms/etc.

Architecture Diagram

Create an architecture diagram. See example of below.

...

Workflow

Create a workflow to summarize the info and process. See example workflow below:

  1. The ClinSpark Agent receives messages from the ClinSpark Client (in JSON structure, sent after "Invoke Device" has been clicked) containing relevant information for the ECG order.

  2. The Agent generates an XML file ("input XML") with this information, and locates input and output directories in Device.

  3. The Agent then locates Device EXE, and sends the input XML to the Device input directory. Then the Device executable is run.

  4. Device begins running simultaneously as the Agent clears any and all files in the input directory (to ensure only one order can ever be processed at a time).

  5. Device runs and functions based on user input. Device, upon completion (and termination), stores output PDF and XML files in its output directory.

  6. The Agent pulls in the most recently time stamped XML and PDF files, and clears out any additional files in this output directory (this is done to minimize the possibility of the Agent picking up the wrong output file, and causing error in the whole of the system when future ECG tests are run). 

  7. The Agent then parses the XML data into JSON, and sends all relevant information back to the ClinSpark app for ECG form population (including the PDF file).

  8. The Agent then saves the XML and PDF files to Device's "Processed" folder, or the configured Archive Directory (ArchiveDir). This Archive Directory can include a local drive, or a shared network drive.

Data

Describe the data types and names included in output data files received by ClinSpark. The should include examples and locations of the data types within the output files. See example of Device below.

Data included in the output XML file, and received by ClinSpark

  • PR (ms)

  • QRS (ms)

  • QT (ms)

  • QTc (ms)

  • QTcF (ms)

  • QTcB (ms)

  • RATE (BPM)

  • RR (ms)

  • P_Axis (degrees)

  • QRS_Axis (degrees)

  • T_Axis (degrees)

  • EGTXT (this is an auto-interpretation of ECG results by Device)

  • EGDTC (DDMMMYYYY HH:MM:SS)

  • EGPDF (PDF Document).

Where in the XML is this Data?

Found in the <ECG> section at the top of the XML Doc

  • RATE (labeled "VENT_RATE")

  • RR (labeled "AVERAGE_RR")

  • EGDTC (labeled "ACQUISITION_TIME_XML")

...

Found in the "Typical Cycle" section of the XML Doc

  • PR (labeled "PR_DURATION")

  • QRS (labeled "QRS_DURATION)

  • QT (labeled "QT"), QTc (labeled "QTC")

  • QTcF (labeled "QTCF"), QTcB (labeled "QTCB")

  • P_Axis (labeled "P_AXIS")

  • QRS_Axis (labeled "QRS_AXIS")

  • T_Axis (labeled "T_AXIS")

...

EGTXT

Contents are found in the <Automatic_Interpretation.../> section, and the <Interpretation.../> section of the XML Doc.

...

EGPDF

Located at the very bottom of the XML Doc, in the section <Associated_REPORT_DOCUMENT.../>. This points to the directory in which the PDF is saved.

...

The ClinSpark Agent is responsible for sending both the XML and the PDF to the ClinSpark Application.

Reports/Dashboards

List all reports and dashboards that can be used “off the shelf” with this device.

Supported Devices / Models / Hardware

List all device / models supported by this integration and any other additional hardware requirements.

Notes

Include any relevant notes that you may reference above. platform is an advanced software solution designed by seca, a leading provider of medical measuring systems and scales, to enhance the evaluation and management of patient data. This platform integrates seamlessly with seca's range of measurement devices, allowing healthcare professionals to collect, analyze, and interpret vital health statistics with precision. It offers comprehensive tools for the assessment of body composition, nutritional status, and overall health, thereby facilitating informed clinical decisions. Seca analytics 125 supports various functionalities, including trend analysis, graphical data representation, and customizable reporting, ultimately aiming to improve patient outcomes through detailed and accurate health insights.

The seca analytics 125 platform is interfaced with ClinSpark via SparkPlug. The interface is delivered transparently through the ClinSpark core application with all device interactions taking place via a ClinSpark forms. The device follows an Initiate Collection > Collect on Device > Upload Results workflow with a single ClinSpark form facilitating all of the required steps.

seca analytics 125 is a device integration utilizing SparkPlug 24.2. SparkPlug 24.2 is currently not available for early-phase implementations but is in development to be released to all customers in the near future.

Installation

SparkPlug 24.2 (or later) and ClinSpark 24.2 (or later) is required for the seca analytics 125 device integration. All of the required software to interface with the seca mBCA 554 device is included in the SparkPlug installation and no additional installation or software is required.

The device profile must be provisioned into the target ClinSpark environment. Both the seca analytics 125 platform and SparkPlug must be configured correctly (detail below) to enable the two systems to connect and exchange data. Additionally, the asynchronous job to populate received data as study form data must be added to Administration > Support > Async Job Management in the target environment. Lastly, the seca device should be configured to allow manual entry of Waist Circumference due to current limitations of the provided seca API.

Configuration

As noted above, SparkPlug must be fully configured with the required elements to enable interconnectivity via the seca API. Overall SparkPlug administration and configuration is outside of the scope of this document, but those configuration elements specific to the seca analytics 125 platform are detailed below:

API URL

The API URL to a valid seca analytics 125 endpoint must be configured in SparkPlug > Administration > Settings > seca > API URL. This URL is established & provided by seca.

...

Tenant Secrets

For each ClinSpark site that utilizes the seca analytics 125 integration, a valid Tenant ID must be established on the seca analytics 125 platform. A given ClinSpark Site ID can be determined by opening the site details in Administration > Sites and observing the Id displayed at the end of the URL.

...

In addition to seca establishing the Tenant, a public and private key pair are generated and provided. Both this seca Tenant name and the public and private key pair must be configured in SparkPlug > Interfaces > seca. When configuring the Tenant in SparkPlug, the tenant name entered must match the Tenant configured in seca.

...

Additionally, the Org URL for the site as configured in ClinSpark must be established in SparkPlug.

...

Collection Workflow & Forms

...

Collection of seca analytics 125 body composition data using the seca mBCA 554 follows a device enrollment / initialization > On-Device Collection > Data Returned to ClinSpark via SparkPlug workflow. Additionally, to facilitate downstream workflows in ClinSpark, returned data is synchronized from Volunteer Monitoring Data to Study Forms via an asynchronous job. The workflow is detailed below:

  1. The device is successfully enrolled and data collection is initiated in ClinSpark by invoking the seca analytics 125 platform via a ClinSpark form containing the minimum required parameters (see https://foundryhealth.atlassian.net/wiki/spaces/DOCS/pages/edit-v2/4646437132#Form-Design) and having the prerequisite subject demographics included as part of the request.

  2. The study participant is welcomed on the screen of the scale and steps on to perform the collection.

  3. Waist circumference and height (when stadiometer is not connected) values are manually entered on the device during collection.

  4. Data is returned to ClinSpark as Volunteer Monitoring Data.

  5. Data populated as Volunteer Monitoring Data is asynchronously returned to the study form as Study Form Data.

Device Enrollment / Initialization

Demographics / Study Metadata

Prior to invocation, the seca analytics 125 platform requires a set of input demographics and study metadata be established to support the generation, processing and analysis of seca data as well as customization of the welcome message presented to the study participant. The required demographics that must be established prior to invocation are DOB, Race, Sex, Ethnicity (optional, see https://foundryhealth.atlassian.net/wiki/spaces/DOCS/pages/edit-v2/4646437132#Race-Mapping below).

Info

This integration supports partial DOB enrollment configurations introduced in ClinSpark 24.1. See https://foundryhealth.atlassian.net/wiki/spaces/DOCS/pages/4335697921/ClinSpark+24.1#Updated-Enrollment-Configurations-for-Subject-DOB for details.

Race Mapping

Due to limitations of race / ethnicity functionality within the seca analytics 125 platform, it was necessary to establish a hardcoded race mapping between the ClinSpark ‘Race Name’ and the seca provided ‘Ethnicity’ value. The mapping rules are presented below as a table.

ClinSpark Race

ClinSpark Ethnicity

Race Value Sent to seca

ANY

Hispanic or Latino

Hispanic

Hispanic

Not Hispanic or Latino

Hispanic

Native Hawaiian or Other Pacific Islander

Not Hispanic or Latino

Other

American Indian or Alaska Native

Not Hispanic or Latino

Other

Asian

Not Hispanic or Latino

Asian

North-East Asian

Not Hispanic or Latino

Asian

South East Asian

Not Hispanic or Latino

Asian

Black or African American

Not Hispanic or Latino

AfroAmerican

White

Not Hispanic or Latino

Caucasian

Other

Not Hispanic or Latino

Other

Unknown

Not Hispanic or Latino

Other

Device Invocation

Device enrollment & initialization is initiated via ClinSpark form by clicking on the seca analytics 125 button on an integration-enabled form. Once the button is clicked, the user is prompted to confirm their intent to begin enrollment / collection.

...

Device Selection

In the event that there is only a single seca device configured for the current ClinSpark site, the device will be readied for collection and values will be returned to the TENANT_ID, DEVICE_ID, and REQUEST_ID form items. In the event that the seca tenant has more than one device associated, SparkPlug will prompt the user to select the device on which the collection should be performed.

image-20241105-011258.pngImage Added

Errors During Enrollment / Initialization

For errors encountered during device enrollment / initialization, see https://foundryhealth.atlassian.net/wiki/spaces/DOCS/pages/edit-v2/4646437132#Errors-%2F-Troubleshooting.

Collection on Device

Once the device has been successfully enrolled / initialized, the device will be readied for collection, and the study participant will be welcomed on the device screen.

image-20241105-005251.pngImage Added

After the Study Participant stands on the device and collection begins, manually entry of waist circumference (and optionally height when the stadiometer is not connected) becomes possible.

image-20241105-005653.pngImage Added

After device collection and manual entry are completed on the device, the collection is complete and results will be returned to ClinSpark (see https://foundryhealth.atlassian.net/wiki/spaces/DOCS/pages/edit-v2/4646437132#Data for details)

Form Design

As detailed in the description of collection workflows, the seca analytics 125 uses a single collection form to facilitate data collection. The form incorporates both clinical and ancillary device parameters that receive result data and enable further workflows.

At a minimum, a seca analytics 125 collection form must include MEASUREMENT_ID and MEASUREMENT_DATETIME. If these parameters are not included on the form, invoking the integration will fail.

Note

All device configuration is performed directly on the seca device and cannot be driven by form design.

Device Profile / Parameters

The seca analytics 125 Device Profile implements both clinical result parameters and supporting parameters that capture device / measurement metadata. As noted in Form Design, the device integration does not allow for any configuration parameters to control device behavior - all device configuration is done directly on the device itself. For all Clinical Parameters, both a Value as well as Unit parameters are provided as the units used by the device are not controlled by the integration (but instead by the device itself).

Clinical Parameters

Parameter Name

Description

BMI_VALUE

Body mass index measurement value expressed as number.

BMI_UNIT

Body mass index measurement unit expressed as abbreviation.

WEIGHT_VALUE

Weight measurement value expressed as number.

WEIGHT_UNIT

Weight measurement unit expressed as abbreviation.

HEIGHT_VALUE

Height measurement value expressed as number.

HEIGHT_UNIT

Height measurement unit expressed as abbreviation.

WC_VALUE

Waist circumference measurement value expressed as number.

WC_UNIT

Waist circumference measurement unit expressed as abbreviation.

TBW_VALUE

Total body water measurement value expressed as number.

TBW_UNIT

Total body water measurement unit expressed as abbreviation.

TBWP_VALUE

Total body water percentage measurement value expressed as number.

TBWP_UNIT

Total body water percentage measurement unit expressed as abbreviation.

ECW_VALUE

Extracellular water measurement value expressed as number.

ECW_UNIT

Extracellular water measurement unit expressed as abbreviation.

ECWP_VALUE

Extracellular water percentage measurement value expressed as number.

ECWP_UNIT

Extracellular water percentage measurement unit expressed as abbreviation.

ECWBYTBW_VALUE

Water ratio (ECW/TBW) measurement value expressed as number.

ECWBYTBW_UNIT

Water ratio (ECW/TBW) measurement unit expressed as abbreviation.

FM_VALUE

Fat mass measurement value expressed as number.

FM_UNIT

Fat mass measurement unit expressed as abbreviation.

FMP_VALUE

Fat mass percentage measurement value expressed as number.

FMP_UNIT

Fat mass percentage measurement unit expressed as abbreviation.

FMI_VALUE

Fat mass index measurement value expressed as number.

FMI_UNIT

Fat mass index measurement unit expressed as abbreviation.

ZFMI_VALUE

Z-score fat mass index measurement value expressed as number.

ZFMI_UNIT

Z-score fat mass index measurement unit expressed as abbreviation.

SMM_VALUE

Skeletal muscle mass measurement value expressed as number.

SMM_UNIT

Skeletal muscle mass measurement unit expressed as abbreviation.

SMMP_VALUE

Skeletal muscle mass percentage measurement value expressed as number.

SMMP_UNIT

Skeletal muscle mass percentage measurement unit expressed as abbreviation.

SMMOVERAGE_VALUE

Skeletal muscle mass over age measurement value expressed as number.

SMMOVERAGE_UNIT

Skeletal muscle mass over age measurement unit expressed as abbreviation.

SMMOVERAGE_PERCENTILE

Skeletal muscle mass over age measurement value in comparison to population for age expressed as number.

SMMOVERAGEBMIINDEPENDENT_VALUE

Skeletal muscle mass over age (BMI independent) measurement value expressed as number.

SMMOVERAGEBMIINDEPENDENT_UNIT

Skeletal muscle mass over age (BMI independent) measurement unit expressed as abbreviation.

SMMOVERAGEBMIINDEPENDENT_PERCENTILE

Skeletal muscle mass over age (BMI independent) measurement value in comparison to population for age expressed as number.

ZSMI_VALUE

Z-score skeletal muscle index measurement value expressed as number.

ZSMI_UNIT

Z-score skeletal muscle index measurement unit expressed as abbreviation.

SSMMRIGHTARM_VALUE

Segmental skeletal muscle mass (right arm) measurement value expressed as number.

SSMMRIGHTARM_UNIT

Segmental skeletal muscle mass (right arm) measurement unit expressed as abbreviation.

SSMMLEFTARM_VALUE

Segmental skeletal muscle mass (left arm) measurement value expressed as number.

SSMMLEFTARM_UNIT

Segmental skeletal muscle mass (left arm) measurement unit expressed as abbreviation.

SSMMRIGHTLEG_VALUE

Segmental skeletal muscle mass (right leg) measurement value expressed as number.

SSMMRIGHTLEG_UNIT

Segmental skeletal muscle mass (right leg) measurement unit expressed as abbreviation.

SSMMLEFTLEG_VALUE

Segmental skeletal muscle mass (left leg) measurement value expressed as number.

SSMMLEFTLEG_UNIT

Segmental skeletal muscle mass (left leg) measurement unit expressed as abbreviation.

SSMMTORSO_VALUE

Segmental skeletal muscle mass (torso) measurement value expressed as number.

SSMMTORSO_UNIT

Segmental skeletal muscle mass (torso) measurement unit expressed as abbreviation.

SSMMRIGHTARMBMIINDEPENDENT_VALUE

Segmental skeletal muscle mass (right arm, BMI independent) measurement value expressed as number.

SSMMRIGHTARMBMIINDEPENDENT_UNIT

Segmental skeletal muscle mass (right arm, BMI independent) measurement unit expressed as abbreviation.

SSMMLEFTARMBMIINDEPENDENT_VALUE

Segmental skeletal muscle mass (left arm, BMI independent) measurement value expressed as number.

SSMMLEFTARMBMIINDEPENDENT_UNIT

Segmental skeletal muscle mass (left arm, BMI independent) measurement unit expressed as abbreviation.

SSMMRIGHTLEGBMIINDEPENDENT_VALUE

Segmental skeletal muscle mass (right leg, BMI independent) measurement value expressed as number.

SSMMRIGHTLEGBMIINDEPENDENT_UNIT

Segmental skeletal muscle mass (right leg, BMI independent) measurement unit expressed as abbreviation.

SSMMLEFTLEGBMIINDEPENDENT_VALUE

Segmental skeletal muscle mass (left leg, BMI independent) measurement value expressed as number.

SSMMLEFTLEGBMIINDEPENDENT_UNIT

Segmental skeletal muscle mass (left leg, BMI independent) measurement unit expressed as abbreviation.

SSMMTORSOBMIINDEPENDENT_VALUE

Segmental skeletal muscle mass (torso, BMI independent) measurement value expressed as number.

SSMMTORSOBMIINDEPENDENT_UNIT

Segmental skeletal muscle mass (torso, BMI independent) measurement unit expressed as abbreviation.

VAT_VALUE

Visceral adipose tissue measurement value expressed as number.

VAT_UNIT

Visceral adipose tissue measurement unit expressed as abbreviation.

PHA_VALUE

Phase angle measurement value expressed as number.

PHA_UNIT

Phase angle measurement unit expressed as abbreviation.

PHA_PERCENTILE

Phase angle measurement value in comparison to population for age expressed as number.

BIVA_ZRH_UNIT

Bioelectrical impedance vector analysis index for resistance (R) by height measurement unit expressed as abbreviation.

BIVA_ZRH_VALUE

Bioelectrical impedance vector analysis index for resistance (R) by height measurement value expressed as number.

BIVA_ZXCH_UNIT

Bioelectrical impedance vector analysis index for reactance (Xc) by height measurement unit expressed as abbreviation.

BIVA_ZXCH_VALUE

Bioelectrical impedance vector analysis index for reactance (Xc) by height measurement value expressed as number.

TBS_VALUE

TRU body score measurement value expressed as number.

TBS_UNIT

TRU body score measurement unit expressed as abbreviation.

TBS_FATSCORE_UNIT

TRU body score fat score measurement unit expressed as abbreviation.

TBS_FATSCORE_VALUE

TRU body score fat score measurement value expressed as number.

TBS_TOPPERCENT

TRU body score measurement value that belongs to top percent of people of person's age and BMI.

TBS_MUSCLESCORE_UNIT

TRU body score muscle score measurement unit expressed as abbreviation.

TBS_MUSCLESCORE_VALUE

TRU body score muscle score measurement value expressed as number.

XC_VALUE

Reactance measurement value expressed as number.

XC_UNIT

Reactance measurement unit expressed as abbreviation.

R_VALUE

Resistance measurement value expressed as number.

R_UNIT

Resistance measurement unit expressed as abbreviation.

Info

All Clinical Parameters that return a value also have an associated unit parameter to indicate which parameters were set on the device at the time of collection.

Other Device Parameters

Parameter Name

Description

TENANT_ID

Unique seca tenant (site) identifier.

DEVICE_ID

Unique device identifier.

REQUEST_ID

Unique start measurement request identifier.

RAW_JSON_DATA

Raw JSON Measurement data from seca. Do not include in form

MEASUREMENT_ID

Unique measurement identifier.

MEASUREMENT_DATETIME

Measurement acquisition date and time.

Note

RAW_JSON_DATA is included to support seca’s Reporting Widgets and are not intended for inclusion on ClinSpark forms.

Data

Volunteer Monitoring Data

Data collected on the device is return to ClinSpark as Volunteer Monitoring Data via SparkPlug. In addition to the parameterized results, raw JSON data is returned to enable seca Widget based reporting.

...

Note

If results are not received back from seca analytics 125 within the allowed 10 minute window, SparkPlug will block the return of result data to ClinSpark.

Study Form Data

After data is received from the seca analytics 125 platform as Volunteer Monitoring Data, an asynchronous job polling the database for new seca result data populates the data to the seca analytics 125 collection form’s Items as Study Form Data.

image-20241105-011851.pngImage Added

Reports / Dashboards

  • Transfer Data Report

  • Site Report

  • Bioimpedance Analysis Visualizations Dashboard (seca Widgets)

Errors / Troubleshooting

Demographics Errors

image-20241105-012601.pngImage Added

'Device Not Ready' Errors

...

seca Tenant Configuration Errors

tenant_config_error-20241105-012149.pngImage Added

Notes

Known Limitations

  • It is currently possible in ClinSpark to start a seca measurement on a form that already has a status of “Complete”, meaning measurement data has been populated via the async job. If a second measurement would be invoked from a “Complete” form, it's possible that the enrollment data (TENANT_ID, DEVICE_ID, & REQUEST_ID) would be inaccurate for the measurement data saved to the form. TENANT_ID would be the same because the data would be collected for the same site. And more than likely DEVICE_ID would match as well if the site only has a single device (as we expect in most cases). But certainly in this scenario, the REQUEST_ID would be wrong as it would reflect an identifier for requesting a measurement that has yet to be acquired.

    -------

    There is currently no solution to block this behavior. I even attempted setting the item group data and form data as locked. The best way to block this would be a ClinSpark code change to prevent invoking the device on the form once it’s "Complete". Can we please get this issue on the product backlog?

  • Currently, measurements that are “Weight Only” are not able to be sent / transferred through ClinSpark. These weight measurements would need to be manually captured on a scale independent of device invocation and entered onto the form manually.

  • The seca mBCA 554 device will timeout if a subject does not step on the platform within 5 minutes of measurement start. We set the threshold to 10 minutes to allow for a 5-minute grace period in the event a subject stands on the platform moments before timeout. Measurement acquisition should not take more than 5 minutes. This threshold is used to prevent processing records that are too old to be considered for data posting.

  • If a Volunteers Demographics are updated following a measurement all past measurements will retain the data as calculated prior to the change. As each invocation and measurement is sent to the seca analytics platform ClinSpark sends the volunteer details as a “snapshot in time” so retrospective data will not be updated within past forms collected via ClinSpark.

  • In scenarios where a scale is not reserved for a specific person / measurement prior to device invocation . In these cases it has been noted that Date of Birth may be requested following the collection workflow. Seca calls this the anonymous workflow “anonymous workflow” and confirmed that this can be caused by error conditions in pushing Demographics to the device. In these instances, the recommendation is to start the collection workflow again. If the condition is seen in numerous consecutive invocations, please review demographics and contact the help desk.

Example Files

...

  • .