NCPI FHIR Implementation Guide
0.2.0 - ci-build

NCPI FHIR Implementation Guide - Local Development build (v0.2.0) built by the FHIR (HL7® FHIR® Standard) Build Tools. See the Directory of published versions

Use Case Tabular Data

Representing Tabular Data in FHIR

There are a number of reasons to support representing tabular data in FHIR whether or not it is expected that the data will be fully transformed to meet the appropriate FHIR representation for interoperable data. These include:

  • Provide FHIR access for data where there isn’t funding to properly transform it to meet the interoperable model.
  • Provide access to all data even if there are items that currently don’t fit any of the current FHIR models in use.
  • Provide data provenance for all of the transformed data using the same API, FHIR as opposed to requiring researchers to step outside FHIR and attempt to trace the origins back to those original data sources.

Tabular Data as Observations (with components)

Tabular Data as Observations FHIR Observations are rich resource structures that provide a direct link to a subject, which can be a Patient or a group of Patients) and an optional focus which can point to any other resource. There is also the possibility to link the observation to an encounter. Each observation can have 0 or more component entries.

Component Composition

Components can contain only a small number of properties of which we’ll use only a few.

  • Code - The code associated with each component MUST be the corresponding code associated with that column from the table’s data-dictionary CodeSystem. This is how consumers will be able to identify what each component represents.
  • value[x] - The data-dictionary for each table should describe the type of each of the columns. This can be exploited to provide baseline casting when storing the column’s contents into FHIR. As such, a column noted as being an integer, will be represented as a valueInteger, while a column with a list of possible values will be a valueCodeableConcept. It should be noted that, while “decimal” values will be represented as valueQuantity, those will only have a unit if the data-dictionary is defined to provide this (currently not supported by NCPI Whistler, but can be added in the future). For quantities whose unit is expressed in a separate column, those should not be expected to ever get linked together except by an end user.
Subject

In general, each row will always refer to a single subject. This is true even for rows that describe something like a sample which may have been extracted from a subject–ultimately, one can trace that sample back to the original source, which would be the subject. The Observation’s subject property is a reference, which we’ll assume will point to the appropriate Patient resource.

Having a subject present for these resources makes it possible for FHIR users to collect all of the raw data for a given patient.

When attempting to automate the construction of these resources, it is possible that the actual subject’s ID will not be present in the table. For instance, we have received files where the patient’s ID was able to extracted from the sample ID, so only the sample ID was provided. For these scenarios, NCPI whistler is not able to link those rows back to the patient.

Advantages of Observations with Components

There are a number of advantages of using Observations with components to represent raw data:

  • Keeping the entire row together makes it much easier for the consumer to establish relationships between any given column and those on the same row. If the columns of a table were considered to be semantically related by those providing the data to be loaded, then their relationship is not lost during, at least, not at the raw level.
  • Components are searchable by default in the current version of FHIR.
  • Data representation is flexible due to the value[x]. The type can be defined by the type in the data dictionary as well as typing on the fly (such as assigning a code for NaN in place of a numeric when the value is “NA”, or possibly capturing numeric fields as strings when they have characters like “<” in them.)
  • Easy to automate given an accurate and complete data-dictionary that matches the expectations of the author of the tools used to generate the resources.
Future Considerations

Beyond linking back to the subject, it is possible that we might want to link back to slightly more specific resources as well.

It should be noted that NCPI Whistler does not support either of these and there may not be plans to support them in the future.

Specimen, VCF, etc

For data like a file that contains data related specifically to a sample or is the result of processing done on a VCF, it is reasonable to suggest one could link a given row back to the original source. For samples, this would mean that, in addition to having a valid subject, the focus could point back to the appropriate Specimen resource. Out from a process run, may have a focus that points either to the DocumentReference or possible the Task related to the data’s origins.

In the case of many task related output, there may not really be a single Patient. In these cases, subject may point to a group of Patients or just be missing altogether.

Encounters

For some data tables, it is easy to imagine they are describing the outcome of a single encounter which will be realized by during a transformation. It seems reasonable that such a relationship could be captured for these resources.

Raw Data as Questionnaires and QuestionnaireResponses

Tabular Data as Questionnaires FHIR R4 natively provides 2 resources to support survey instruments in FHIR along with their responses: Questionnaire and QuestionnaireResponse. These are rich resources intended to support the types of surveys that may be used during routine medical care. As a result, these fit nicely alongside our objectives for capturing raw research data.

There are two components to this model:

Questionnaire

Each questionnaire will represent the “blue print” associated with a single dataset table where each of the table’s columns are represented as individual items. Each of these items has a single type property which defines the actual type of data that is expected from the matching responses. A string property, linkId, is used to differentiate each column in a given Questionnaire from the others. For items of type, choice, an additional property, answerValueSet, is used to define a list of codes which can be assigned in the responses.

For the code, we can link back to the data-dictionary’s entry for the table in the dataset CodeSystem.

Each Questionnaire must have a unique URL.

QuestionnaireResponse

Each response represents a single row from the table their corresponding Questionnaire represents. The response refers back to the questionnaire by way of providing the property, questionnaire, the value from the corresponding Questionnaire’s url property.

Each item must have a linkId that matches one of the linkIds from the Questionnaire and their valueX must correspond to the type specified by the item’s type definition. This will fail during FHIR validation if the data type is not what the Questionnaire specified it should be.