This page is part of the CCDA: Consolidated CDA Release (v3.0.0-ballot: CCDA 3.0 Ballot 1) based on FHIR (HL7® FHIR® Standard) v5.0.0. . For a full list of available versions, see the Directory of published versions
Official URL: http://hl7.org/cda/us/ccda/StructureDefinition/ProductInstance | Version: 3.0.0-ballot | |||
Draft as of 2023-12-21 | Computable Name: ProductInstance | |||
Other Identifiers: id: urn:oid:2.16.840.1.113883.10.20.22.4.37 |
This clinical statement represents a particular device that was placed in a patient or used as part of a procedure or other act. This provides a record of the identifier and other details about the given product that was used. For example, it is important to have a record that indicates not just that a hip prostheses was placed in a patient but that it was a particular hip prostheses number with a unique identifier.
The FDA Amendments Act specifies the creation of a Unique Device Identification (UDI) System that requires the label of devices to bear a unique identifier that will standardize device identification and identify the device through distribution and use.
The FDA permits an issuing agency to designate that their Device Identifier (DI) + Production Identifier (PI) format qualifies as a UDI through a process of accreditation. Currently, there are three FDA-accredited issuing agencies that are allowed to call their format a UDI. These organizations are GS1, HIBCC, and ICCBBA. For additional information on technical formats that qualify as UDI from each of the issuing agencies see the UDI Appendix.
When communicating only the issuing agency device identifier (i.e., subcomponent of the UDI), the use of the issuing agency OID is appropriate. However, when communicating the unique device identifier (DI + PI), the FDA OID (2.16.840.1.113883.3.3719) must be used. When sending a UDI, populate the participantRole/id/@root with the FDA OID (2.16.840.1.113883.3.3719) and participantRole/id/@extension with the UDI.
When sending a DI, populate the participantRole/id/@root with the appropriate assigning agency OID and participantRole/id/@extension with the DI. The scopingEntity/id should correspond to FDA or the appropriate issuing agency.
Usage:
Description of Profiles, Differentials, Snapshots and how the different presentations work.
This structure is derived from ParticipantRole
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
ParticipantRole | ParticipantRole | XML Namespace: urn:hl7-org:v3 Elements defined in Ancestors: @nullFlavor, realmCode, typeId, templateId, @classCode, id, sdtcIdentifiedBy, code, addr, telecom, playingDevice, playingEntity, scopingEntity Instances of this type are validated by templateId Logical Container: ClinicalDocument (CDA Class) | ||
Slices for templateId | 1..* | II | Slice: Unordered, Open by value:root | |
templateId:product-instance | 1..1 | II | ||
@root | 1..1 | oid, uuid, ruid | Required Pattern: 2.16.840.1.113883.10.20.22.4.37 | |
@extension | 0..0 | |||
@classCode | 1..1 | cs | Fixed Value: MANU | |
id | 1..* | II | ||
playingDevice | C | 1..1 | Device | should-code: SHOULD contain code |
code | 0..1 | CE | ||
scopingEntity | 1..1 | Entity | ||
id | 1..* | II | ||
Documentation for this format |
Id | Grade | Path(s) | Details | Requirements |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
ParticipantRole | C | 1..1 | ParticipantRole | XML Namespace: urn:hl7-org:v3 Elements defined in Ancestors: @nullFlavor, realmCode, typeId, templateId, @classCode, id, sdtcIdentifiedBy, code, addr, telecom, playingDevice, playingEntity, scopingEntity Base for all types and resources Instances of this type are validated by templateId Logical Container: ClinicalDocument (CDA Class) |
Slices for templateId | 1..* | II | Slice: Unordered, Open by value:root | |
templateId:product-instance | 1..1 | II | ||
@root | 1..1 | oid, uuid, ruid | Required Pattern: 2.16.840.1.113883.10.20.22.4.37 | |
@classCode | 1..1 | cs | Binding: RoleClassRoot (required) Fixed Value: MANU | |
id | 1..* | II | ||
playingDevice | C | 1..1 | Device | should-code: SHOULD contain code |
@classCode | 1..1 | cs | Binding: EntityClassDevice (required) | |
code | 0..1 | CE | Binding: EntityCode (example) | |
scopingEntity | 1..1 | Entity | ||
@classCode | 1..1 | cs | Binding: EntityClassRoot (required) | |
id | 1..* | II | ||
Documentation for this format |
Path | Conformance | ValueSet / Code |
ParticipantRole.classCode | required | Fixed Value: MANU |
ParticipantRole.playingDevice.classCode | required | EntityClassDevice |
ParticipantRole.playingDevice.code | example | EntityCode |
ParticipantRole.scopingEntity.classCode | required | EntityClassRoot |
Id | Grade | Path(s) | Details | Requirements |
role-choice | error | ParticipantRole | playingDevice and playingEntity are mutually exclusive : (playingDevice | playingEntity).count() <= 1 | |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
Path | Conformance | ValueSet / Code |
ParticipantRole.nullFlavor | required | CDANullFlavor |
ParticipantRole.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.templateId:product-instance.nullFlavor | required | CDANullFlavor |
ParticipantRole.classCode | required | Fixed Value: MANU |
ParticipantRole.code | example | RoleCode |
ParticipantRole.playingDevice.nullFlavor | required | CDANullFlavor |
ParticipantRole.playingDevice.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.playingDevice.classCode | required | EntityClassDevice |
ParticipantRole.playingDevice.determinerCode | required | Fixed Value: INSTANCE |
ParticipantRole.playingDevice.code | example | EntityCode |
ParticipantRole.playingDevice.manufacturerModelName | example | ManufacturerModelNameExample |
ParticipantRole.playingDevice.softwareName | example | SoftwareNameExample |
ParticipantRole.scopingEntity.nullFlavor | required | CDANullFlavor |
ParticipantRole.scopingEntity.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.scopingEntity.classCode | required | EntityClassRoot |
ParticipantRole.scopingEntity.determinerCode | required | Fixed Value: INSTANCE |
ParticipantRole.scopingEntity.code | example | EntityCode |
Id | Grade | Path(s) | Details | Requirements |
role-choice | error | ParticipantRole | playingDevice and playingEntity are mutually exclusive : (playingDevice | playingEntity).count() <= 1 | |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
This structure is derived from ParticipantRole
Summary
Mandatory: 7 elements
Fixed Value: 1 element
Prohibited: 1 element
Slices
This structure defines the following Slices:
Differential View
This structure is derived from ParticipantRole
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
ParticipantRole | ParticipantRole | XML Namespace: urn:hl7-org:v3 Elements defined in Ancestors: @nullFlavor, realmCode, typeId, templateId, @classCode, id, sdtcIdentifiedBy, code, addr, telecom, playingDevice, playingEntity, scopingEntity Instances of this type are validated by templateId Logical Container: ClinicalDocument (CDA Class) | ||
Slices for templateId | 1..* | II | Slice: Unordered, Open by value:root | |
templateId:product-instance | 1..1 | II | ||
@root | 1..1 | oid, uuid, ruid | Required Pattern: 2.16.840.1.113883.10.20.22.4.37 | |
@extension | 0..0 | |||
@classCode | 1..1 | cs | Fixed Value: MANU | |
id | 1..* | II | ||
playingDevice | C | 1..1 | Device | should-code: SHOULD contain code |
code | 0..1 | CE | ||
scopingEntity | 1..1 | Entity | ||
id | 1..* | II | ||
Documentation for this format |
Id | Grade | Path(s) | Details | Requirements |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
Key Elements View
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
ParticipantRole | C | 1..1 | ParticipantRole | XML Namespace: urn:hl7-org:v3 Elements defined in Ancestors: @nullFlavor, realmCode, typeId, templateId, @classCode, id, sdtcIdentifiedBy, code, addr, telecom, playingDevice, playingEntity, scopingEntity Base for all types and resources Instances of this type are validated by templateId Logical Container: ClinicalDocument (CDA Class) |
Slices for templateId | 1..* | II | Slice: Unordered, Open by value:root | |
templateId:product-instance | 1..1 | II | ||
@root | 1..1 | oid, uuid, ruid | Required Pattern: 2.16.840.1.113883.10.20.22.4.37 | |
@classCode | 1..1 | cs | Binding: RoleClassRoot (required) Fixed Value: MANU | |
id | 1..* | II | ||
playingDevice | C | 1..1 | Device | should-code: SHOULD contain code |
@classCode | 1..1 | cs | Binding: EntityClassDevice (required) | |
code | 0..1 | CE | Binding: EntityCode (example) | |
scopingEntity | 1..1 | Entity | ||
@classCode | 1..1 | cs | Binding: EntityClassRoot (required) | |
id | 1..* | II | ||
Documentation for this format |
Path | Conformance | ValueSet / Code |
ParticipantRole.classCode | required | Fixed Value: MANU |
ParticipantRole.playingDevice.classCode | required | EntityClassDevice |
ParticipantRole.playingDevice.code | example | EntityCode |
ParticipantRole.scopingEntity.classCode | required | EntityClassRoot |
Id | Grade | Path(s) | Details | Requirements |
role-choice | error | ParticipantRole | playingDevice and playingEntity are mutually exclusive : (playingDevice | playingEntity).count() <= 1 | |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
Snapshot View
Path | Conformance | ValueSet / Code |
ParticipantRole.nullFlavor | required | CDANullFlavor |
ParticipantRole.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.templateId:product-instance.nullFlavor | required | CDANullFlavor |
ParticipantRole.classCode | required | Fixed Value: MANU |
ParticipantRole.code | example | RoleCode |
ParticipantRole.playingDevice.nullFlavor | required | CDANullFlavor |
ParticipantRole.playingDevice.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.playingDevice.classCode | required | EntityClassDevice |
ParticipantRole.playingDevice.determinerCode | required | Fixed Value: INSTANCE |
ParticipantRole.playingDevice.code | example | EntityCode |
ParticipantRole.playingDevice.manufacturerModelName | example | ManufacturerModelNameExample |
ParticipantRole.playingDevice.softwareName | example | SoftwareNameExample |
ParticipantRole.scopingEntity.nullFlavor | required | CDANullFlavor |
ParticipantRole.scopingEntity.typeId.nullFlavor | required | CDANullFlavor |
ParticipantRole.scopingEntity.classCode | required | EntityClassRoot |
ParticipantRole.scopingEntity.determinerCode | required | Fixed Value: INSTANCE |
ParticipantRole.scopingEntity.code | example | EntityCode |
Id | Grade | Path(s) | Details | Requirements |
role-choice | error | ParticipantRole | playingDevice and playingEntity are mutually exclusive : (playingDevice | playingEntity).count() <= 1 | |
should-code | warning | ParticipantRole.playingDevice | SHOULD contain code : code.exists() |
This structure is derived from ParticipantRole
Summary
Mandatory: 7 elements
Fixed Value: 1 element
Prohibited: 1 element
Slices
This structure defines the following Slices: