{
  "resourceType": "StructureDefinition",
  "meta": {
    "lastUpdated": "2017-12-14T09:17:26.671+00:00"
  },
  "url": "http://pchalliance.org/phdfhir/StructureDefinition/PhdBaseObservation",
  "name": "PhdBaseObservation",
  "status": "draft",
  "date": "2017-11-24T20:17:35.385+00:00",
  "description": "Observation elements that are common to all the Continua PHD Observation profiles",
  "fhirVersion": "3.0.1",
  "kind": "resource",
  "abstract": false,
  "type": "Observation",
  "baseDefinition": "http://hl7.org/fhir/StructureDefinition/Observation",
  "derivation": "constraint",
  "differential": {
    "element": [
      {
        "id": "Observation",
        "path": "Observation",
        "comment": "This variant on the Observation defines a base profile for the PHD Observation profiles. This profile is abstract and does not exist alone."
      },
      {
        "id": "Observation.identifier",
        "path": "Observation.identifier",
        "comment": "For Phd Observations that require conditional creates the create selection criteria will be based upon the information placed in an identifier element. The information will uniquely represent the measurement content. How that information is generated is dependent upon the Phd Observation Profile."
      },
      {
        "id": "Observation.status",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/structuredefinition-display-hint",
            "valueString": "default: final"
          }
        ],
        "path": "Observation.status",
        "definition": "The status of the result value. Either 'final' or 'preliminary'",
        "comment": "The value shall be set to 'final' unless a Measurement-Status attribute or Nu-Observed-Value attribute status field indicates that the measurement is preliminary. In that case this field shall be set to 'preliminary'"
      },
      {
        "id": "Observation.code.coding",
        "path": "Observation.code.coding",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "system"
            }
          ],
          "ordered": true,
          "rules": "open"
        },
        "min": 1
      },
      {
        "id": "Observation.code.coding:11073Type",
        "path": "Observation.code.coding",
        "sliceName": "11073Type",
        "short": "The 11073-10101 code for the measurement",
        "comment": "For non-compound 11073-20601 metric numeric measurements, this code is obtained from one or more of the Type, Metric-Id, Nu-Observed-Value, and Metric-Id-Partition attributes. The algorithm to get the 16-bit partition and 16-bit term code is as follows:  1. The partition and term code are obtained from the Type attribute. 2. If there is a Metric-Id attribute the term code comes from this attribute. 3. If there is a Nu-Observed-Value attribute the term code comes from this attribute. 4. If the term code is NOT from the Type attribute, and there is a Metric-Id-Partition attribute, the partition comes from this attribute. 5. The 32-bit 11073-10101 code value is given by partition * 2 **16 + term code.  It is this value that is placed in the code.coding.code element for this 11073Type slice.\r\nFor compound numeric measurements, the code comes from the Type attribute.",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.code.coding:11073Type.system",
        "path": "Observation.code.coding.system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.code.coding:11073Type.code",
        "path": "Observation.code.coding.code",
        "min": 1
      },
      {
        "id": "Observation.code.coding:LoincCoding",
        "path": "Observation.code.coding",
        "sliceName": "LoincCoding",
        "comment": "If the measurement is one of the magic vital signs, the Magic LOINC code for that vital sign as specified by FHIR appears here. When it occurs It shall be second after the MDC code.",
        "max": "1"
      },
      {
        "id": "Observation.code.coding:LoincCoding.system",
        "path": "Observation.code.coding.system",
        "min": 1,
        "fixedUri": "http://loinc.org"
      },
      {
        "id": "Observation.code.coding:LoincCoding.code",
        "path": "Observation.code.coding.code",
        "comment": "Required if the measurement is a vital sign",
        "min": 1
      },
      {
        "id": "Observation.subject",
        "path": "Observation.subject",
        "min": 1
      },
      {
        "id": "Observation.subject.reference",
        "path": "Observation.subject.reference",
        "min": 1
      },
      {
        "id": "Observation.effective[x]",
        "path": "Observation.effective[x]",
        "slicing": {
          "discriminator": [
            {
              "type": "exists",
              "path": "start"
            }
          ],
          "rules": "open"
        },
        "definition": "The time or time-period the observed value is asserted as being true. It is a time period if a Measure-Active-Period (duration) attribute is part of the metric measurement sent by the PHD. Otherwise it is the time stamp sent by the PHD or the time of reception by the PHG if the PHD sent no time stamp.",
        "min": 1
      },
      {
        "id": "Observation.effective[x]:dateTimeEffective",
        "path": "Observation.effective[x]",
        "sliceName": "dateTimeEffective",
        "comment": "A date and time shall always be present.",
        "type": [
          {
            "code": "dateTime"
          }
        ]
      },
      {
        "id": "Observation.effective[x].effective[x]:effectivePeriod",
        "path": "Observation.effectivePeriod",
        "sliceName": "effectivePeriod",
        "definition": "The time period when there is a Measure-Active-Period attribute. The difference between the end and start fields is the value of the Measure-Active-Period.",
        "type": [
          {
            "code": "Period"
          }
        ]
      },
      {
        "id": "Observation.effective[x].effective[x]:effectivePeriod.start",
        "path": "Observation.effectivePeriod.start",
        "min": 1
      },
      {
        "id": "Observation.effective[x].effective[x]:effectivePeriod.end",
        "path": "Observation.effectivePeriod.end",
        "definition": "The end of the period. It will be the value of the Measure-Active-Period plus the start time.",
        "min": 1
      },
      {
        "id": "Observation.device",
        "path": "Observation.device",
        "comment": "This field will reference the DeviceComponent when the updated fixes are in place. In the meantime it will reference the DeviceMetric",
        "min": 1
      },
      {
        "id": "Observation.device.reference",
        "path": "Observation.device.reference",
        "short": "Reference to the device responsible for the measurement",
        "definition": "Reference to the device-related resources that describe the sensor device taking the measurement and the gateway that handled it. This element will point to a DeviceComponent resource following the Phd Parent DeviceComponent Profile.",
        "comment": "This reference points to the DeviceComponent resource containing information about the sensor device that took the measurement and gateway (if any) that handled it.",
        "min": 1
      },
      {
        "id": "Observation.related",
        "path": "Observation.related",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "target.reference"
            }
          ],
          "ordered": true,
          "rules": "open"
        }
      },
      {
        "id": "Observation.related:coincidentTimeStampRelated",
        "path": "Observation.related",
        "sliceName": "coincidentTimeStampRelated",
        "short": "Pointer to the Coincident Time Stamp",
        "definition": "A reference to the Coincident Time Stamp observation. The Coincident Time Stamp indicates how the time stamps from the PHD are corrected, if at all.",
        "comment": "This reference shall be present if the PHD reports a time stamp. The reference shall point to the Coincident Time Stamp observation. The Coincident Time Stamp Observation provides an audit of the time stamp. Whether or not the gateway corrected the time stamp can be determined from the elements in this Observation. If the timestamps were corrected, the elements of the Observation can be used to obtain the actual time stamps reported by the PHD.\r\n\r\nThere is no reference to a Coincident Time Stamp Observation when the PHD does not report a time stamp.",
        "requirements": "This Observation allows one to re-create the original time stamp generated by the PHD should it have been modified by the PHG."
      },
      {
        "id": "Observation.related:coincidentTimeStampRelated.target.reference",
        "path": "Observation.related.target.reference",
        "min": 1
      },
      {
        "id": "Observation.related:SourceHandleReferenceRelated",
        "path": "Observation.related",
        "sliceName": "SourceHandleReferenceRelated",
        "comment": "A measurement may have one or more source handle references which point to measurements that this measurement is related to in some way. When one of these attributes are present in the measurement, these values point to other measurements. In this case these measurements will be previously generated Observation resources which are then referenced here. Note that the previously received measurement must be received in the same connection as the current measurement. The application does not need to keep record of all measurements from the given device!",
        "requirements": "Points to a measurement that this measurement is related to or dependent upon, for example a BMI which is calculated from a weight and height measurement or a heart rate taken during a running session."
      },
      {
        "id": "Observation.related:SourceHandleReferenceRelated.target.reference",
        "path": "Observation.related.target.reference",
        "min": 1
      },
      {
        "id": "Observation.component",
        "path": "Observation.component",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "code.coding.code"
            }
          ],
          "rules": "open"
        }
      },
      {
        "id": "Observation.component:supplementalTypesComponent",
        "path": "Observation.component",
        "sliceName": "supplementalTypesComponent",
        "definition": "For each paritition:term code pair contained in the Supplemental-Types attribute, a separate supplementalTypesComponent element is generated. The component is not generated if the attribute is absent or empty. The component shall be generated otherwise.",
        "comment": "A PHD may send a Supplemental-Types attribute as part of the measurement. This attribute consists of a set of MDC nomenclature codes as partition:term code pairs. Each pair is a code describing something additional about the measurement, such as MDC_MODALITY_SPOT in the pulse oximeter which indicates that the provided meausrement is a stable average. An MDC_MODALITY_FAST would indicate that a short averaging is used and the result reported regardless of stability."
      },
      {
        "id": "Observation.component:supplementalTypesComponent.code.coding",
        "path": "Observation.component.code.coding",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "system"
            }
          ],
          "ordered": true,
          "rules": "open"
        },
        "min": 1
      },
      {
        "id": "Observation.component:supplementalTypesComponent.code.coding:11073Type",
        "path": "Observation.component.code.coding",
        "sliceName": "11073Type",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.code.coding:11073Type.system",
        "path": "Observation.component.code.coding.system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.code.coding:11073Type.code",
        "path": "Observation.component.code.coding.code",
        "definition": "68193 is the 32-bit nomenclature code indicating a 'Supplemental-Types' value",
        "min": 1,
        "fixedCode": "68193"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.code.coding:11073Type.display",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/elementdefinition-translatable",
            "valueBoolean": true
          }
        ],
        "path": "Observation.component.code.coding.display",
        "definition": "It is recommended to display at least the reference identifier for the Supplemental-Types which is MDC_ATTR_SUPPLEMENTAL_TYPES"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.value[x]:valueCodeableConcept",
        "path": "Observation.component.valueCodeableConcept",
        "sliceName": "valueCodeableConcept",
        "definition": "The information determined as a result of making the observation, if the information is a code.",
        "min": 1,
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "Observation.component:supplementalTypesComponent.value[x]:valueCodeableConcept.coding",
        "path": "Observation.component.valueCodeableConcept.coding",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "system"
            }
          ],
          "ordered": true,
          "rules": "open"
        },
        "min": 1
      },
      {
        "id": "Observation.component:supplementalTypesComponent.value[x]:valueCodeableConcept.coding:11073Value",
        "path": "Observation.component.valueCodeableConcept.coding",
        "sliceName": "11073Value",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.value[x]:valueCodeableConcept.coding:11073Value.system",
        "path": "Observation.component.valueCodeableConcept.coding.system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:supplementalTypesComponent.value[x]:valueCodeableConcept.coding:11073Value.code",
        "path": "Observation.component.valueCodeableConcept.coding.code",
        "definition": "For the given Supplemental-Types entry the code here is given by: partition * 2**16 + term code",
        "min": 1
      },
      {
        "id": "Observation.component:supplementalTypesComponent.dataAbsentReason",
        "path": "Observation.component.dataAbsentReason",
        "max": "0"
      },
      {
        "id": "Observation.component:relativeTimeComponent",
        "path": "Observation.component",
        "sliceName": "relativeTimeComponent",
        "definition": "This component shall be present if the measurement contains a Relative-Time-Stamp.",
        "comment": "Relative time stamps are converted to wall clock time by the PHG through the Coincident Time Stamp Observation. The original relative time value shall be provided here in order to recover the data sent by the sensor device.\r\nThe Relative-Time-Stamp is a 32-bit unsigned integer in units of 1/8th ms.",
        "max": "1"
      },
      {
        "id": "Observation.component:relativeTimesComponent.code.coding",
        "path": "Observation.component.code.coding",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "code"
            }
          ],
          "ordered": true,
          "rules": "open"
        },
        "min": 1
      },
      {
        "id": "Observation.component:relativeTimeComponent.code.coding:11073Type",
        "path": "Observation.component.code.coding",
        "sliceName": "11073Type",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:relativeTimeComponent.code.coding:11073Type.system",
        "path": "Observation.component.code.coding.system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:relativeTimeComponent.code.coding:11073Type.code",
        "path": "Observation.component.code.coding.code",
        "definition": "The MDC code of the Relative-Time-Stamp attribute",
        "min": 1,
        "fixedCode": "67985"
      },
      {
        "id": "Observation.component:relativeTimeComponent.code.coding:11073Type.display",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/elementdefinition-translatable",
            "valueBoolean": true
          }
        ],
        "path": "Observation.component.code.coding.display",
        "definition": "The reference identifier should be included in the description. For a Relative-Time-Stamp the ref id is MDC_ATTR_TIME_STAMP_REL"
      },
      {
        "id": "Observation.component:relativeTimeComponent.value[x]:valueQuantity",
        "path": "Observation.component.valueQuantity",
        "sliceName": "valueQuantity",
        "min": 1,
        "type": [
          {
            "code": "Quantity"
          }
        ]
      },
      {
        "id": "Observation.component:relativeTimeComponent.value[x]:valueQuantity.value",
        "path": "Observation.component.valueQuantity.value",
        "definition": "The value of the relative time attribute which is in units of 1/8th milliseconds scaled to microseconds.",
        "min": 1
      },
      {
        "id": "Observation.component:relativeTimeComponent.value[x]:valueQuantity.unit",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/elementdefinition-translatable",
            "valueBoolean": true
          }
        ],
        "path": "Observation.component.valueQuantity.unit",
        "definition": "A human-readable form of the unit which in this case is recommended to be the UCUM code for microseconds (us)",
        "min": 1
      },
      {
        "id": "Observation.component:relativeTimeComponent.value[x]:valueQuantity.system",
        "path": "Observation.component.valueQuantity.system",
        "definition": "The unit code shall use the MDC system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:relativeTimeComponent.value[x]:valueQuantity.code",
        "path": "Observation.component.valueQuantity.code",
        "definition": "The MDC code for microseconds is 264339",
        "min": 1,
        "fixedCode": "264339"
      },
      {
        "id": "Observation.component:relativeTimeComponent.dataAbsentReason",
        "path": "Observation.component.dataAbsentReason",
        "max": "0"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent",
        "path": "Observation.component",
        "sliceName": "hiresRelativeTimeComponent",
        "definition": "This component shall be present if the measurement contains Hi-Res-Relative-Time-Stamp.",
        "comment": "Hi Res Relative time stamps are converted to wall clock time by the PHG through the Coincident Time Stamp Observation. The original relative time value shall be provided here in order to recover the data sent by the sensor device.\r\nThe Hi-Res-Relative-Time-Stamp is a 64-bit unsigned interger in units of microseconds.",
        "max": "1"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.code.coding",
        "path": "Observation.component.code.coding",
        "slicing": {
          "discriminator": [
            {
              "type": "value",
              "path": "code"
            }
          ],
          "ordered": true,
          "rules": "open"
        },
        "min": 1
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.code.coding:11073Type",
        "path": "Observation.component.code.coding",
        "sliceName": "11073Type",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.code.coding:11073Type.system",
        "path": "Observation.component.code.coding.system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.code.coding:11073Type.code",
        "path": "Observation.component.code.coding.code",
        "definition": "The MDC code for the Hi-Res-Relative-Time-Stamp attribute",
        "min": 1,
        "fixedCode": "68073"
      },
      {
        "id": "Observation.component:hiresRelativeTime.code.coding:11073Type.display",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/elementdefinition-translatable",
            "valueBoolean": true
          }
        ],
        "path": "Observation.component.code.coding.display",
        "definition": "The reference identifier should be included in the description. For a Hi-Res-Relative-Time-Stamp the ref id is MDC_ATTR_TIME_STAMP_REL_HI_RES"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.value[x]:valueQuantity",
        "path": "Observation.component.valueQuantity",
        "sliceName": "valueQuantity",
        "min": 1,
        "type": [
          {
            "code": "Quantity"
          }
        ]
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.value[x]:valueQuantity.value",
        "path": "Observation.component.valueQuantity.value",
        "short": "Numerical value",
        "definition": "The value of the hi res relative time attribute (already in microseconds).",
        "min": 1
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.value[x]:valueQuantity.unit",
        "extension": [
          {
            "url": "http://hl7.org/fhir/StructureDefinition/elementdefinition-translatable",
            "valueBoolean": true
          }
        ],
        "path": "Observation.component.valueQuantity.unit",
        "definition": "A human-readable form of the unit which in this case is recommended to be the UCUM code for microseconds (us)",
        "min": 1
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.value[x]:valueQuantity.system",
        "path": "Observation.component.valueQuantity.system",
        "definition": "The unit code shall use the MDC system",
        "min": 1,
        "fixedUri": "urn:iso:std:iso:11073:10101"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.value[x]:valueQuantity.code",
        "path": "Observation.component.valueQuantity.code",
        "definition": "The MDC code for microseconds is 264339",
        "min": 1,
        "fixedCode": "264339"
      },
      {
        "id": "Observation.component:hiresRelativeTimeComponent.dataAbsentReason",
        "path": "Observation.component.dataAbsentReason",
        "max": "0"
      },
      {
        "id": "Observation.component:measurementStatusComponent",
        "path": "Observation.component",
        "sliceName": "measurementStatusComponent",
        "definition": "This component gives one of the settings reported in the Measurement-Status attribute that are not reported in the Observation.dataAbsentReason or Observation.status element. The settings that ARE reported in the dataAbsentReason and status elements are 'invalid', 'questionable', 'not-available', and 'early-indication'. It is optional to report any of the other settings UNLESS MDER-BITs 14 or 15 are set. It is optional to report any defined cleared setting; these are all events.",
        "comment": "When MDER-BITs 14 and 15 are set, these are special uses cases by the Pulse Oximeter and Continuous Glucose specialization. MDER-BIT 14 indicates that a threshold set up in other attributes has been crossed. MDER-BIT 15 indicates that the alert mechanism has been turned off.  There will be one measurementStatusComponent entry for every setting reported.",
        "requirements": "This component indicates a Measurement-Status setting."
      },
      {
        "id": "Observation.component:measurementStatusComponent.code.coding",
        "path": "Observation.component.code.coding",
        "comment": "Normally alternative coding systems are allowed but in this case the value is intimately tied to the code. The code represents the feature indicated by a bit settin in the attribute value. which is either cleared (0) or set (1). Thus the value for this entry is itself a binary 'Y' or 'N' code from http://hl7.org/fhir/v2/0136",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:measurementStatusComponent.code.coding.system",
        "path": "Observation.component.code.coding.system",
        "min": 1,
        "fixedUri": "http://hl7.org/fhir/IEEE.ASN1"
      },
      {
        "id": "Observation.component:measurementStatusComponent.code.coding.code",
        "path": "Observation.component.code.coding.code",
        "definition": "This code, which is an alpha-numeric string, is generated by the attribute MDC code, which is 133447 for the Measurement-Status, followed by a dot (.) followed by the MDER-bit that was set.",
        "comment": "Note that this code is an alpha-numeric string and not a decimal number. Think of it like a very-limited OID. MDER-BITs 14 and 15 shall be reported if set.",
        "min": 1
      },
      {
        "id": "Observation.component:measurementStatusComponent.value[x]",
        "path": "Observation.component.valueCodeableConcept",
        "min": 1,
        "type": [
          {
            "code": "CodeableConcept"
          }
        ]
      },
      {
        "id": "Observation.component:measurementStatusComponent.value[x]:valueCodeableConcept.coding",
        "path": "Observation.component.valueCodeableConcept.coding",
        "min": 1,
        "max": "1"
      },
      {
        "id": "Observation.component:measurementStatusComponent.value[x]:valueCodeableConcept.coding.system",
        "path": "Observation.component.valueCodeableConcept.coding.system",
        "definition": "This coding system contains only two entries, 'Y' (yes) and 'N' (no)",
        "min": 1,
        "fixedUri": "http://hl7.org/fhir/v2/0136"
      },
      {
        "id": "Observation.component:measurementStatusComponent.value[x]:valueCodeableConcept.coding.code",
        "path": "Observation.component.valueCodeableConcept.coding.code",
        "definition": "If the MDER-Bit is set, the code value is 'Y' otherwise it is 'N'",
        "comment": "Recall that when the value is 'Y' the alarm or alert is turned off",
        "min": 1
      },
      {
        "id": "Observation.component:measurementStatusComponent.dataAbsentReason",
        "path": "Observation.component.dataAbsentReason",
        "max": "0"
      }
    ]
  }
}