WHO Immunization Implementation Guide
1.0.0 - release

WHO Immunization Implementation Guide, published by WHO. This guide is not an authorized publication; it is the continuous build for version 1.0.0 built by the FHIR (HL7® FHIR® Standard) CI Build. This version is based on the current content of https://github.com/WorldHealthOrganization/smart-immunizations/tree/132/merge and changes regularly. See the Directory of published versions

: WHOCommon - TTL Representation

Draft as of 2026-03-31

Raw ttl | Download

@prefix fhir: <http://hl7.org/fhir/> .
@prefix owl: <http://www.w3.org/2002/07/owl#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .

# - resource -------------------------------------------------------------------

 a fhir:Library ;
  fhir:nodeRole fhir:treeRoot ;
  fhir:id [ fhir:v "WHOCommon"] ; # 
  fhir:meta [
    ( fhir:profile [
fhir:v "http://hl7.org/fhir/uv/crmi/StructureDefinition/crmi-shareablelibrary"^^xsd:anyURI ;
fhir:l <http://hl7.org/fhir/uv/crmi/StructureDefinition/crmi-shareablelibrary>     ] [
fhir:v "http://hl7.org/fhir/uv/crmi/StructureDefinition/crmi-publishablelibrary"^^xsd:anyURI ;
fhir:l <http://hl7.org/fhir/uv/crmi/StructureDefinition/crmi-publishablelibrary>     ] [
fhir:v "http://hl7.org/fhir/uv/cql/StructureDefinition/cql-library"^^xsd:anyURI ;
fhir:l <http://hl7.org/fhir/uv/cql/StructureDefinition/cql-library>     ] [
fhir:v "http://hl7.org/fhir/uv/cql/StructureDefinition/cql-module"^^xsd:anyURI ;
fhir:l <http://hl7.org/fhir/uv/cql/StructureDefinition/cql-module>     ] )
  ] ; # 
  fhir:text [
fhir:status [ fhir:v "extensions" ] ;
fhir:div [ fhir:v "<div xmlns=\"http://www.w3.org/1999/xhtml\">\n<div>\n    <table class=\"grid dict\">\n        \n        \n        <tr>\n            <th scope=\"row\"><b>Title: </b></th>\n            <td style=\"padding-left: 4px;\">WHOCommon</td>\n        </tr>\n        \n\n        \n        \n        <tr>\n            <th scope=\"row\"><b>Id: </b></th>\n            <td style=\"padding-left: 4px;\">WHOCommon</td>\n        </tr>\n        \n\n        \n        \n        <tr>\n            <th scope=\"row\"><b>Version: </b></th>\n            <td style=\"padding-left: 4px;\">1.0.0</td>\n        </tr>\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Url: </b></th>\n            <td style=\"padding-left: 4px;\"><a href=\"Library-WHOCommon.html\">WHOCommon</a></td>\n        </tr>\n        \n\n        \n\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Status: </b></th>\n            <td style=\"padding-left: 4px;\">draft</td>\n        </tr>\n        \n\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Type: </b></th>\n            <td style=\"padding-left: 4px;\">\n                \n                    \n                        \n                        <p style=\"margin-bottom: 5px;\">\n                            <b>system: </b> <span><a href=\"http://terminology.hl7.org/7.1.0/CodeSystem-library-type.html\">http://terminology.hl7.org/CodeSystem/library-type</a></span>\n                        </p>\n                        \n                        \n                        <p style=\"margin-bottom: 5px;\">\n                            <b>code: </b> <span>logic-library</span>\n                        </p>\n                        \n                        \n                    \n                \n                \n            </td>\n        </tr>\n        \n\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Date: </b></th>\n            <td style=\"padding-left: 4px;\">2026-03-31 13:54:17+0000</td>\n        </tr>\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Publisher: </b></th>\n            <td style=\"padding-left: 4px;\">WHO</td>\n        </tr>\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Description: </b></th>\n            <td style=\"padding-left: 4px;\"><div><p>This library defines common terminologies and functions used throughout WHO SMART Guidelines content</p>\n</div></td>\n        </tr>\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n\n        \n        <tr>\n            <th scope=\"row\"><b>Related Artifacts: </b></th>\n            <td style=\"padding-left: 4px;\">\n                \n                \n                \n                <p><b>Dependencies</b></p>\n                <ul>\n                  \n                    <li><a href=\"http://terminology.hl7.org/7.1.0/CodeSystem-condition-clinical.html\">Condition Clinical Status Codes</a></li>\n                  \n                </ul>\n                \n                \n                \n                \n                \n            </td>\n        </tr>\n        \n\n        \n        <tr>\n          <th scope=\"row\"><b>Parameters: </b></th>\n          <td style=\"padding-left: 4px;\">\n            <table class=\"grid-dict\">\n              <tr><th><b>Name</b></th><th><b>Type</b></th><th><b>Min</b></th><th><b>Max</b></th><th><b>In/Out</b></th></tr>\n              \n                <tr><th>Patient</th><th>Patient</th><th>0</th><th>1</th><th>Out</th></tr>\n              \n            </table>\n          </td>\n        </tr>\n        \n\n        \n\n        \n        \n        <tr>\n          <td colspan=\"2\">\n            <table>\n              <tr><th><a id=\"cql-content\"><b>Content: </b></a> text/cql</th></tr>\n              <tr><td><pre><code class=\"language-cql\">library WHOCommon#xD;\n#xD;\nusing FHIR version '4.0.1'#xD;\n#xD;\ninclude FHIRHelpers version '4.0.1'#xD;\n#xD;\ncodesystem \"ConditionClinicalStatusCodes\": 'http://terminology.hl7.org/CodeSystem/condition-clinical'#xD;\n#xD;\n// Condition Clinical Status Codes - Consider value sets for these#xD;\ncode \"active\": 'active' from \"ConditionClinicalStatusCodes\"#xD;\ncode \"recurrence\": 'recurrence' from \"ConditionClinicalStatusCodes\"#xD;\ncode \"relapse\": 'relapse' from \"ConditionClinicalStatusCodes\"#xD;\ncode \"inactive\": 'inactive' from \"ConditionClinicalStatusCodes\"#xD;\ncode \"remission\": 'remission' from \"ConditionClinicalStatusCodes\"#xD;\ncode \"resolved\": 'resolved' from \"ConditionClinicalStatusCodes\"#xD;\n#xD;\ncontext Patient#xD;\n#xD;\ndefine fluent function official(identifiers List&lt;Identifier&gt;):#xD;\n  singleton from (identifiers I where I.use = 'official')#xD;\n#xD;\ndefine fluent function official(addresses List&lt;Address&gt;):#xD;\n  singleton from (addresses A where A.use = 'official')#xD;\n#xD;\ndefine fluent function official(names List&lt;HumanName&gt;):#xD;\n  singleton from (names N where N.use = 'official')#xD;\n#xD;\ndefine fluent function mobile(contactPoints List&lt;ContactPoint&gt;):#xD;\n  singleton from (contactPoints P where P.use = 'mobile')#xD;\n#xD;\ndefine fluent function only(allergies List&lt;AllergyIntolerance&gt;):#xD;\n  singleton from allergies#xD;\n#xD;\ndefine fluent function only(appointments List&lt;Appointment&gt;):#xD;\n  singleton from appointments#xD;\n#xD;\ndefine fluent function only(careplans List&lt;CarePlan&gt;):#xD;\n  singleton from careplans#xD;\n#xD;\ndefine fluent function only(conditions List&lt;Condition&gt;):#xD;\n  singleton from conditions#xD;\n#xD;\ndefine fluent function only(encounters List&lt;Encounter&gt;):#xD;\n  singleton from encounters#xD;\n#xD;\ndefine fluent function only(immunizations List&lt;Immunization&gt;):#xD;\n  singleton from immunizations#xD;\n#xD;\ndefine fluent function only(locations List&lt;Location&gt;):#xD;\n  singleton from locations#xD;\n#xD;\ndefine fluent function only(medicationrequests List&lt;MedicationRequest&gt;):#xD;\n  singleton from medicationrequests#xD;\n#xD;\ndefine fluent function only(observations List&lt;Observation&gt;):#xD;\n  singleton from observations#xD;\n#xD;\ndefine fluent function only(procedures List&lt;Procedure&gt;):#xD;\n  singleton from procedures#xD;\n#xD;\ndefine fluent function only(serviceRequests List&lt;ServiceRequest&gt;):#xD;\n  singleton from serviceRequests#xD;\n#xD;\ndefine fluent function only(dosages List&lt;Dosage&gt;):#xD;\n  singleton from dosages#xD;\n#xD;\ndefine fluent function only(doses List&lt;FHIR.Dosage.DoseAndRate&gt;):#xD;\n  singleton from doses#xD;\n#xD;\ndefine fluent function earliest(observations List&lt;Observation&gt;):#xD;\n  First(#xD;\n    observations O#xD;\n      sort by issued#xD;\n  )#xD;\n#xD;\ndefine fluent function earliest(immunizations List&lt;Immunization&gt;):#xD;\n  First(#xD;\n    immunizations I#xD;\n      sort by start of occurrence.toInterval()#xD;\n  )#xD;\n#xD;\n#xD;\ndefine fluent function latest(observations List&lt;Observation&gt;):#xD;\n  Last(#xD;\n    observations O#xD;\n      sort by issued#xD;\n  )#xD;\n#xD;\ndefine fluent function mostRecent(observations List&lt;Observation&gt;):#xD;\n  Last(#xD;\n    observations O#xD;\n      sort by issued#xD;\n  )#xD;\n#xD;\ndefine fluent function mostRecent(procedures List&lt;Procedure&gt;):#xD;\n  Last(#xD;\n    procedures P#xD;\n      sort by start of performed.toInterval()#xD;\n  )#xD;\n#xD;\ndefine fluent function mostRecent(immunizations List&lt;Immunization&gt;):#xD;\n  Last(#xD;\n    immunizations I#xD;\n      sort by start of occurrence.toInterval()#xD;\n  )#xD;\n#xD;\ndefine fluent function mostRecent(medicationRequests List&lt;MedicationRequest&gt;):#xD;\n  Last(#xD;\n    medicationRequests MR#xD;\n      sort by authoredOn#xD;\n  )#xD;\n#xD;\ndefine fluent function lowest(observations List&lt;Observation&gt;):#xD;\n  First(#xD;\n    observations O#xD;\n      sort by FHIRHelpers.ToQuantity(value as FHIR.Quantity)#xD;\n  )#xD;\n#xD;\ndefine fluent function highest(observations List&lt;Observation&gt;):#xD;\n  Last(#xD;\n    observations O#xD;\n      sort by FHIRHelpers.ToQuantity(value as FHIR.Quantity)#xD;\n  )#xD;\n#xD;\ndefine fluent function complete(observations List&lt;Observation&gt;):#xD;\n  observations O where O.status in { 'final', 'amended', 'corrected' }#xD;\n#xD;\ndefine function EarliestOf(dates List&lt;Date&gt;):#xD;\n  Min(dates)#xD;\n#xD;\ndefine function LatestOf(dates List&lt;Date&gt;):#xD;\n  Max(dates)#xD;\n#xD;\n/*#xD;\nFrom FHIRCommon 4.1.0:#xD;\n*/#xD;\n#xD;\n/*#xD;\n@description: Normalizes a value that is a choice of timing-valued types to an equivalent interval#xD;\n@comment: Normalizes a choice type of FHIR.dateTime, FHIR.Period, FHIR.Timing, FHIR.instance, FHIR.string, FHIR.Age, or FHIR.Range types#xD;\nto an equivalent interval. This selection of choice types is a superset of the majority of choice types that are used as possible#xD;\nrepresentations for timing-valued elements in FHIR, allowing this function to be used across any resource.#xD;\n#xD;\nThe input can be provided as a dateTime, Period, Timing, instant, string, Age, or Range.#xD;\nThe intent of this function is to provide a clear and concise mechanism to treat single#xD;\nelements that have multiple possible representations as intervals so that logic doesn't have to account#xD;\nfor the variability. More complex calculations (such as medication request period or dispense period#xD;\ncalculation) need specific guidance and consideration. That guidance may make use of this function, but#xD;\nthe focus of this function is on single element calculations where the semantics are unambiguous.#xD;\nIf the input is a dateTime, the result a DateTime Interval beginning and ending on that dateTime.#xD;\nIf the input is a Period, the result is a DateTime Interval.#xD;\nIf the input is a Timing, an error is raised indicating a single interval cannot be computed from a Timing.#xD;\nIf the input is an instant, the result is a DateTime Interval beginning and ending on that instant.#xD;\nIf the input is a string, an error is raised indicating a single interval cannot be computed from a string.#xD;\nIf the input is an Age, the result is a DateTime Interval beginning when the patient was the given Age,#xD;\nand ending immediately prior to when the patient was the given Age plus one year.#xD;\nIf the input is a Range, the result is a DateTime Interval beginning when the patient was the Age given#xD;\nby the low end of the Range, and ending immediately prior to when the patient was the Age given by the#xD;\nhigh end of the Range plus one year.#xD;\n#xD;\nNOTE: Due to the#xD;\ncomplexity of determining a single interval from a Timing or String type, this function will throw a run-time exception if it is used#xD;\nwith a Timing or String.#xD;\n*/#xD;\ndefine fluent function toInterval(choice Choice&lt;FHIR.dateTime, FHIR.Period, FHIR.Timing, FHIR.instant, FHIR.string, FHIR.Age, FHIR.Range&gt;):#xD;\n  case#xD;\n    when choice is FHIR.dateTime then#xD;\n      Interval[FHIRHelpers.ToDateTime(choice as FHIR.dateTime), FHIRHelpers.ToDateTime(choice as FHIR.dateTime)]#xD;\n    when choice is FHIR.Period then#xD;\n      FHIRHelpers.ToInterval(choice as FHIR.Period)#xD;\n    when choice is FHIR.instant then#xD;\n      Interval[FHIRHelpers.ToDateTime(choice as FHIR.instant), FHIRHelpers.ToDateTime(choice as FHIR.instant)]#xD;\n    when choice is FHIR.Age then#xD;\n      Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(choice as FHIR.Age),#xD;\n        FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(choice as FHIR.Age) + 1 year)#xD;\n    when choice is FHIR.Range then#xD;\n      Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((choice as FHIR.Range).low),#xD;\n        FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((choice as FHIR.Range).high) + 1 year)#xD;\n    when choice is FHIR.Timing then#xD;\n      Message(null as Interval&lt;DateTime&gt;, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a Timing value is not supported')#xD;\n    when choice is FHIR.string then#xD;\n      Message(null as Interval&lt;DateTime&gt;, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a String value is not supported')#xD;\n    else#xD;\n      null as Interval&lt;DateTime&gt;#xD;\n  end#xD;\n#xD;\n// Was getting error on this for this particular choice set not being found#xD;\n#xD;\n#xD;\n/*#xD;\n@description: Returns an interval representing the normalized Abatement of a given Condition resource.#xD;\n@comment: NOTE: Due to the complexity of determining an interval from a String, this function will throw#xD;\na run-time exception if used with a Condition instance that has a String as the abatement value.#xD;\n*/#xD;\ndefine fluent function abatementInterval(condition Condition):#xD;\n  if condition.abatement is FHIR.dateTime then#xD;\n    Interval[FHIRHelpers.ToDateTime(condition.abatement as FHIR.dateTime), FHIRHelpers.ToDateTime(condition.abatement as FHIR.dateTime)]#xD;\n  else if condition.abatement is FHIR.Period then#xD;\n    FHIRHelpers.ToInterval(condition.abatement as FHIR.Period)#xD;\n  else if condition.abatement is FHIR.string then#xD;\n    Message(null as Interval&lt;DateTime&gt;, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a String value is not supported')#xD;\n  else if condition.abatement is FHIR.Age then#xD;\n    Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(condition.abatement as FHIR.Age),#xD;\n      FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(condition.abatement as FHIR.Age) + 1 year)#xD;\n  else if condition.abatement is FHIR.Range then#xD;\n    Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((condition.abatement as FHIR.Range).low),#xD;\n      FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((condition.abatement as FHIR.Range).high) + 1 year)#xD;\n  else if condition.abatement is FHIR.boolean then#xD;\n    Interval[end of condition.onset.toInterval(), condition.recordedDate)#xD;\n  else #xD;\n    null#xD;\n#xD;\n/*#xD;\n@description: Returns an interval representing the normalized prevalence period of a given Condition resource.#xD;\n@comment: Uses the toInterval and toAbatementInterval functions to determine the widest potential interval from#xD;\nonset to abatement as specified in the given Condition.#xD;\n*/#xD;\ndefine fluent function prevalenceInterval(condition Condition):#xD;\nif condition.clinicalStatus ~ \"active\"#xD;\n  or condition.clinicalStatus ~ \"recurrence\"#xD;\n  or condition.clinicalStatus ~ \"relapse\" then#xD;\n  Interval[start of condition.onset.toInterval(), end of condition.abatementInterval()]#xD;\nelse#xD;\n  (end of condition.abatementInterval()) abatementDate#xD;\n    return #xD;\n	  if abatementDate is null then#xD;\n        Interval[start of condition.onset.toInterval(), abatementDate)#xD;\n      else#xD;\n        Interval[start of condition.onset.toInterval(), abatementDate]#xD;\n#xD;\n/*#xD;\n@description: Returns true if the given reference is to the given resource#xD;\n@comment: Returns true if the `id` element of the given resource exactly equals the tail of the given reference.#xD;\nNOTE: This function assumes resources from the same source server.#xD;\n*/#xD;\ndefine fluent function references(reference FHIR.Reference, resource FHIR.Resource):#xD;\n  resource.id = Last(Split(reference.reference, '/'))  #xD;\n#xD;\n/*#xD;\n@description: Returns true if the given reference is to the given resourceId#xD;\n@comment: Returns true if the `resourceId` parameter exactly equals the tail of the given reference.#xD;\nNOTE: This function assumes resources from the same source server.#xD;\n*/#xD;\ndefine fluent function references(reference FHIR.Reference, resourceId String):#xD;\n  resourceId = Last(Split(reference.reference, '/'))#xD;\n#xD;\n/*#xD;\n@description: Returns true if any of the given references are to the given resource#xD;\n@comment: Returns true if the `id` element of the given resource exactly equals the tail of any of the given references.#xD;\nNOTE: This function assumes resources from the same source server.#xD;\n*/#xD;\ndefine fluent function references(references List&lt;FHIR.Reference&gt;, resource FHIR.Resource):#xD;\n  exists (references R where R.references(resource))#xD;\n  #xD;\n/*#xD;\n@description: Returns true if any of the given references are to the given resourceId#xD;\n@comment: Returns true if the `resourceId` parameter exactly equals the tail of any of the given references.#xD;\nNOTE: This function assumes resources from the same source server.#xD;\n*/#xD;\ndefine fluent function references(references List&lt;FHIR.Reference&gt;, resourceId String):#xD;\n  exists (references R where R.references(resourceId))#xD;\n</code></pre></td></tr>\n            </table>\n          </td>\n        </tr>\n        \n        \n        \n    </table>\n</div>\n</div>"^^rdf:XMLLiteral ]
  ] ; # 
  fhir:extension ( [
fhir:url [
fhir:v "http://hl7.org/fhir/StructureDefinition/cqf-knowledgeCapability"^^xsd:anyURI ;
fhir:l <http://hl7.org/fhir/StructureDefinition/cqf-knowledgeCapability>     ] ;
fhir:value [
a fhir:Code ;
fhir:v "computable"     ]
  ] ) ; # 
  fhir:url [
fhir:v "http://smart.who.int/immunizations/Library/WHOCommon"^^xsd:anyURI ;
fhir:l <http://smart.who.int/immunizations/Library/WHOCommon>
  ] ; # 
  fhir:version [ fhir:v "1.0.0"] ; # 
  fhir:name [ fhir:v "WHOCommon"] ; # 
  fhir:title [ fhir:v "WHOCommon"] ; # 
  fhir:status [ fhir:v "draft"] ; # 
  fhir:experimental [ fhir:v false] ; # 
  fhir:type [
    ( fhir:coding [
fhir:system [
fhir:v "http://terminology.hl7.org/CodeSystem/library-type"^^xsd:anyURI ;
fhir:l <http://terminology.hl7.org/CodeSystem/library-type>       ] ;
fhir:code [ fhir:v "logic-library" ]     ] )
  ] ; # 
  fhir:date [ fhir:v "2026-03-31T13:54:17+00:00"^^xsd:dateTime] ; # 
  fhir:publisher [ fhir:v "WHO"] ; # 
  fhir:contact ( [
fhir:name [ fhir:v "WHO" ] ;
    ( fhir:telecom [
fhir:system [ fhir:v "url" ] ;
fhir:value [ fhir:v "http://who.int" ]     ] )
  ] ) ; # 
  fhir:description [ fhir:v "This library defines common terminologies and functions used throughout WHO SMART Guidelines content"] ; # 
  fhir:relatedArtifact ( [
fhir:type [ fhir:v "depends-on" ] ;
fhir:display [ fhir:v "Code System ConditionClinicalStatusCodes" ] ;
fhir:resource [
fhir:v "http://terminology.hl7.org/CodeSystem/condition-clinical"^^xsd:anyURI ;
fhir:l <http://terminology.hl7.org/CodeSystem/condition-clinical>     ]
  ] ) ; # 
  fhir:parameter ( [
fhir:name [ fhir:v "Patient" ] ;
fhir:use [ fhir:v "out" ] ;
fhir:min [ fhir:v 0 ] ;
fhir:max [ fhir:v "1" ] ;
fhir:type [ fhir:v "Patient" ]
  ] ) ; # 
  fhir:content ( [
fhir:contentType [ fhir:v "text/cql" ] ;
fhir:data [ fhir:v "library WHOCommon

using FHIR version '4.0.1'

include FHIRHelpers version '4.0.1'

codesystem "ConditionClinicalStatusCodes": 'http://terminology.hl7.org/CodeSystem/condition-clinical'

// Condition Clinical Status Codes - Consider value sets for these
code "active": 'active' from "ConditionClinicalStatusCodes"
code "recurrence": 'recurrence' from "ConditionClinicalStatusCodes"
code "relapse": 'relapse' from "ConditionClinicalStatusCodes"
code "inactive": 'inactive' from "ConditionClinicalStatusCodes"
code "remission": 'remission' from "ConditionClinicalStatusCodes"
code "resolved": 'resolved' from "ConditionClinicalStatusCodes"

context Patient

define fluent function official(identifiers List<Identifier>):
  singleton from (identifiers I where I.use = 'official')

define fluent function official(addresses List<Address>):
  singleton from (addresses A where A.use = 'official')

define fluent function official(names List<HumanName>):
  singleton from (names N where N.use = 'official')

define fluent function mobile(contactPoints List<ContactPoint>):
  singleton from (contactPoints P where P.use = 'mobile')

define fluent function only(allergies List<AllergyIntolerance>):
  singleton from allergies

define fluent function only(appointments List<Appointment>):
  singleton from appointments

define fluent function only(careplans List<CarePlan>):
  singleton from careplans

define fluent function only(conditions List<Condition>):
  singleton from conditions

define fluent function only(encounters List<Encounter>):
  singleton from encounters

define fluent function only(immunizations List<Immunization>):
  singleton from immunizations

define fluent function only(locations List<Location>):
  singleton from locations

define fluent function only(medicationrequests List<MedicationRequest>):
  singleton from medicationrequests

define fluent function only(observations List<Observation>):
  singleton from observations

define fluent function only(procedures List<Procedure>):
  singleton from procedures

define fluent function only(serviceRequests List<ServiceRequest>):
  singleton from serviceRequests

define fluent function only(dosages List<Dosage>):
  singleton from dosages

define fluent function only(doses List<FHIR.Dosage.DoseAndRate>):
  singleton from doses

define fluent function earliest(observations List<Observation>):
  First(
    observations O
      sort by issued
  )

define fluent function earliest(immunizations List<Immunization>):
  First(
    immunizations I
      sort by start of occurrence.toInterval()
  )


define fluent function latest(observations List<Observation>):
  Last(
    observations O
      sort by issued
  )

define fluent function mostRecent(observations List<Observation>):
  Last(
    observations O
      sort by issued
  )

define fluent function mostRecent(procedures List<Procedure>):
  Last(
    procedures P
      sort by start of performed.toInterval()
  )

define fluent function mostRecent(immunizations List<Immunization>):
  Last(
    immunizations I
      sort by start of occurrence.toInterval()
  )

define fluent function mostRecent(medicationRequests List<MedicationRequest>):
  Last(
    medicationRequests MR
      sort by authoredOn
  )

define fluent function lowest(observations List<Observation>):
  First(
    observations O
      sort by FHIRHelpers.ToQuantity(value as FHIR.Quantity)
  )

define fluent function highest(observations List<Observation>):
  Last(
    observations O
      sort by FHIRHelpers.ToQuantity(value as FHIR.Quantity)
  )

define fluent function complete(observations List<Observation>):
  observations O where O.status in { 'final', 'amended', 'corrected' }

define function EarliestOf(dates List<Date>):
  Min(dates)

define function LatestOf(dates List<Date>):
  Max(dates)

/*
From FHIRCommon 4.1.0:
*/

/*
@description: Normalizes a value that is a choice of timing-valued types to an equivalent interval
@comment: Normalizes a choice type of FHIR.dateTime, FHIR.Period, FHIR.Timing, FHIR.instance, FHIR.string, FHIR.Age, or FHIR.Range types
to an equivalent interval. This selection of choice types is a superset of the majority of choice types that are used as possible
representations for timing-valued elements in FHIR, allowing this function to be used across any resource.

The input can be provided as a dateTime, Period, Timing, instant, string, Age, or Range.
The intent of this function is to provide a clear and concise mechanism to treat single
elements that have multiple possible representations as intervals so that logic doesn't have to account
for the variability. More complex calculations (such as medication request period or dispense period
calculation) need specific guidance and consideration. That guidance may make use of this function, but
the focus of this function is on single element calculations where the semantics are unambiguous.
If the input is a dateTime, the result a DateTime Interval beginning and ending on that dateTime.
If the input is a Period, the result is a DateTime Interval.
If the input is a Timing, an error is raised indicating a single interval cannot be computed from a Timing.
If the input is an instant, the result is a DateTime Interval beginning and ending on that instant.
If the input is a string, an error is raised indicating a single interval cannot be computed from a string.
If the input is an Age, the result is a DateTime Interval beginning when the patient was the given Age,
and ending immediately prior to when the patient was the given Age plus one year.
If the input is a Range, the result is a DateTime Interval beginning when the patient was the Age given
by the low end of the Range, and ending immediately prior to when the patient was the Age given by the
high end of the Range plus one year.

NOTE: Due to the
complexity of determining a single interval from a Timing or String type, this function will throw a run-time exception if it is used
with a Timing or String.
*/
define fluent function toInterval(choice Choice<FHIR.dateTime, FHIR.Period, FHIR.Timing, FHIR.instant, FHIR.string, FHIR.Age, FHIR.Range>):
  case
    when choice is FHIR.dateTime then
      Interval[FHIRHelpers.ToDateTime(choice as FHIR.dateTime), FHIRHelpers.ToDateTime(choice as FHIR.dateTime)]
    when choice is FHIR.Period then
      FHIRHelpers.ToInterval(choice as FHIR.Period)
    when choice is FHIR.instant then
      Interval[FHIRHelpers.ToDateTime(choice as FHIR.instant), FHIRHelpers.ToDateTime(choice as FHIR.instant)]
    when choice is FHIR.Age then
      Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(choice as FHIR.Age),
        FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(choice as FHIR.Age) + 1 year)
    when choice is FHIR.Range then
      Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((choice as FHIR.Range).low),
        FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((choice as FHIR.Range).high) + 1 year)
    when choice is FHIR.Timing then
      Message(null as Interval<DateTime>, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a Timing value is not supported')
    when choice is FHIR.string then
      Message(null as Interval<DateTime>, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a String value is not supported')
    else
      null as Interval<DateTime>
  end

// Was getting error on this for this particular choice set not being found


/*
@description: Returns an interval representing the normalized Abatement of a given Condition resource.
@comment: NOTE: Due to the complexity of determining an interval from a String, this function will throw
a run-time exception if used with a Condition instance that has a String as the abatement value.
*/
define fluent function abatementInterval(condition Condition):
  if condition.abatement is FHIR.dateTime then
    Interval[FHIRHelpers.ToDateTime(condition.abatement as FHIR.dateTime), FHIRHelpers.ToDateTime(condition.abatement as FHIR.dateTime)]
  else if condition.abatement is FHIR.Period then
    FHIRHelpers.ToInterval(condition.abatement as FHIR.Period)
  else if condition.abatement is FHIR.string then
    Message(null as Interval<DateTime>, true, 'NOT_IMPLEMENTED', 'Error', 'Calculation of an interval from a String value is not supported')
  else if condition.abatement is FHIR.Age then
    Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(condition.abatement as FHIR.Age),
      FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity(condition.abatement as FHIR.Age) + 1 year)
  else if condition.abatement is FHIR.Range then
    Interval[FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((condition.abatement as FHIR.Range).low),
      FHIRHelpers.ToDate(Patient.birthDate) + FHIRHelpers.ToQuantity((condition.abatement as FHIR.Range).high) + 1 year)
  else if condition.abatement is FHIR.boolean then
    Interval[end of condition.onset.toInterval(), condition.recordedDate)
  else 
    null

/*
@description: Returns an interval representing the normalized prevalence period of a given Condition resource.
@comment: Uses the toInterval and toAbatementInterval functions to determine the widest potential interval from
onset to abatement as specified in the given Condition.
*/
define fluent function prevalenceInterval(condition Condition):
if condition.clinicalStatus ~ "active"
  or condition.clinicalStatus ~ "recurrence"
  or condition.clinicalStatus ~ "relapse" then
  Interval[start of condition.onset.toInterval(), end of condition.abatementInterval()]
else
  (end of condition.abatementInterval()) abatementDate
    return 
	  if abatementDate is null then
        Interval[start of condition.onset.toInterval(), abatementDate)
      else
        Interval[start of condition.onset.toInterval(), abatementDate]

/*
@description: Returns true if the given reference is to the given resource
@comment: Returns true if the `id` element of the given resource exactly equals the tail of the given reference.
NOTE: This function assumes resources from the same source server.
*/
define fluent function references(reference FHIR.Reference, resource FHIR.Resource):
  resource.id = Last(Split(reference.reference, '/'))  

/*
@description: Returns true if the given reference is to the given resourceId
@comment: Returns true if the `resourceId` parameter exactly equals the tail of the given reference.
NOTE: This function assumes resources from the same source server.
*/
define fluent function references(reference FHIR.Reference, resourceId String):
  resourceId = Last(Split(reference.reference, '/'))

/*
@description: Returns true if any of the given references are to the given resource
@comment: Returns true if the `id` element of the given resource exactly equals the tail of any of the given references.
NOTE: This function assumes resources from the same source server.
*/
define fluent function references(references List<FHIR.Reference>, resource FHIR.Resource):
  exists (references R where R.references(resource))
  
/*
@description: Returns true if any of the given references are to the given resourceId
@comment: Returns true if the `resourceId` parameter exactly equals the tail of any of the given references.
NOTE: This function assumes resources from the same source server.
*/
define fluent function references(references List<FHIR.Reference>, resourceId String):
  exists (references R where R.references(resourceId))
"^^xsd:base64Binary ]
  ] ) . #