R4 Ballot #2 (Mixed Normative/Trial use)

This page is part of the FHIR Specification (v3.5.0: R4 Ballot #2). The current version which supercedes this version is 5.0.0. For a full list of available versions, see the Directory of published versions . Page versions: R5 R4B R4 R3 R2

Decimal.profile.xml

Modeling and Methodology Work GroupMaturity Level: N/ABallot Status: Informative

Raw XML (canonical form + also see XML Format Specification)

StructureDefinition for decimal

<?xml version="1.0" encoding="UTF-8"?>

<StructureDefinition xmlns="http://hl7.org/fhir">
  <id value="decimal"/> 
  <text> 
    <status value="generated"/> 
    <div xmlns="http://www.w3.org/1999/xhtml">to do</div> 
  </text> 
  <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-standards-status">
    <valueString value="Normative"/> 
  </extension> 
  <url value="http://hl7.org/fhir/StructureDefinition/decimal"/> 
  <name value="decimal"/> 
  <status value="draft"/> 
  <date value="2018-08-19T21:48:56+10:00"/> 
  <publisher value="HL7 FHIR Standard"/> 
  <contact> 
    <telecom> 
      <system value="url"/> 
      <value value="http://hl7.org/fhir"/> 
    </telecom> 
  </contact> 
  <description value="Base StructureDefinition for decimal Type: A rational number with implicit precision"/> 
  <fhirVersion value="3.5.0"/> 
  <kind value="primitive-type"/> 
  <abstract value="false"/> 
  <type value="decimal"/> 
  <baseDefinition value="http://hl7.org/fhir/StructureDefinition/Element"/> 
  <derivation value="specialization"/> 
  <snapshot> 
    <element id="decimal">
      <path value="decimal"/> 
      <short value="Primitive Type decimal"/> 
      <definition value="A rational number with implicit precision"/> 
      <comment value="Do not use a IEEE type floating point type, instead use something that works like a true
       decimal, with inbuilt precision (e.g. Java BigInteger)"/> 
      <min value="0"/> 
      <max value="*"/> 
      <base> 
        <path value="decimal"/> 
        <min value="0"/> 
        <max value="*"/> 
      </base> 
      <constraint> 
        <key value="ele-1"/> 
        <severity value="error"/> 
        <human value="All FHIR elements must have a @value or children"/> 
        <expression value="hasValue() or (children().count() &gt; id.count())"/> 
        <xpath value="@value|f:*|h:div"/> 
        <source value="Element"/> 
      </constraint> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="decimal.id">
      <path value="decimal.id"/> 
      <representation value="xmlAttr"/> 
      <short value="xml:id (or equivalent in JSON)"/> 
      <definition value="unique id for the element within a resource (for internal references)"/> 
      <min value="0"/> 
      <max value="1"/> 
      <base> 
        <path value="Element.id"/> 
        <min value="0"/> 
        <max value="1"/> 
      </base> 
      <type> 
        <code value="string"/> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="decimal.extension">
      <path value="decimal.extension"/> 
      <short value="Additional Content defined by implementations"/> 
      <definition value="May be used to represent additional information that is not part of the basic definition
       of the resource. To make the use of extensions safe and manageable, there is a strict
       set of governance  applied to the definition and use of extensions. Though any implementer
       can define an extension, there is a set of requirements that SHALL be met as part of the
       definition of the extension."/> 
      <comment value="There can be no stigma associated with the use of extensions by any application, project,
       or standard - regardless of the institution or jurisdiction that uses or defines the extensions.
        The use of extensions is what allows the FHIR specification to retain a core level of
       simplicity for everyone."/> 
      <alias value="extensions"/> 
      <alias value="user content"/> 
      <min value="0"/> 
      <max value="*"/> 
      <base> 
        <path value="Element.extension"/> 
        <min value="0"/> 
        <max value="*"/> 
      </base> 
      <type> 
        <code value="Extension"/> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="decimal.value">
      <path value="decimal.value"/> 
      <representation value="xmlAttr"/> 
      <short value="Primitive value for decimal"/> 
      <definition value="The actual value"/> 
      <min value="0"/> 
      <max value="1"/> 
      <base> 
        <path value="decimal.value"/> 
        <min value="0"/> 
        <max value="1"/> 
      </base> 
    <!--  Note: primitive values do not have an assigned type. e.g. this is compiler magic. XML,
       JSON and RDF types provided by extension  -->
      <type> 
        <extension url="http://hl7.org/fhir/StructureDefinition/regex">
          <valueString value="-?(0|[1-9][0-9]*)(\.[0-9]+)?([eE][+-]?[0-9]+)?"/> 
        </extension> 
        <code> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-json-type">
            <valueString value="number"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-xml-type">
            <valueString value="xsd:decimal OR xsd:double"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-rdf-type">
            <valueString value="xsd:decimal OR xsd:double"/> 
          </extension> 
        </code> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
  </snapshot> 
  <differential> 
    <element id="decimal">
      <path value="decimal"/> 
      <short value="Primitive Type decimal"/> 
      <definition value="A rational number with implicit precision"/> 
      <comment value="Do not use a IEEE type floating point type, instead use something that works like a true
       decimal, with inbuilt precision (e.g. Java BigInteger)"/> 
      <min value="0"/> 
      <max value="*"/> 
    </element> 
    <element id="decimal.value">
      <path value="decimal.value"/> 
      <representation value="xmlAttr"/> 
      <short value="Primitive value for decimal"/> 
      <definition value="Primitive value for decimal"/> 
      <min value="0"/> 
      <max value="1"/> 
    <!--  Note: primitive values do not have an assigned type. e.g. this is compiler magic. XML,
       JSON and RDF types provided by extension  -->
      <type> 
        <extension url="http://hl7.org/fhir/StructureDefinition/regex">
          <valueString value="-?(0|[1-9][0-9]*)(\.[0-9]+)?([eE][+-]?[0-9]+)?"/> 
        </extension> 
        <code> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-json-type">
            <valueString value="number"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-xml-type">
            <valueString value="xsd:decimal OR xsd:double"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-rdf-type">
            <valueString value="xsd:decimal OR xsd:double"/> 
          </extension> 
        </code> 
      </type> 
    </element> 
  </differential> 
</StructureDefinition> 

Usage note: every effort has been made to ensure that the examples are correct and useful, but they are not a normative part of the specification.