The Digital Twins Definition Language (DTDL) is made up of a set of metamodel classes. In addition to its native classes — Interface, Command, Component, Property, Relationship, and Telemetry — DTDL supports language extensions that define additional metamodel classes. There are three categories of language extensions: Partner extensions add types, properties, and elements that are relevant to a specific cloud service. Feature extensions add non-core features to the DTDL language in a selectable manner. Limit extensions increase the value of one or more limits specified by the core DTDL language.
Each partner or feature extension commonly includes one or more adjunct types, which are types that can be added to the @type
property of a DTDL element.
For example, a Property can be co-typed with the adjunct type Historized defined in the Historization feature extension:
{
"@context": [
"dtmi:dtdl:context;4",
"dtmi:dtdl:extension:historization;2"
],
"@id": "dtmi:com:example:Thermometer;1",
"@type": "Interface",
"contents": [
{
"@type": [ "Property", "Historized" ],
"name": "currentTemp",
"schema": "double"
}
]
}
Each language extension is identifed by a JSON-LD context specifier, which is a DTMI.
To use a language extension, a model's @context
property includes the extension's context specifier in addition to the DTDL context specifier, as illustrated in the example above.
The order of context specifiers is important; different versions of DTDL may have different sets of extensions available, so it is necessary to first declare the DTDL version with a DTDL context specifier before declaring any language extensions via extension context specifiers.
Of particular note is the QuantitativeTypes extension.
DTDL v2 provides native support for semantic types and units, so the following example is valid.
The Telemetry named "currentTemp" is co-typed Temperature, and it has a unit
property with value degreeFahrenheit.
Note that the only context specifier is the core DTDL v2 context, "dtmi:dtdl:context;2".
{
"@context": "dtmi:dtdl:context;2",
"@id": "dtmi:com:example:Sensor;1",
"@type": "Interface",
"contents": [
{
"@type": [ "Telemetry", "Temperature" ],
"name": "currentTemp",
"schema": "double",
"unit": "degreeFahrenheit"
}
]
}
Begining with DTDL v3, semantic types and units are no longer included in the core DTDL language. Instead, they are included in the QuantitativeTypes feature extension, enabling them to evolve more rapidly that the core language is expected to evolve. The following example is the same as the above except the DTDL context has been upgraded from 2 to 3. Conseqently, an additional context for the QuantitativeTypes extension is also specified.
{
"@context": [
"dtmi:dtdl:context;3",
"dtmi:dtdl:extension:quantitativeTypes;1"
],
"@id": "dtmi:com:example:Sensor;1",
"@type": "Interface",
"contents": [
{
"@type": [ "Telemetry", "Temperature" ],
"name": "currentTemp",
"schema": "double",
"unit": "degreeFahrenheit"
}
]
}
Limit extensions do not add new adjunct types to a DTDL model. Instead, a limit extension defines increased values for one or more numerical limits on DTDL property values. For example, in DTDL v4, the maximum depth of nested complex schemas is 8 levels. The Onvif limit extension increases this maximum depth to 24 levels.
Although extensions can add definitions to the DTDL language, they cannot remove any core language definitions. Therefore, for a model to use a limit extension, the model must include only the portion of the core language definitions that do not define any limits. This is done by using a DTDL context specifier with a fragment that indicates the "limitless" portion of the DTDL language, followed by the context specifier for the limit extension:
{
"@context": [
"dtmi:dtdl:context;4#limitless",
"dtmi:dtdl:limits:onvif;1"
],
"@id": "dtmi:com:example:Sampler;1",
"@type": "Interface",
"contents": [
{
"@type": "Property",
"name": "samples",
"schema": {
"@id": "dtmi:ex:very:deep:Object:schema;1",
"@type": "Object",
"comment": "This is not really deep, just a placeholder for the example.",
"fields": []
}
}
]
}
When the limitless DTDL context and a limit extension context are specified, a model may validly exceed the core DTDL limits as long as it does not exceed the limits defined in the extension.
The chart below lists the partner extensions that are currently available.
Extension | Description | DTDL versions |
---|---|---|
Iotcentral v2 | A set of semantic types and schema types used by IoT Central. | 2 |
The chart below lists the feature extensions that are currently available.
Extension | Description | DTDL versions |
---|---|---|
QuantitativeTypes v1 | A set of standard semantic types, unit types, and units. | 3 |
QuantitativeTypes v2 | A set of standard semantic types, unit types, and units. | 4 |
Historization v1 | Record the historical sequence of values of a Property or Telemetry and the times at which values change. | 3 |
Historization v2 | Record the historical sequence of values of a Property or Telemetry and the times at which values change. | 3, 4 |
Annotation v1 | Add custom metadata to a Property or a Telemetry. | 3 |
Annotation v2 | Add custom metadata to a Property or a Telemetry. | 3, 4 |
Overriding v1 | Override a model property with an instance value. | 3 |
Overriding v2 | Override a model property with an instance value. | 3, 4 |
MQTT v1 | Specify Interface properties to facilitate communication via the MQTT pub/sub protocol. | 3 |
MQTT v2 | Specify Interface properties to facilitate communication via the MQTT pub/sub protocol. | 3, 4 |
Requirement v1 | Selectively designate one or more fields in an Object as required. | 3, 4 |
The chart below lists the limit extensions that are currently available.
Extension | Description | DTDL versions |
---|---|---|
Onvif v1 | Increased limits that support translating ONVIF WSDL definitions into DTDL. | 4 |
A service or tool is permitted to claim full support of DTDL as long as it understands the core language. No service or tool is required to support any given language extension, and lack of extension support does not impinge on the claim of DTDL compatibility. If a service or tool does not recognize a partner or feature extension context specifier, it ignores the context definitions and any adjunct types and properties it does not recognize. If a model employs a language extension that is understood by a service or tool, the model can be used in a different service or tool that does not understand the extension. However, aspects of the model defined by the language extension will not be understood by the latter service or tool.
Note: A service that does not understand an extension will not be able to determine whether the extension is used in a model correctly. When using a language extension, always validate your model against a tool or service that recognizes the extension context; otherwise, errors in your model may go undetected.
All DTDL-compliant services and tools are required to accept models that satisfy the core DTDL limits. However, there is no requirement for a service to accept any given limit extension, since the limits defined by the extension could be greater than what the service can support. It is recommended to include a limit extension only when a model contains definitions that exceed the core DTDL limits. Otherwise, a service or tool might reject a model that it could have accepted if the limit extension had not been specified.