This is the Continuous Integration Build of FHIR (will be incorrect/inconsistent at times).
See the Directory of published versions
Orders and Observations ![]() | Maturity Level: 2 | Trial Use | Security Category: Business | Compartments: No defined compartments |
A manufactured item that is used in the provision of healthcare without being substantially changed through that activity. The device may be a medical or non-medical device.
Note to Implementers: For an overview of this resource and others in the Device domain, also see the module page.
Note to Implementers: The owner has been removed from Device and is now included in DeviceAssociation as .relationship of the subject. Please comment on the revision if there are issues with removing the identification of individuals in the Device resource.
Note to Implementers: The following extensions will be added to a future Extension Pack release to cover removed Device elements including: mode, cycle, duration, gateway and endpoint. In addition, the following new extensions will be added: 1. For device alerts called device-alertDetection, which describes the alert detection activation states for the overall device. 2. For the source of the specification, device-conformsTo-source.
This is a base resource that tracks individual instances of a device and their location. It is referenced by other resources for recording which device performed an action such as a procedure or an observation, which device was implanted in or explanted from a patient, dispensing a device to a patient for their use, managing inventory, or when requesting a specific device for a patient's use. Medical devices include durable (reusable) medical equipment, implantable devices, as well as disposable equipment used for diagnostic, treatment, and research for healthcare and public health. Medical devices may also include some types of software.
Non-medical devices may include items such as a machine, cellphone, computer, software application or algorithm, etc. In short, a Device can range from a tongue depressor to an MRI. The fields in the Device resource must be flexible enough to cover this range.
The resource may be used to document the Unique Device Identifier (UDI) and information about a device where appropriate or necessary according to local jurisdictions over time. Additional information about UDI is provided in the Unique Device Identifier (UDI) section.
Devices may be categorized and may be associated with one or more categories. Device category examples include, but are not limited to: active, communicating, durable medical equipment, home use, implantable, InVitro diagnostics, personal health, point-of-care, single use, re-usable, and software. See DeviceDefinition for detailed descriptions of devce categories.
When referring to a specific instance, even without specific instance details, Device is to be used, not a DeviceDefinition. The context of a data exchange indicates whether the data is representing a physical instance or a "kind", not the presence of instance data such as lot and serial numbers.
Some examples:
Note to Implementers: The module pages under development by Orders and Observations will further describe the variations of device use cases across the device resources, e.g., Device, DeviceDefinition, DeviceAssociation, DeviceDispense, DeviceMetric, DeviceRequest, and Device Usage.
There are several resources that can be used to represent device related events, requests or definitions. The following Resources should be used in the following manner:
In FHIR, the Device represents either the device in total, or a component of an encapsulating device when there is a need for individual tracking of a component. A Device as a component then points to the parent device it is part of. The top-level Device captures the actual data about the instance of the device and the instances of all its children that either provides identifying characteristics of the Device (including applicable UDI – unique device identification) and data that can vary dynamically by device, e.g., specific settings at a particular point in time.
Devices differ from medications because they are not "used up" - they remain active in or for a patient for a longer duration. They also may be re-used, particularly non-implanted devices and those used for diagnostics and procedures. Frequently, when a device is packaged with a medication, the ordering, dispense, and administration processes typically focus on the medication aspects and reference the device.
In the case of an infusion pump, while some actions are focused on the device (e.g., ordering to a room or maintaining the pump), the focus is as well on the medication while the device is used for administration. However, that separation is not always as clear and may be impacted by specific implementations. Regardless, the Medication resource should not be used to represent (implanted) devices, rather reference the relationship where an actual device needs to be tracked in addition to the medication. In some sense the Medication is analogous to the Observation generated by a Blood Pressure personal health device. The Observation resource contains the blood pressure values, units and the time stamp while the Device resource contains the manufacturer name, model number, serial number, firmware and hardware versions, exchange protocol information, any clock capabilities, etc.
Additional definitions: Master Definition XML + JSON, XML Schema/Schematron + JSON Schema, ShEx (for Turtle) + see the extensions, the spreadsheet version & the dependency analysis
Path | ValueSet | Type | Documentation |
---|---|---|---|
Device.udiCarrier.entryType | UDIEntryType | Required | Codes to identify how UDI data was entered. |
Device.status | FHIRDeviceStatus | Required | The status of the Device record. |
Device.availabilityStatus | FHIRDeviceAvailabilityStatus | Extensible | The availability status of the device. |
Device.name.type | DeviceNameType | Extensible | The type of name the device is referred by. |
Device.category | FHIRDeviceCategory | Example | The association state of the device. |
Device.type | DeviceType | Example | Codes used to identify medical devices. Includes concepts from SNOMED CT (http://www.snomed.org/) where concept is-a 49062001 (Device) and is provided as a suggestive example. |
Device.deviceVersion.type | DeviceVersionType | Example | Describes the type of version |
Device.conformsTo.category | DeviceSpecificationCategory (a valid code from FHIR Device Specialization Category) | Example | The kind of standards used by the device. |
Device.conformsTo.specification | DeviceSpecificationType | Example | The type or specification of a standard that devices can adhere to |
Device.property.type | DeviceType | Example | Codes used to identify medical devices. Includes concepts from SNOMED CT (http://www.snomed.org/) where concept is-a 49062001 (Device) and is provided as a suggestive example. |
Device.additive.type | SubstanceCode | Example | This value set contains concept codes for specific substances. It includes codes from SNOMED |
Device.safety | DeviceSafety | Example | Codes used to identify medical devices safety characteristics. These codes are taken from the NCI Thesaurus |
UniqueKey | Level | Location | Description | Expression |
![]() | Rule | (base) | only one Device.name.display SHALL be true when there is more than one Device.name | name.where(display=true).count() <= 1 |
Nearly all devices are assigned a string of characters to represent one or more identifiers or codes, which are usually printed or affixed to the device using either barcodes or RFIDs. The identifier or code can come from the manufacturer (for example, a 'serial number', 'reference number', or 'catalog number'), various institution and registries. Any of these identifiers or codes assigned to the device can and should be recorded in the device resource. However, there can there can be confusion where to represent them in the resource because codes and identifiers are represented in FHIR as semantically distinct elements and because organizations may conflate the term 'code' for an identifier or 'identifier' for a code in their names.
The identifier
element is only intended for use when it's an actual identifier for a specific instance of a device. That would mean that each device would have a separate serial number and would be represented using this element - devices without serial numbers (for example, a box of syringes) would not. Concepts such as a reference number or catalog number or GTIN describe a code which represents a kind of device and are conveyed using the type
element. Some sources of standard codes for devices and translations within type
are listed below:
For systems that do have a system URI for device types (indicating the model number or part number), they can and should appear as codings in Device.type
.
Device.type
relates DeviceDefinition.classification.type
using the same binding enabling referencing. Please see the Search Parameters for details on how to search for devices by type.
The International Medical Device Regulators Forum IMDRF UDI Working Group published UDI System for Medical Devices (Version 2.0) , the base specification for Unique Device Identifiers (UDI). The United States Food and Drug Administration has produced an implementation guide
for Unique Device Identifiers (UDI) which implements the IMDRF specification and other jurisdictions may produce similar IMDRF implementation guides as well. The full UDI string that represents the barcode as printed on the packaging of the device or Automatic Identification and Data Capture (AIDC) representation is called the "UDI carrier". The UDI has 2 components*:
*non-UDI elements may also appear within the UDI carrier.
**a "GTIN" (sometimes also called an EAN number) is a code developed by GS1 for the kind of device not an identifier for the device. A GTIN may appear on its own or it may appear in a UDI string as the DI component.
The DI of the UDI may be stored in a jurisdictional repository and used as the primary key to access other device information. For example, in the United States, the DI of the UDI is submitted in a device record to the Global Unique Device Identification Database (GUDID) . The UDI may identify an instance of a device uniquely (when the PI includes a serial number), or it may just identify the type of the device. The UDI is parsed into its constituent parts (DI, PI and other elements) by parsing rules developed by each Issuing Agency standard. Where the device has an assigned UDI, the other details carried in the resource (e.g., lot, expiration date, etc.) SHALL be consistent with the information encoded in the UDI string or registered in the local repository.
Best practice guidelines for transmitting UDI data using the Device resource dictate transmitting both the UDI Carrier and all components found within the UDI as described in Device UDI Mapping. Several examples are provided for further guidance.
Device.status is about the record, while .availabilityStatus is about the device itself.
Search parameters for this resource. See also the full list of search parameters for this resource, and check the Extensions registry for search parameters on extensions related to this resource. The common parameters also apply. See Searching for more information about searching in REST, messaging, and services.
Name | Type | Description | Expression | In Common |
biological-source-event | token | The biological source for the device | Device.biologicalSourceEvent | |
code | token | The definition / type of the device (code) | Device.type | Device.definition.resolve().classification.type | |
code-value-concept | composite | Code and value parameter pair | On Device: specification: specification.ofType(CodeableConcept) version: version.ofType(string) |
|
definition | reference | The definition / type of the device | Device.definition (DeviceDefinition) |
|
device-name | string | A server defined search that may match any of the string fields in Device.name or Device.type. | Device.name.value | Device.type.coding.display | Device.type.text | |
expiration-date | date | The expiration date of the device | Device.expirationDate | |
identifier | token | Instance id from manufacturer, owner, and others | Device.identifier | |
location | reference | A location, where the resource is found | Device.location (Location) |
|
lot-number | string | The lot number of the device | Device.lotNumber | |
manufacture-date | date | The manufacture date of the device | Device.manufactureDate | |
manufacturer | string | The manufacturer of the device | Device.manufacturer | |
model | string | The model of the device | Device.modelNumber | |
parent | reference | The parent device | Device.parent (Device) |
|
serial-number | string | The serial number of the device | Device.serialNumber | Device.identifier.where(type='SNO') | |
specification | token | The standards, specifications, or formal guidances. | Device.conformsTo.specification | |
specification-version | composite | A composite of both specification and version | On Device.conformsTo: specification: specification version: version |
|
status | token | active | inactive | entered-in-error | unknown | Device.status | |
type | token | The type of the device | Device.type | Device.definition.resolve().classification.type | |
udi-carrier-hrf | string | UDI Barcode (RFID or other technology) string in HRF format. |
Device.udiCarrier.carrierHRF | |
udi-di | string | The udi Device Identifier (DI) | Device.udiCarrier.deviceIdentifier | |
version | string | The specific version of the device | Device.deviceVersion.value | |
version-type | composite | Value and type of version | On Device.deviceVersion: type: type value: value |