This wiki has undergone a migration to Confluence found Here
<meta name="googlebot" content="noindex">

Difference between revisions of "Template Functional Requirements"

From HL7Wiki
Jump to navigation Jump to search
 
(99 intermediate revisions by 5 users not shown)
Line 1: Line 1:
HL7 V3 Templates maintain a set of functional requirements.  What is the list of functional requirements required of Templates for use in HL7?
+
HL7 V3 Templates maintain a set of functional requirements.  What is the list of functional requirements required of Templates for use in HL7?
 +
 
 +
This document does not discuss implimentation of these requirements, which will be addressed in a different document.
 +
 
 +
 
 +
'''Disclaimer'''
 +
----
 +
The purpose of this work - working through the joint CEN and openEHR Archetype Requirements in detail - is to provide the basis of understanding for the requirements of HL7 Templates only.  This work is NOT intended to be the formal HL7 Templates requirements document.
 +
 
 +
The CEN/openEHR Requirements are here: [http://www.cen.eu/cen/Members/Pages/default.aspx http://www.cen.eu/cen/Members/Pages/default.aspx]
  
  
 
'''Acknowledgements'''
 
'''Acknowledgements'''
 +
----
 +
The specification of HL7 templates defined here has been produced under work program of the HL7 Templates Special Interest Group.  It has been greatly influenced by the work contained within the CEN 13606-2:2005 (Annex A) draft standard which defines formal requirements for 'archetype' representation.  Representatives of the CEN and openEHR standards working group have supplied this in the interest of harmonisation of CEN and HL7 standards work in the templates area.  Many thanks to Dr Dipak Kalra for his support of this process and continuing engagement with HL7, CEN, and openEHR harmonisation work.
 +
  
The specification of HL7 templates defined here has been produced under work program of the HL7 Templates Special Interest Group.  It has been greatly influenced by the work contained within the CEN 13606-2:2005 (Annex A) draft standard which defines formal requirements for 'archetype' representation.  Representatives of the CEN standards working group have supplied this in the interest of harmonisation of CEN and HL7 standards work in the templates area.  Many thanks to Dr Dipak Kalra for his support of this process and continuing engagement with HL7 and CEN harmonisation work.
+
== '''HL7 Template Metadata''' ==
  
== HL7 Template Metadata ==
+
=== '''Identification Metadata''' - Mandatory ===
=== '''Identification Metadata''' - Required ===
+
----
==== '''''templateID''''' ====  
+
==== '''''[[TemplateId]]''''' ====  
A globally unique, non-semantic, identifier for the Template.  Within the context of HL7, a '''''templateID''''' should take the form of an ISO Object Identifier (OID) or an HL7 Artifact ID.  This is the primary identifier for all Templates.
+
A globally unique, non-semantic, identifier for the Template.  This is the primary identifier for all Templates.
  
 
==== '''''templateName''''' ====  
 
==== '''''templateName''''' ====  
Line 16: Line 28:
 
==== '''''originatingAuthorEntityID''''' ====
 
==== '''''originatingAuthorEntityID''''' ====
 
A globally unique non-semantic identifier for the original author of the Template.
 
A globally unique non-semantic identifier for the original author of the Template.
 +
 +
'''NOTE''':  Determining the form of the ID and its issuer etc is necessary but out of scope for the Templates SIG.
  
 
==== '''''templateIntention''''' ====  
 
==== '''''templateIntention''''' ====  
 
A free text natural language description of the intent and scope of the Template.  The purpose is to provide the author’s initial intent for the Template.   
 
A free text natural language description of the intent and scope of the Template.  The purpose is to provide the author’s initial intent for the Template.   
 +
 +
'''Example''': The intention may include the [[Realm]] or sub-realm within which the Template was designed to be used for.
  
 
'''NOTE''': A change to the semantic meaning or intent of a Template will constitute a new Template, not a new version of the Template.
 
'''NOTE''': A change to the semantic meaning or intent of a Template will constitute a new Template, not a new version of the Template.
Line 25: Line 41:
 
The version identifier for the Template.  The ability to determine the correct version of a Template is essential to its identification.
 
The version identifier for the Template.  The ability to determine the correct version of a Template is essential to its identification.
  
==== '''''templateReferenceModelID''''' ==== The globally unique identifier (ISO OID or HL7 Artifact ID) of the reference model against which the Template was developedThe underlying reference model may be A DIM, LIM, or Profile or Template.
+
'''NOTE''':  Changes to the Template that do not change the semantis or intention of the Template will constitute a new version of the Template being createdAny change to the semantic meaning of the Template will constitute the creation of a new Template.
  
==== '''''templateRepositoryIdentifier''''' ==== The identifier of the repository where the Template is locatedThis is a required metadata item since the core functional purpose of a Template is reuse, and things in general are much harder to reuse when they cannot be easily located.
+
==== '''''templateReferenceModelID''''' ====  
 +
The globally unique identifier of the reference model against which the Template was developedThe underlying reference model may be A DIM, LIM, or Profile or Template.
  
'''Open Issue:'''  What form should this identifier take?
+
==== '''''templateRepositoryIdentifier''''' ====
 +
The identifier of the repository where the Template is located. This is a required metadata item since the core functional purpose of a Template is reuse, and things in general are much harder to reuse when they cannot be easily located.
  
==== '''''templateRegistrationAuthority''''' ==== The identifier of the registration authority (organization, institution, committee, or individual ) for the Template.   
+
'''Open Issue:'''  What form should this identifier take?  This will be addressed in the Template Implimentation guide, and will likely be ITS dependent.
 +
 
 +
==== '''''templateRegistrationAuthority''''' ====  
 +
The identifier of the registration authority (organization, institution, committee, or individual ) for the Template.   
  
 
'''Open Issues''':  What are registration rules?  What is the relationship between the repository and registration? What is the purpose of regsistration?
 
'''Open Issues''':  What are registration rules?  What is the relationship between the repository and registration? What is the purpose of regsistration?
 
  
 
=== '''Identification Metadata''' - Optional ===
 
=== '''Identification Metadata''' - Optional ===
 +
----
 +
==== '''''templateCodedTerm''''' ====
 +
The coded concept that uniquely represents the templateName within a given code system.  A concept code can be assigned to an entire Template, providing it with a language independent method of secondary indentification.  This can be used in conjunction with the '''''templateName''''' to convey the intended purpose and use of the template.  (Refer to '''''templateName'''''.) The same '''''templateCodedTerm''''' and '''''templateName''''' may be used in multiple Templates.
  
==== '''''templateCodedTerm''''' ==== The coded concept that uniquely represents the templateName within a given code system.  A concept code can be assigned to an entire Template, providing it with a language independent method of secondary indentification.  This can be used in conjunction with the '''''templateName''''' to convey the intended purpose and use of the template. (Refer to '''''templateName'''''.) The same '''''templateCodedTerm''''' and '''''templateName''''' may be used in multiple Templates.
+
=== '''Description Metadata''' – Mandatory ===
 +
----
 +
==== '''''descriptionLanguage''''' ====  
 +
The natural language in which the Template is represented.
  
 +
==== '''''templateDescription''''' ====
 +
A free text natural language description of the intent and scope of the Template.  The purpose is to provide the author’s initial intent for the Template.
  
 +
=== '''Description Metadata''' – Optional ===
 +
----
 +
==== '''''implementationFormat''''' ====
 +
The preferred format that the Template should be implemented in from an ITS perspective.  Implementation formats other than that recommended(if any) are not deemed suitable for this Template by the '''''publishingAuthority'''''.  Other implementation formats are possible, but it is the responsibility of the translator to make the tralation to the new format, not that of the '''''publishingAuthority'''''.
  
 +
==== '''''evidenceSource''''' ====
 +
A description, reference or link to the published medical knowledge that was used in the definition of this Template.
  
=== Description Metadata – Required ===
+
==== '''''detailedDescription''''' ====  
==== '''''descriptionLanguage''''' ====  The natural language in which the Template is represented.
+
A detailed explanation of the purpose of this Template, including features of intrest. This may include an indication of the intended user group for which this definition is intended.
  
==== '''''templateDescription''''' ==== A free text natural language description of the intent and scope of the Template.  The purpose is to provide the author’s initial intent for the Template.
+
==== '''''cautionPoints''''' ====  
 +
A formal statement regarding when this Template should not be used, or may be used erroneously.  To define roles where the Template should not be used, or should be used with careThis field is used to expand in detail on the '''''templateIntention'''''.
  
 
+
=== '''Publication Metadata''' – Mandatory ===
=== Description Metadata – Optional ===
+
----
==== '''''implementationFormat''''' ==== The preferred format that the Template should be implemented in from an ITS perspective.  Implementation formats other than that recommended(if any) are not deemed suitable for this Template by the '''''publishingAuthority'''''.  Other implementation formats are possible, but it is the responsibility of the translator to make the tralation to the new format, not that of the '''''publishingAuthority'''''.
+
==== '''''publicationStatus''''' ====  
 
+
The current publication status for the template.
==== '''''evidenceSource''''' ==== A description, reference or link to the published medical knowledge that was used in the definition of this Template.
 
 
 
==== '''''detailedDescription''''' ==== A detailed explanation of the purpose of this Template, including features of intrest.  This may include an indication of the intended user group for which this definition is intended.
 
 
 
==== '''''cautionPoints''''' ==== A formal statement regarding when this Template should not be used, or may be used erroneously.  To define roles where the Template should not be used, or should be used with care.  This field is used to expand in detail on the '''''templateIntention'''''.
 
 
 
 
 
=== Publication Metadata – Required ===
 
==== '''''publicationStatus''''' ==== The current publication status for the template.
 
 
* Development
 
* Development
 
* Test
 
* Test
Line 69: Line 95:
 
* Deprecated
 
* Deprecated
  
==== '''''publicationStatusChangeDate''''' ==== The date that the current value for '''''publicationStatus''''' was applied of the Template.
+
==== '''''publicationStatusChangeDate''''' ====  
 +
The date that the current value for '''''publicationStatus''''' was applied of the Template.
  
==== '''''publisher''''' ==== The name of the author(s) institutional affiliations and contact infomation for the creators of the Template.
+
==== '''''publisher''''' ====  
 +
The name of the author(s) institutional affiliations and contact infomation for the creators of the Template.
  
==== '''''publishingAuthority''''' ==== The autoritative body who has reviewed the Template for clinical accuracy and relevance, and autorized it for publication.
+
==== '''''publishingAuthority''''' ====  
  
==== '''''revisionHistory''''' ==== The free text description describing the changes in this version of the Template as compared to the previous version.  Since Template versions are built off of previous versions, the net effect of this field is to function as a comprehensive historical reference of the Template.
+
The autoritative body who has reviewed the Template for clinical accuracy and relevance, and autorized it for publication.
  
=== Publication Metadata – Optional ===
+
==== '''''revisionHistory''''' ====  
==== '''''effectiveDate''''' ==== The date after which the Template can be considered for use.  Use of the Template prior to this date would be considered an invalid use of the Template.
+
The free text description describing the changes in this version of the Template as compared to the previous version.  Since Template versions are built off of previous versions, the net effect of this field is to function as a comprehensive historical reference of the Template.
 
 
==== expirationDate ==== The date at which the clincal concept represented by this Template becomes stale, and should be reviewed for clinical relevance and accuracy.  Use of the Template after this date would be considered venturesome.
 
  
 +
=== '''Publication Metadata''' – Optional ===
 +
----
 +
==== '''''effectiveDate''''' ====
 +
The date after which the Template can be considered for use.  Use of the Template prior to this date would be considered an invalid use of the Template.
  
 +
==== '''''expirationDate''''' ====
 +
The date at which the clincal concept represented by this Template becomes stale, and should be reviewed for clinical relevance and accuracy.  Use of the Template after this date would be considered venturesome.
  
 +
== '''Template Node Constraints''' ==
  
== '''Template Node Constraints''' ==
+
=== '''''templateNodeExplicit''''' ===
  
=== '''templateNode''' ===
 
 
Explicitly defines a node in the template constraint definition.  Template nodes are organised in a hierarchial structure.  The top level constraint node is known as the 'root template node' or the 'template'.
 
Explicitly defines a node in the template constraint definition.  Template nodes are organised in a hierarchial structure.  The top level constraint node is known as the 'root template node' or the 'template'.
  
==== '''templateNodeId''' ====
+
==== '''''templateNodeId''''' ====
 
A globally unique, non-semantic, identifier for the template node.  Within the context of HL7, a '''''templateNodeID''''' should take the form of an ISO Object Identifier (OID) or an HL7 Artifact ID.  
 
A globally unique, non-semantic, identifier for the template node.  Within the context of HL7, a '''''templateNodeID''''' should take the form of an ISO Object Identifier (OID) or an HL7 Artifact ID.  
  
==== '''templateNodeReferenceModelID ''' ====
+
==== '''''templateNodeReferenceModelID'' ''' ====
 
The globally unique identifier (ISO OID or HL7 Artifact ID) of the reference model against which the Template was developed. The underlying reference model may be A DIM, LIM, or Profile or Template
 
The globally unique identifier (ISO OID or HL7 Artifact ID) of the reference model against which the Template was developed. The underlying reference model may be A DIM, LIM, or Profile or Template
  
 
----
 
----
  
=== '''templateNodeReference''' ===
+
=== '''''templateNodeReference''''' ===
 +
 
 
References a template node that can be used in the template node hierarchy.  This may be referring to a template root node or a template node within an explicit template definition.
 
References a template node that can be used in the template node hierarchy.  This may be referring to a template root node or a template node within an explicit template definition.
  
==== '''inclusionRationale''' ====
+
==== '''''inclusionRationale''''' ====
 
Annotation as to the rationale for inclusion of this template node reference at this point in the hierarchy.
 
Annotation as to the rationale for inclusion of this template node reference at this point in the hierarchy.
  
==== '''templateReferenceId''' ====
+
==== '''''templateReferenceId''''' ====
 
A node reference may refer to another template, this identifer (ISO OID or HL7 Artifact ID) specifies the relevant template.
 
A node reference may refer to another template, this identifer (ISO OID or HL7 Artifact ID) specifies the relevant template.
 
A node reference may refer to another template node contained within a template, this identifier (ISO OID or HL7 Artifact ID) specifies the relevant containing template.
 
A node reference may refer to another template node contained within a template, this identifier (ISO OID or HL7 Artifact ID) specifies the relevant containing template.
  
==== '''templateNodeReferenceId''' ====
+
==== '''''templateNodeReferenceId''''' ====
 
A node reference may refer to a pre-existing template node by it's unique template node identifier (ISO OID or HL7 Artifact ID)
 
A node reference may refer to a pre-existing template node by it's unique template node identifier (ISO OID or HL7 Artifact ID)
 
The template node may be within the current template, or an external reference to a node within another template.
 
The template node may be within the current template, or an external reference to a node within another template.
 +
----
  
 +
=== '''''templateNodeConstrained''''' ===
 +
Another template node referenced by required attributes??  That is not defined by identifier but by rules governing allowed template nodes.
 
----
 
----
  
=== '''templateNodeConstrained''' ===
+
=== '''''templateNodeChoice''''' ===
Constrains allowed nodes based on the attributes of a template node definiton.
 
  
==== '''inclusionRationale''' ====
+
A node choice allows the selection of one of a set of possible choices, this may be an explicit '''''templateNode''''', reference '''''templateNodeReference''''', constrained refererence '''''templateNodeConstrained'''''. 
Annotation as to the rationale for inclusion of this template node constraint at this point in the hierarchy.
+
----
  
==== '''constraintStatement''' ====
+
=== '''''templateNodeConstraint''''' ===
Statement of the constraints placed on template nodes that are allowed to be included at this point in the template node hierarchy.
 
  
=== '''templateNodeChoice''' ===
+
Constrains allowed nodes based on the attributes of a template node definiton.  This inclusion constraint may be made against explicit or referenced template nodes.
A node choice allows the selection of one of a set of possible choices, this may be an explicit '''''templateNode''''', referrence '''''templateNodeReference''''' or constrained node '''''templateNodeConstrained'''''.
 
  
----
+
==== '''''inclusionRationale''''' ====
 +
Annotation as to the rationale for inclusion of this template node constraint at this point in the hierarchy.
  
=== '''Instantiation Constraint Rules''' ===
+
==== '''''constraintStatement''''' ====
''in progress''
+
Statement of the constraints placed on template nodes that are allowed to be instantiated at this point corresponding to template node hierarchy.
  
Constraint rules on an archetype node must identify the expression formalism employed.
+
===== '''cardinality''' =====
 +
Constraints on the number of instances that can be instantiated corresponding to this template node.
  
Constraint cardinality of an archetype node must be defined. (is this HL7 DT & RIM?)
+
===== '''logicalCondition''' =====
 +
Constraint rule expression statement.  This may include references to environmental parameters, relatively referenced instances or absolutely referenced instances.
  
Constraint rules may be specified to govern allowed archetype node instance creation.
+
===== '''expressionFormalism''' =====
 +
The expression formalism used to express the logical condition. Such as OWL, OCL, GELLO etc.
  
Constraints may be expressed as logical conditions referencing operating environment, or pre-existing archetype nodes in the instance hierarchy.
+
----
  
Constraint rules may be expressed as inclusion or exclusion criteria.  That is rule-in or rule-out instantiation of specified archetype node.
+
=== '''''codedTermBinding''''' ===
  
=== '''codedTermBinding''' ===
+
Every template node must be associated with at least one clinical term. 
''in progress''
 
  
Every archetype node must be associated with at least one clinical term.  (can all nodes be bound to clinical concepts?)
+
Issue: not all nodes can be bound to clinical concepts
  
 
Each archetype node may be associated with additional clincal concepts, terms, or synonyms.
 
Each archetype node may be associated with additional clincal concepts, terms, or synonyms.
Line 155: Line 191:
  
 
Any referenced coded term must include code, code system (OID), and display name text.
 
Any referenced coded term must include code, code system (OID), and display name text.
 +
----
  
=== '''Reference Model Association Constraints''' ===
+
=== '''''attributeConstraints''''' ===
''in progress''
 
  
Name of the association for which this archetype node was ideally fashioned may be defined.
+
A template node may specify constraints on attributes corresponding to a reference model.
  
Label of type of association (code) for which this archetype node was ideally fashioned may be defined.
+
This covers the case where RIM class attributes are constrained further as required by a particular template. This includes:
 +
* Restricting cardinality e.g. 0..* to 1..1
 +
* Restricting a data type to a specialisation e.g. GTS to TS (this is the equivalent to Data Type flavours)
 +
Issue: this now asserts that datatypes are definately part of the reference model; NOT data values as examined in the next section.
  
Cardinality constraints may be defined on instantiation of associations.
 
  
Other constraints or rules may be specified in a desired expression formalism. (including plain text? allowed formalism?)
+
==== '''''attributeName''''' ====
 +
Name of the attribute corresponding to the underlying reference model.
  
=== '''Reference Model Attribute Constraints''' ===
+
==== '''''attributeCode''''' ====
''in progress''
+
Label/code of type of attribute describing its context. This may be role code, type code, etc.
 
 
Name of the attribute for which this archetype node was ideally fashioned may be defined.
 
 
 
Label of type of attribute for which this archetype node was ideally fashioned may be defined.
 
  
 +
==== '''''cardinality''''' ====
 
Cardinality constraints may be defined on instantiation of attributes.
 
Cardinality constraints may be defined on instantiation of attributes.
  
Multiple instances can be specified as unordered list, ordered list or a unique instance set. (need to refer to HL7 collections)
+
==== '''''instantiationConstraint''''' ====
  
Constraints may be made on leaf attributes.
+
Other constraints or rules may be specified in a desired expression formalism.  
  
Other constraints or rules may be specified in a desired expression formalism. (including plain text? allowed formalism?)
+
==== '''''collectionType''''' ====
 +
Multiple instances can be specified as unordered list, ordered list or a unique instance set.
  
Constraints may be made on data value leaf nodes. Data-type value restriction.
+
== '''HL7 Template Data Value Constraints''' ==
  
== HL7 Template Data Value Constraints ==
+
=== '''structuralAttributeConstraints''' ===
 +
----
 +
It must be possible to specify constraints and rules for the Structural Attributes within the Reference Information Model.
  
=== It must be possible to specify constraints and rules for the Structural Attributes and Data Values within the Reference Information Model. ===
+
- in process
  
=== It must be possible to specify data value constraint information, including: ===
+
=== dataValueConstraints ===
 +
----
 +
It must be possible to specify data value constraint information, including:
  
==== Null and null flavor values as well as an optional reason to specify a null flavor value. ====
+
* Null and null flavor values as well as an optional reason to specify a null flavor value.  
  
==== If the constraint or rule specifies inclusion or exclusion criteria. ====
+
* If the constraint or rule specifies inclusion or exclusion criteria.
  
==== The formalism (including version) in which this constraint specification is represented. ====
+
* The formalism (including version) in which this constraint specification is represented.
  
==== The intended fixed (prescribed) value for conforming instances. ====
+
* The intended fixed (prescribed) value for conforming instances.
  
==== The intended default value for conforming instances. ====
+
* The intended default value for conforming instances.
 
 
==== A list of permitted candidate values for conforming instances (i.e. to be a subset of those vales legally permissible in the underlying Reference Model.) ====
 
  
 +
* A list of permitted candidate values for conforming instances (i.e. to be a subset of those vales legally permissible in the underlying Reference Model.)
  
 
=== Quantity data types must be able to specify ===
 
=== Quantity data types must be able to specify ===
 +
----
  
==== A value range where the value(s) for conforming instances must be inclusive; ====
+
==== '''''inclusiveQuantity''''' ====  
 
+
A value range where the value(s) for conforming instances must be inclusive;
==== A value range where the value(s) for conforming instances must be exclusive; ====
 
 
 
  
==== A range within which values are considered to be clinically exceptional or critical. ====
+
==== exclusiveQuantity ====  
 +
A value range where the value(s) for conforming instances must be exclusive;
  
==== A range within which values are considered to be clinically exceptional or critical. ====
+
==== '''''inclusiveCritical''''' ====
 +
A range within which values are considered to be clinically exceptional or critical.  
  
 +
==== '''''exclusiveCritical''''' ====
 +
A range ouside of which values are considered to be clinically exceptional or critical.
  
 
=== Date data types must be able to specify ===
 
=== Date data types must be able to specify ===
 +
----
 +
==== '''''inclusiveDateValueRange''''' ====
 +
A value range where the value(s) for conforming instances must be inclusive;
  
==== A value range where the value(s) for conforming instances must be inclusive; ====
+
==== '''''exclusiveDateValueRange''''' ====  
 
+
A value range where the value(s) for conforming instances must be exclusive;
==== A value range where the value(s) for conforming instances must be exclusive; ====
 
 
 
==== The intended measurement units for conforming instances. ====
 
  
 +
==== '''''dataValueUnits''''' ====
 +
The intended measurement units for conforming instances.
  
 
=== Textual Data Types ===
 
=== Textual Data Types ===
 +
----
  
==== A Regular Expression pattern defining the range of possible values for a String. ====
+
==== '''''regularExpression''''' ====
 +
A Regular Expression pattern defining the range of possible values for a String.
  
==== The intended coding scheme to be used for conforming instances. ====
+
==== '''''codingScheme''''' ====
 +
----
 +
The intended coding scheme to be used for conforming instances for the textual data.
  
 +
=== Logic Operators ===
 +
----
 +
Constraint rules might be expressed using logical operators, and may include reference to environment parameters such as the current time or location or participants, or be related to the (preexisting) values other nodes in the instance hierarchy.  Relative constraints may be nested, and include logical or set operators in order to represent compound rules.
 +
<ul>
 +
<p><li>Logical operators can be applied to a set of assertions to indicate which assertions in the set must be true or false.
 +
Example: (All | at least X | at most X | exactly X) of the assertions contained in this set must be (true | false).</p>
 +
</ul>
  
=== Constraint rules might be expressed as logical conditions, and may include reference to environment parameters such as the current time or location or participants, or be related to the (preexisting) values other nodes in the instance hierarchy. ===
+
=== '''Template Reference''' ===
 +
----
 +
The reference to a preexisting value must specify that instance precisely and unambiguously.
  
=== The reference to a preexisting value must specify that instance precisely and unambiguously. ===
+
==== '''''templateID''''' ====  
 
+
The Template identifier ('''''templateID''''') for the Template being referenced
==== The Template identifier ('''''templateID''''') for the Template being referenced ====
 
  
 
==== The occurrence in the instance hierarchy ====
 
==== The occurrence in the instance hierarchy ====
Line 245: Line 302:
 
* lowest value
 
* lowest value
 
* one or more instances within a definable time value
 
* one or more instances within a definable time value
 
 
=== Relative constraints may be nested, and include logical or set operators in order to represent compound rules. ===
 
 
 
 
  
 
== Template Assertions ==
 
== Template Assertions ==
Line 301: Line 352:
 
<p><li>Items in a template and constituent archetypes can be “ordered” or “unordered”. In an ordered template and archetype, the order of the stated assertions is important. In an unordered template and archetype, the order is not important.<br>
 
<p><li>Items in a template and constituent archetypes can be “ordered” or “unordered”. In an ordered template and archetype, the order of the stated assertions is important. In an unordered template and archetype, the order is not important.<br>
 
'''Example:''' Assertion One: There is a nested act under observationOne that has an observation.cd for “hemoglobin”. Assertion Two: There is a nested act under observationOne that has an observation.cd for “hematocrit. If the template and constituent archetypes are “ordered”, the “hemoglobin” must come before the “hematocrit”. If the template and constituent archetypes is “unordered” the “hemoglobin” can come before or after the “hematocrit”.</p>
 
'''Example:''' Assertion One: There is a nested act under observationOne that has an observation.cd for “hemoglobin”. Assertion Two: There is a nested act under observationOne that has an observation.cd for “hematocrit. If the template and constituent archetypes are “ordered”, the “hemoglobin” must come before the “hematocrit”. If the template and constituent archetypes is “unordered” the “hemoglobin” can come before or after the “hematocrit”.</p>
</ul>
 
 
 
 
=== Logic Assertions ===
 
----
 
<ul>
 
<p><li>Logical operators can be applied to a set of assertions to indicate which assertions in the set must be true or false.
 
Example: (All | at least X | at most X | exactly X) of the assertions contained in this set must be (true | false).</p>
 
 
</ul>
 
</ul>

Latest revision as of 13:58, 18 July 2012

HL7 V3 Templates maintain a set of functional requirements. What is the list of functional requirements required of Templates for use in HL7?

This document does not discuss implimentation of these requirements, which will be addressed in a different document.


Disclaimer


The purpose of this work - working through the joint CEN and openEHR Archetype Requirements in detail - is to provide the basis of understanding for the requirements of HL7 Templates only. This work is NOT intended to be the formal HL7 Templates requirements document.

The CEN/openEHR Requirements are here: http://www.cen.eu/cen/Members/Pages/default.aspx


Acknowledgements


The specification of HL7 templates defined here has been produced under work program of the HL7 Templates Special Interest Group. It has been greatly influenced by the work contained within the CEN 13606-2:2005 (Annex A) draft standard which defines formal requirements for 'archetype' representation. Representatives of the CEN and openEHR standards working group have supplied this in the interest of harmonisation of CEN and HL7 standards work in the templates area. Many thanks to Dr Dipak Kalra for his support of this process and continuing engagement with HL7, CEN, and openEHR harmonisation work.


Contents

HL7 Template Metadata

Identification Metadata - Mandatory


TemplateId

A globally unique, non-semantic, identifier for the Template. This is the primary identifier for all Templates.

templateName

A free text natural language name identifying the Template. It is anticipated that there will be far too many templates to be able to assign a unique mnemonic or meaningful name to all of them. This is the secondary identifier for all Templates. (Refer to templateCodedTerm.)

originatingAuthorEntityID

A globally unique non-semantic identifier for the original author of the Template.

NOTE: Determining the form of the ID and its issuer etc is necessary but out of scope for the Templates SIG.

templateIntention

A free text natural language description of the intent and scope of the Template. The purpose is to provide the author’s initial intent for the Template.

Example: The intention may include the Realm or sub-realm within which the Template was designed to be used for.

NOTE: A change to the semantic meaning or intent of a Template will constitute a new Template, not a new version of the Template.

templateVersion

The version identifier for the Template. The ability to determine the correct version of a Template is essential to its identification.

NOTE: Changes to the Template that do not change the semantis or intention of the Template will constitute a new version of the Template being created. Any change to the semantic meaning of the Template will constitute the creation of a new Template.

templateReferenceModelID

The globally unique identifier of the reference model against which the Template was developed. The underlying reference model may be A DIM, LIM, or Profile or Template.

templateRepositoryIdentifier

The identifier of the repository where the Template is located. This is a required metadata item since the core functional purpose of a Template is reuse, and things in general are much harder to reuse when they cannot be easily located.

Open Issue: What form should this identifier take? This will be addressed in the Template Implimentation guide, and will likely be ITS dependent.

templateRegistrationAuthority

The identifier of the registration authority (organization, institution, committee, or individual ) for the Template.

Open Issues: What are registration rules? What is the relationship between the repository and registration? What is the purpose of regsistration?

Identification Metadata - Optional


templateCodedTerm

The coded concept that uniquely represents the templateName within a given code system. A concept code can be assigned to an entire Template, providing it with a language independent method of secondary indentification. This can be used in conjunction with the templateName to convey the intended purpose and use of the template. (Refer to templateName.) The same templateCodedTerm and templateName may be used in multiple Templates.

Description Metadata – Mandatory


descriptionLanguage

The natural language in which the Template is represented.

templateDescription

A free text natural language description of the intent and scope of the Template. The purpose is to provide the author’s initial intent for the Template.

Description Metadata – Optional


implementationFormat

The preferred format that the Template should be implemented in from an ITS perspective. Implementation formats other than that recommended(if any) are not deemed suitable for this Template by the publishingAuthority. Other implementation formats are possible, but it is the responsibility of the translator to make the tralation to the new format, not that of the publishingAuthority.

evidenceSource

A description, reference or link to the published medical knowledge that was used in the definition of this Template.

detailedDescription

A detailed explanation of the purpose of this Template, including features of intrest. This may include an indication of the intended user group for which this definition is intended.

cautionPoints

A formal statement regarding when this Template should not be used, or may be used erroneously. To define roles where the Template should not be used, or should be used with care. This field is used to expand in detail on the templateIntention.

Publication Metadata – Mandatory


publicationStatus

The current publication status for the template.

  • Development
  • Test
  • Private
  • Public
  • Preferred
  • Former
  • Deprecated

publicationStatusChangeDate

The date that the current value for publicationStatus was applied of the Template.

publisher

The name of the author(s) institutional affiliations and contact infomation for the creators of the Template.

publishingAuthority

The autoritative body who has reviewed the Template for clinical accuracy and relevance, and autorized it for publication.

revisionHistory

The free text description describing the changes in this version of the Template as compared to the previous version. Since Template versions are built off of previous versions, the net effect of this field is to function as a comprehensive historical reference of the Template.

Publication Metadata – Optional


effectiveDate

The date after which the Template can be considered for use. Use of the Template prior to this date would be considered an invalid use of the Template.

expirationDate

The date at which the clincal concept represented by this Template becomes stale, and should be reviewed for clinical relevance and accuracy. Use of the Template after this date would be considered venturesome.

Template Node Constraints

templateNodeExplicit

Explicitly defines a node in the template constraint definition. Template nodes are organised in a hierarchial structure. The top level constraint node is known as the 'root template node' or the 'template'.

templateNodeId

A globally unique, non-semantic, identifier for the template node. Within the context of HL7, a templateNodeID should take the form of an ISO Object Identifier (OID) or an HL7 Artifact ID.

templateNodeReferenceModelID

The globally unique identifier (ISO OID or HL7 Artifact ID) of the reference model against which the Template was developed. The underlying reference model may be A DIM, LIM, or Profile or Template


templateNodeReference

References a template node that can be used in the template node hierarchy. This may be referring to a template root node or a template node within an explicit template definition.

inclusionRationale

Annotation as to the rationale for inclusion of this template node reference at this point in the hierarchy.

templateReferenceId

A node reference may refer to another template, this identifer (ISO OID or HL7 Artifact ID) specifies the relevant template. A node reference may refer to another template node contained within a template, this identifier (ISO OID or HL7 Artifact ID) specifies the relevant containing template.

templateNodeReferenceId

A node reference may refer to a pre-existing template node by it's unique template node identifier (ISO OID or HL7 Artifact ID) The template node may be within the current template, or an external reference to a node within another template.


templateNodeConstrained

Another template node referenced by required attributes?? That is not defined by identifier but by rules governing allowed template nodes.


templateNodeChoice

A node choice allows the selection of one of a set of possible choices, this may be an explicit templateNode, reference templateNodeReference, constrained refererence templateNodeConstrained.


templateNodeConstraint

Constrains allowed nodes based on the attributes of a template node definiton. This inclusion constraint may be made against explicit or referenced template nodes.

inclusionRationale

Annotation as to the rationale for inclusion of this template node constraint at this point in the hierarchy.

constraintStatement

Statement of the constraints placed on template nodes that are allowed to be instantiated at this point corresponding to template node hierarchy.

cardinality

Constraints on the number of instances that can be instantiated corresponding to this template node.

logicalCondition

Constraint rule expression statement. This may include references to environmental parameters, relatively referenced instances or absolutely referenced instances.

expressionFormalism

The expression formalism used to express the logical condition. Such as OWL, OCL, GELLO etc.


codedTermBinding

Every template node must be associated with at least one clinical term.

Issue: not all nodes can be bound to clinical concepts

Each archetype node may be associated with additional clincal concepts, terms, or synonyms.

Coded term (mapping?) purpose must be labelled: - prinicpal concept - code system translation - language translation - synonym

Any referenced coded term must include code, code system (OID), and display name text.


attributeConstraints

A template node may specify constraints on attributes corresponding to a reference model.

This covers the case where RIM class attributes are constrained further as required by a particular template. This includes:

  • Restricting cardinality e.g. 0..* to 1..1
  • Restricting a data type to a specialisation e.g. GTS to TS (this is the equivalent to Data Type flavours)

Issue: this now asserts that datatypes are definately part of the reference model; NOT data values as examined in the next section.


attributeName

Name of the attribute corresponding to the underlying reference model.

attributeCode

Label/code of type of attribute describing its context. This may be role code, type code, etc.

cardinality

Cardinality constraints may be defined on instantiation of attributes.

instantiationConstraint

Other constraints or rules may be specified in a desired expression formalism.

collectionType

Multiple instances can be specified as unordered list, ordered list or a unique instance set.

HL7 Template Data Value Constraints

structuralAttributeConstraints


It must be possible to specify constraints and rules for the Structural Attributes within the Reference Information Model.

- in process

dataValueConstraints


It must be possible to specify data value constraint information, including:

  • Null and null flavor values as well as an optional reason to specify a null flavor value.
  • If the constraint or rule specifies inclusion or exclusion criteria.
  • The formalism (including version) in which this constraint specification is represented.
  • The intended fixed (prescribed) value for conforming instances.
  • The intended default value for conforming instances.
  • A list of permitted candidate values for conforming instances (i.e. to be a subset of those vales legally permissible in the underlying Reference Model.)

Quantity data types must be able to specify


inclusiveQuantity

A value range where the value(s) for conforming instances must be inclusive;

exclusiveQuantity

A value range where the value(s) for conforming instances must be exclusive;

inclusiveCritical

A range within which values are considered to be clinically exceptional or critical.

exclusiveCritical

A range ouside of which values are considered to be clinically exceptional or critical.

Date data types must be able to specify


inclusiveDateValueRange

A value range where the value(s) for conforming instances must be inclusive;

exclusiveDateValueRange

A value range where the value(s) for conforming instances must be exclusive;

dataValueUnits

The intended measurement units for conforming instances.

Textual Data Types


regularExpression

A Regular Expression pattern defining the range of possible values for a String.

codingScheme


The intended coding scheme to be used for conforming instances for the textual data.

Logic Operators


Constraint rules might be expressed using logical operators, and may include reference to environment parameters such as the current time or location or participants, or be related to the (preexisting) values other nodes in the instance hierarchy. Relative constraints may be nested, and include logical or set operators in order to represent compound rules.

  • Logical operators can be applied to a set of assertions to indicate which assertions in the set must be true or false. Example: (All | at least X | at most X | exactly X) of the assertions contained in this set must be (true | false).

Template Reference


The reference to a preexisting value must specify that instance precisely and unambiguously.

templateID

The Template identifier (templateID) for the Template being referenced

The occurrence in the instance hierarchy

  • First
  • Most Recent
  • Any
  • N ordered by Y (the nth set of instances ordered on y)
  • highest value
  • lowest value
  • one or more instances within a definable time value

Template Assertions

Static assertions


  • A template can constrain the cardinality of a clone’s association.
  • A template can constrain the cardinality of a clone’s attribute.
  • A template can constrain the allowable date/time values in a date/time field.
  • A template can constrain any attribute value to be a subset of those values legally permissible in the specification being constrained.
  • A template can constrain the range of allowable date/time values for attributes valued by date/time data types.
  • A template can constrain the range of allowable code values for attributes valued by terminology concepts.
  • A template can constrain the range of allowable numbers for attributes valued by numbers.
  • A template can express a regular expression constraint on attributes valued by strings.
  • A template can constrain any data type component, including recursively-nested components.
  • A template can constrain the range of allowable values of a clone’s attribute.
  • All additional constraints that can be expressed in a normative specification (including all the columns in an HMD) can be further constrained in a template.

Co-occurrence Assertions


  • The value of one field can be constrained based on the value of another field.
    Example: If fieldOne is “X”, then fieldTwo’s value must be “A”.

  • Chronological assertions can constrain the date/time value of one field based on the date/time of another field.
    Example: The start time for fieldOne is (earlier | later | equal to) the start time of fieldTwo.

  • Numeric comparison assertions can constrain the numeric value of one field based on the value of another field.
    Example: The value of fieldOne is (equal to | less than | greater than) the value of fieldTwo.

  • Numeric operation assertions can constrain the numeric value of one field based on a numeric operator applied to the value of another field or constant.
    Example: The value of fieldOne is (equal to | less than | greater than) the value of fieldTwo (plus 7 | divided by 27).

  • String comparison assertions can constrain the string value of one field based on the value of another field.
    Example: The string value of fieldOne is contained in the value of fieldTwo.

  • Any constraint a template and constituent archetypes can make can be made dependent on the value expressed in one or more other fields. For instance, in addition to constraining the cardinality of an association, a template and constituent archetypes can constrain the cardinality based on the value in a particular field.
    Example: If ((fieldOne is “X” or “Y”) OR (fieldTwo is “ABC”)) then ((a nested act relationship under Observation is required) AND (fieldThree in the nested act has a value of “A” or “B” or “C”) AND (fieldThree in the nested act cannot be NULL)).


Containment Assertions


  • Data descendant assertions can constrain allowable depth at which one component is nested within another component.
    Example: The vital-signs section must be (a direct child of | some descendant of | less than a depth of X from) the physical-exam section.

  • Items in a template and constituent archetypes can be “ordered” or “unordered”. In an ordered template and archetype, the order of the stated assertions is important. In an unordered template and archetype, the order is not important.
    Example: Assertion One: There is a nested act under observationOne that has an observation.cd for “hemoglobin”. Assertion Two: There is a nested act under observationOne that has an observation.cd for “hematocrit. If the template and constituent archetypes are “ordered”, the “hemoglobin” must come before the “hematocrit”. If the template and constituent archetypes is “unordered” the “hemoglobin” can come before or after the “hematocrit”.