General

Introduction

Before specifying the information metamodel of the Asset Administration Shell, some general topics relevant for the Asset Administration Shell are explained.

Subclause Types and Instances describes some general aspects of handling type and instance assets.

Subclause Identification of Elements explains the very important aspects of identification in the context of the Asset Administration Shell.

Subclause Matching Strategies provides matching strategies for semantic identifiers and references.

Subclause Submodel Instances and Templates explains the difference between submodel instances and templates.

Subclause Events discusses aspects of event handling.

Types and Instances

Life Cycle with Type Assets and Instance Assets

Industry 4.0 utilizes an extended understanding of assets, comprising elements such as factories, production systems, equipment, machines, components, produced products and raw materials, business processes and orders, immaterial assets (such as processes, software, documents, plans, intellectual property, standards), services, human personnel, etc..

The RAMI4.0 model [3] defines a generalized life cycle concept derived from IEC 62890. The basic idea is to distinguish between possible types and instances for all assets within Industry 4.0. This makes it possible to apply the type/instance distinction for all elements such as material type/material instance, product type/product instance, machine type/ machine instance, etc. Business-related information is handled on the 'business' layer of the RAMI4.0 model. The business layer also covers order details and workflows, again for both type and instance assets.

Note: to distinguish asset 'type' and asset 'instance', the term 'asset kind' is used in this document. The three different relationship classes between assets, especially type assets and instance assets, explained below show why the distinction is so important. The attribute "derivedFrom" in the metamodel is used to explicitly state a relationship between assets that are being derived from one another. Other relationships are not explicitly supported by the metamodel of the Asset Administration Shell, but they can be modelled via the "RelationshipElement" submodel element type.

Table 1 gives an overview of the different life cycle phases and the role of type assets and instance assets as well as their relationship in these phases.

This important relationship should be maintained throughout the life of the instance assets. It makes it possible to forward updates from the type assets to the instance assets, either automatically or on demand.

Table 1. Life Cycle Phases and Roles of Type and Instance Assets
Asset Kind Life Cycle Phase Description

Type asset

Development

Valid from the ideation/conceptualization to the first prototypes/test. The 'type' of an asset is defined; distinguishing properties and functionalities are defined and implemented. All (internal) design artefacts associated with the type asset are created, such as CAD data, schematics, embedded software.

Usage/
Maintenance

Ramping up production capacity. The 'external' information associated to the asset is created, such as technical data sheets, marketing information. The selling process starts.

Instance asset

Production

Instance assets are created/produced, based on the type asset information. Specific information about production, logistics, qualification, and test are associated with the instance assets.

Usage/
Maintenance

Usage phase by the purchaser of the instance assets. Usage data is associated with the instance asset and might be shared with other value chain partners, such as the manufacturer of the instance asset.

Also included: maintenance, re-design, optimization, and de-commissioning of the instance asset. The full life cycle history is associated with the asset and might be archived/shared for documentation.

The second class of relationships are feedback loops/information within the life cycle of the type asset and instance asset. For product assets, for example, information on usage and maintenance of product instances may be used to improve product manufacturing as well as the design of the (next) product type.

The third class of relationships are feedforward/information exchange with assets of other asset classes. For example, sourcing information from business assets can influence design aspects of products; or the design of the products affects the design of the manufacturing line.

Note: the NIST model [49] provides an illustration of the second/third class of relationships.

A fourth class of relationships consists between assets of different hierarchy levels. For example, these could be the (dynamic) relationships between manufacturing stations and currently produced products. They could be also the decomposition of production systems in physical, functional, or safety hierarchies. In this class of relationships, automation equipment is seen as a complex, interrelated graph of automation devices and products, performing intelligent production and self-learning/optimization tasks.

Details and examples for composite I4.0 Components can be found in [12]. A composite I4.0 Component is the combination of a complex asset and its Asset Administration Shell. The hierarchy, typically a Bill of Material (BOM) but also any other relationship between different assets, can be represented in one of its submodels.

Note: for submodels representing the Bill of Material of a complex asset, the metamodel not only provides the possibility to define relationships (via the submodel element RelationshipElement, see above), it also explicitly supports the representation of another asset (via the submodel element "Entity"). The term "Entity" is chosen as superordinate concept in this context and refers to either an asset or another item that is not an asset but may be part of a more complex item or asset.

Asset Administration Shells Representing Type Assets and Instance Assets

An Asset Administration Shell either represents a type asset or an instance asset. Typically, there is a relationship between instance assets and a type asset. However, not every instance asset is required to have a corresponding type asset.

Figure 1 gives an example of how to handle type assets and their derived instance assets. The attribute "assetKind" indicates whether the Asset Administration Shell (denoted by the ": AAS" UML notation for a class instance) represents a type asset or an instance asset. Additionally, attributes are added to show that the attributes of type asset and instance assets typically differ from each other.

Example: Asset Administration Shells for Type and Instance Assets
Figure 1. Example: Asset Administration Shells for Type and Instance Assets

Note 1: the example is simplified for ease of understanding and only roughly complies with the metamodel as specified in Clause Specification (normative). The ID handling is simplified as well: the names of the classes correspond to the unique global identifier of the Asset Administration Shells.

Note 2: in the context of Plattform Industrie 4.0, types and instances typically refer to "type assets" and "instance assets". When referring to types or instances of an Asset Administration Shell, this is explicitly denoted as "Asset Administration Shell types" and "Asset Administration Shell instances" to not mix them up. Asset Administration Shell types are synonymously used with the term "Asset Administration Shell template".

Note 3: please refer to Clause Terms and Definitions for the IEC definition of types and instances. Within the scope of this document, there is no full equivalency between these definitions and the type/instance concepts of object-oriented programming (OO).

There shall be a concrete type asset of a temperature sensor and two uniquely identifiable physical temperature sensors of this type. The intention is to provide a separate Asset Administration Shell for the type asset as well as for every single instance asset.

In the example, the first sensor has the unique ID "0215551AAA_T1" and the second sensor has the unique ID "0215551AAA_T2". "0215551AAA_T1" and "0215551AAA_T2" are the global asset IDs of the two assets, i.e. sensors. The Asset Administration Shell for the first sensor has the unique URI "http://T1.com" and the Asset Administration Shell for the second sensor has the unique URI "http://T2.com". The asset kind of both is "Instance". The example shows that the measured temperature at operation time of the two sensors is different: for T1 it is 60 °C, for T2 it is 100 °C. For the time-being we ignore the relationship "derivedFrom" of the two Asset Administration Shells "http://T1.com " and "http://T2.com" with Asset Administration Shell "http://T0215551AA.com".

Note 1: even though the HTTP scheme is used for the identifier, please be aware that these identifiers are logical ones. Identifiers do not have to be URLs. At the same time, URLs used as identifiers do not have to refer to accessible content.

Note 2: the physical unit can be obtained by the semantic reference of the element "measuredTemperature". This is not shown in the example for simplicity reasons.

These two instance assets share a lot of information on the type asset (in this example a sensor type), for which an own Asset Administration Shell is created. The unique ID for this Asset Administration Shell is "http://T0215551AA.com", the unique ID of the sensor type is "0215551AA". The asset kind is "Type" and not "Instance". The information shared by all instances of this temperature sensor type is the product class (="Component"), the manufacturer (="ExampleManufacturer"), the English Description (="precise and fast temperature measurement"), and the value range ("-40 °C / 140 °C").

Now the two Asset Administration Shells of the two instance assets may refer to the Asset Administration Shell of the type asset "0215551AA" using the relationship attribute "derivedFrom".

Note 1: in the UML sense, "attribute" refers to the property or characteristic of a class (instance).

Note 2: if a specific type asset exists, it typically exists in time before the respective instance assets.

Note 3: the term Asset Administration Shell is used synonymously with the term Asset Administration Shell instance. An Asset Administration Shell may be realized based on an Asset Administration Shell type. Asset Administration Shell types are out of the scope of this document.

Note 4: in public standardization, the Asset Administration Shell types might be standardized. However, it is much more important to standardize the property types (called property definitions or concept descriptions) or other submodel element types as well as complete submodel types because these can be reused in different Asset Administration Shells.

Note 5: in the domain of the Internet of Things (IoT), instance assets are typically denoted as "Things" whereas type assets are denoted as "Product".

Asset Administration Shell Types and Instances

In the previous clause, type assets and instance assets were explained. The obvious question now is how to harmonize Asset Administration Shells and Asset Administration Shell types. The example in Figure 2 shows that the attributes "globalAssetId" and "assetKind" as well as the global Asset Administration Shell identifier (id, represented as name of the class) are present for all Asset Administration Shells. However, if there is no standard, the semantics of "id", "globalAssetId" or "kind" are not clear, although they are the same for all Asset Administration Shells. It is also not clear, which of the attributes are mandatory and which are specific for the asset (type or instance), as illustrated in Figure 2.

This is the purpose of this document: the definition of a metamodel that defines which attributes are mandatory and which are optional for all Asset Administration Shells. The Plattform Industrie 4.0 metamodel for Asset Administration Shells is defined in Clause Specification.

Note 1: the metamodel of the Asset Administration Shell is suitable for type assets or instance assets. An alternative approach could have been to define two metamodels, one for type assets and one for instance assets. However, the large set of similarities led to the decision of only one metamodel.

Note 2: the metamodel itself does not require the existence of mandatory submodels. This is another step of standardization similar to the standardization of submodels of the Asset Administration Shell type level.

Note 3: an Asset Administration Shell type shall be realized based on the metamodel of an Asset Administration Shell as defined in this document. This metamodel is referred to as "Asset Administration Shell Metamodel".

Note 4: it is not mandatory to define an Asset Administration Shell type before defining an Asset Administration Shell (instance). An Asset Administration Shell instance that does not realize an Asset Administration Shell type shall be realized based on the metamodel of an Asset Administration Shell as defined in this document.

Example: Asset Administration Shell, Asset Administration Shell Types and Instances
Figure 2. Example: Asset Administration Shell, Asset Administration Shell Types and Instances

Identification of Elements

Overview

According to [4], identifiers are needed for the unique identification of many different elements within the domain of smart manufacturing. They are a fundamental element of a formal description of the Administration Shell. Identification is especially required for

  • Asset Administration Shells,

  • assets,

  • submodel instances and submodel templates,

  • property definitions/concept descriptions in external repositories, such as ECLASS or IEC CDD.

Identification will take place for two purposes

  • to uniquely distinguish all elements of an Administration Shell and the asset it is representing, and

  • to relate elements to external definitions, such as submodel templates and property definitions, in order to bind semantics to this data and the functional elements of an Administration Shell.

Identifiers for Assets and Administration Shells

In the domain of smart manufacturing, the assets need to be uniquely identified worldwide [4] [20] by the means of identifiers (IDs). The Administration Shell also has a unique ID (see Figure 3).

6 unique identifier for aas and asset
Figure 3. Unique Identifier for Administration Shell and Asset (Modified Figure from [4])

An Administration Shell represents exactly one asset, with a unique asset ID. In a batch-based production, the batches will become the assets and will be described by a respective Administration Shell. If a set of assets shall be described by an Administration Shell, a unique ID for the composite asset needs to be created [13].

The ID of the asset needs to comply with the restrictions for global identifiers according to [4][20]. If the asset features further identifications like serial numbers and alike, they are not to be confused with the unique global identifiers of the asset itself[1].

What Type of Identifiers Exist?

In [4][20], two standard-conforming global identification types are defined:

  • IRDI – ISO29002-5, ISO IEC 6523 and ISO IEC 11179-6 [20] as an identifier scheme for properties and classifications. They are created in a process of consortium-wise specification or international standardization. To this end, users come together and feed their ideas into the consortia or standardization bodies. Properties in ISO, IEC help to safeguard key commercial interests. Repositories like ECLASS and others make it possible to standardize a relatively large number of identifiers in an appropriately short time.

  • IRI – IRI (RFC 3987) or URI and URL according to RFC 3986 as identification of assets, Administration Shells and other (probably not standardized, but globally unique) properties and classifications.

The following is also permitted:

  • Custom – internal custom identifiers such as UUIDs/GUIDs (universally unique identifiers/globally unique identifiers), which a manufacturer can use for all sorts of in-house purposes within the Administration Shell.

This means that the IRIs/URIs/URLs and internal custom identifiers can represent and communicate manufacturer-specific information and functions in the Administration Shell and the 4.0 infrastructure just as well as standardized information and functions. One infrastructure can serve both purposes.

CLSID are URIs for GUIDs. They start with a customer specific schema. Hence, Custom should really only be used if the customer-specific identifier is no IRDI nor IRI.

Besides the global identifiers, there are also identifiers that are unique only within a defined namespace, typically its parent element. These identifiers are also called local identifiers. For example, properties within a submodel have local identifiers.

Besides absolute URIs there are also relative URIs.

See also DIN SPEC 91406 [31] for further information on identification.

Which Identifiers for Which Elements?

Not every identifier is applicable for every element of the UML model representing the Asset Administration Shell. Table 2 therefore gives an overview on the different constraints and recommendations on the various entities, which implement Identifiable or HasSemantics.

See Annex How Are New Identifiers Created? for more information on how to create new identifiers and best practices for creating URI identifiers.

Table 2. Elements with Allowed Identifying Values
Elements with identifying values Attribute Allowed identifiers (recommended or typical) Remarks

AssetAdministrationShell

id

IRI (URL)

mandatory

Typically, URLs will be used.

idShort

string

optional[2]

displayName

multi language string

optional

AssetInformation

globalAssetId

IRI

recommended

As soon as the Asset Administration Shell is "released" for production or operation, a globalAssetId should be assigned.

An Asset ID may be retrieved e.g., by a QR code on the asset, by an RFID for the asset, from the firmware of the asset, or from an asset database. IEC 61406 (formerly DIN SPEC 91406) defines the format of such Asset IDs.

specificAssetId

IRI, Custom

recommended

An asset typically may be represented by several different identification properties like for example the serial number, its RFID code etc.

They are used for lookup of Asset Administration Shells in cases the globalAssetId is not available. However, they do not need to be globally unique.

Submodel with kind = Template

id

IRDI, IRI (URI)

mandatory

IRDI, if the defined submodel is standardized and has been assigned an IRDI.

idShort

string

recommended

Typically used as idShort for the submodel of kind Instance as well

displayName

multi language string

recommended

Typically used as displayName for the submodel of kind Instance as well

semanticId

IRDI, IRI (URI)

recommended

The semantic ID might refer to an external semantic model defining the semantics of the submodel.

supplementalSemanticId

IRDI, IRI (URI)

optional

Submodel with kind = Instance

id

IRI (URI), Custom

mandatory

idShort

string

recommended

Typically, the idShort or English short name of the submodel template that is referenced via semanticId.

displayName

multi language string

optional

semanticId

IRDI, IRI (URI)

recommended

Typically, the semanticId is an external reference to an external standard defining the semantics of the submodel.

supplementalSemanticId

IRDI, IRI (URI)

optional

SubmodelElement

idShort

string

mandatory

Typically, the English short name of the concept definition that is referenced via semanticId.

displayName

multi language string

optional

If no display name is defined in the language requested by the application, the display name may be selected in the following order, if available:

  • the preferred name in the requested language of the concept description defining the semantics of the element,

  • if there is a default language list defined in the application, the corresponding preferred name in the language is chosen according to this order,

  • the English preferred name of the concept description defining the semantics of the element,

  • the short name of the concept description,

  • the idShort of the element.

semanticId

IRDI, IRI (URI), Custom

recommended

link to a ConceptDescription or the concept definition in an external repository via a global ID

supplementalSemanticId

IRDI, IRI (URI)

optional

ConceptDescription

id

IRDI, IRI, Custom

mandatory

ConceptDescription needs to have a global ID. If the concept description is a copy from an external dictionary like ECLASS or IEC CDD, it may use the same global ID as it is used in the external dictionary.

idShort

string

recommended

e.g. same as English short name

displayName

multi language string

optional

isCaseOf

IRDI, IRI (URI)

optional

links to the concept definition in an external repository, which the concept description is a copy from, or that it corresponds to

Qualifier

semanticId

IRDI, IRI (URI), Custom

recommended

Links to the qualifier type definition in an external repository

IRDI, if the defined qualifier type is standardized and has been assigned an IRDI.

Usage of Short ID for Identifiable Elements

The Administration Shell fosters the use of worldwide unique identifiers to a large degree. However, in some cases, this may lead to inefficiencies. Example: a property, which is part of a submodel, which in turn is part of an Administration Shell, each of which is identified by global identifiers [4].

In an application featuring a resource-oriented architecture (ROA), a worldwide unique resource locator (URL) might be composed of a series of segments, which do not need to be globally unique, see Figure 4.

7 motiviation of exemplary ids
Figure 4. Motivation of Exemplary Identifiers and idShort

To allow such efficient addressing by the chaining of elements by an API of an Administration Shell, idShort is provided for a set of classes of the metamodel. It inherits from the abstract class Referable, in order to refer to such dependent elements.

Before accessing concrete data provided via a submodel, an application typically checks if the submodel provides the required data, i.e. the semantics of the submodel is checked for suitability. A so-called semanticId should be defined for this submodel as well as the submodel element. This semantic ID helps to easily find the semantic definition of the submodel (see Clause Has Semantics Attributes).

Matching Strategies

Matching Strategies for Semantic Identifiers

When comparing two elements, different use cases should be considered in order to define how these two elements are semantically related. This clause gives first hints on the aspects to consider when dealing with matching semantic identifiers. The actual implementations in applications may differ from the strategies presented here. For example, semantic references including context information as represented in IRDI-Path in ECLASS are not yet considered. Sometimes a concept description is derived from another concept description or is identical to or at least compatible with another concept description.

Exact Matching (identical semanticIds) – DEFAULT

  • With exact matching, two semantic IDs need to represent two exact matching references (see Matching Algorithm for References).

    • Example: Property with idShort "ManufacturerName" + semanticId value 0173-1#02-AAO677#002 and Property with idShort "Herstellername" + semanticId value 0173-1#02-AAO677#002 have exactly equal semantics if the key types in both semanticIds are identical plus the other attributes of a Reference like type and referredSemanticId as well. So if the first key type of property "ManufacturerName" is "ExternalReference" and the first key type of the semanticId of property "Herstellername" is "ModelReference" then the two semanticIds are no exact match. Or if the first reference contains a referredSemanticId value and the second does not the two semantic IDs are not exact matches.

Note 1: Typically, a semanticId does not have a referredSemanticId

Value Matching

  • With value matching, the key values of the two semantic IDs being compared need to be string-identical, i.e. the two references need to value match (see Matching Algorithm for References).

    • Example: Property with idShort "ManufacturerName" + semanticId 0173-1#02-AAO677#002 and Property with idShort "Herstellername" + semanticId 0173-1#02-AAO677#002 have value equal semantics.

Intelligent Matching (compatible semanticIds)

Diffent kinds of intelligent matching may be considered to be implemented. Some are explained in the following.

  • Ignore Versioning

    • With intelligent matching, different versions of a concept definition may be matched. For example, if semantic versioning is used to version the concept description, then upward or backward compatible versions can be matched.

    • Example: property with idShort "ManufacturerName" + semanticId 0173-1#02-AAO677#002 and Property with idShort "Herstellername" + semanticId 0173-1#02-AAO677#003 have equal semantics.

Note 2: to compare two semantic IDs, knowledge about versioning needs to be available. In the example above, two IRDIs from ECLASS are compared. ECLASS rules ensure that the semantics is always backward compatible for new versions; a new IRDI would be created for breaking changes.

  • Consider different syntax of identifiers

    • With intelligent matching, different syntax of the same identifier may be matched. For example ECLASS allows to specify an identifier of a concept definition as IRDI or as URL. ECLASS and IEC CDD both use IRDIs, however, the limiters are different.

    • Example: https://api.eclass-cdp.com/0173-1-02-AAC895-008 matches 0173-1#02-AAC895#008

    • Example: 0173-1#02-AAC895#008 matches 0173/1///02#AAC895#008

  • Consider supplemental semantic IDs (any)

    • With intelligent matching two sets of semantic IDs may be compared: Input is a set of semantic IDs, not distinguishing between semanticId and supplementalSemanticId. SupplementalSemanticIds are not ordered, so index information is not relevant. The input matches to an element for which either its semanticId is in the Input set of semantic IDs or one of its supplemental IDs matches to ones of the semantic IDs in the Input set.

    • In addition exact or value matching of semantic IDs can be distinguished (see before)

    • Example: Input Set = { 0173/1///02#AAC895#008} matches for a property with semanticId = https://api.eclass-cdp.com/0173-1-02-AAC895-008 and supplementalSemanticId = 0173/1///02#AAC895#008.

    • Example: Input Set = { 0173-1#02-AAC895#00, https://api.eclass-cdp.com/0173-1-02-AAC895-008, 0173/1///02#AAC895#008 } would match for a property with semanticId = https://api.eclass-cdp.com/0173-1-02-AAC895-008 and no supplemental semantic IDs.

  • Consider supplemental semantic IDs (all)

    • With intelligent matching two sets of semantic IDs may be compared: Input is a set of semantic IDs, not distinguishing between semanticId and supplementalSemanticId. SupplementalSemanticIds are not ordered, so index information is not relevant. The input matches to an element for which all the semantic IDS of the input set are available, either as semantic ID or as supplementalSemanticId.

    • In addition exact or value matching of semantic IDs can be distinguished (see before)

    • Example: Input Set = { 0173/1///02#AAC895#008} matches for a property with semanticId = https://api.eclass-cdp.com/0173-1-02-AAC895-008 and supplementalSemanticId = 0173/1///02#AAC895#008.

    • Example: Input Set = { 0173-1#02-AAC895#00, https://api.eclass-cdp.com/0173-1-02-AAC895-008, 0173/1///02#AAC895#008 } does not match for a property with semanticId = https://api.eclass-cdp.com/0173-1-02-AAC895-008 and no supplemental semantic IDs.

  • Consider supplemental semantic IDs and isCaseOf

    • The two intelligent matching strategies "Consider supplemental semantic IDs (any)" and "Consider supplemental semantic IDs (all)" may be extended to also include the isCaseOf information of a ConceptDescription referenced via one of the semantic IDs (semanticId or supplementalSemanticId) of an element.

    • Example: Input Set = { 0173/1///02#AAC895#008} matches for a property with semanticId = [ModelRef](ConceptDescription) https://admin-shell.io.example if the isCaseOf value of the referenced concept description with id = https://admin-shell.io.example is equal to 0173/1///02#AAC895#008.

  • Consider Semantic Mappings

    • Existing semantic mapping information can be considered for intelligent matching. Semantic mappings may exist within one and the same dictionary, but also between different dictionaries and ontologies.

    • Example: 0112/2///61360_4#AAE530 for nominal capacity of a battery in dictionary IEC CDD and 0173-1#02-AAI048#004 in ECLASS have equal semantics[3] [4].

Note 3: this example does not represent an existing semantic mapping; it is only a candidate.

  • Consider Domain Knowledge

    • With intelligent matching, domain knowledge available in machine-readable form may be taken into account, such as an "is-a"-relationship between two concept definitions.

    • Example: a Hammer drill (0173-1#01-ADS698#010) and a percussion drill (0173-1#01-ADS700#010) are drills for mineral material (0173-1#01-ADN177#005) and are compatible with a request or constraints asking for drills for mineral material.

Matching Algorithm for References

Clause Matching Strategies for Semantic Identifiers has discussed matching strategies for semantic identifiers. This clause explains matching strategies based on the reference concept (see Clause Referencing) in more detail and covers other kinds of identifying elements.

For example, the string serialization of references as defined in Clause Text Serialization of Values of Type "Reference" is used for easier understanding.

Note 4: Matching in this context means supporting a discovery query against an existing model.

A typical query would be to find some element with a specific semantic ID. In this case the data consumer only knows the external ID whereas the provider may have created a duplicate of the concept definition as ConceptDescription and a model reference could be used

Matching does not mean to define equivalence classes that allow to overwrite constraints as defined in the specification for valid instances of the metamodel.

Exact matching of two references

  • Two References are identical if all attributes values are identical.

Examples for non-matching external references[5]:

(GlobalReference)0173-1#01-ADS698#010, (GlobalReference)0173-1#01-ADS700#010

is no exact match for

(GlobalReference 0173-1#01-ADS698#010, (FragmentReference)0173-1#01-ADS700#010

but a value match.

Value matching of two references

  • An external reference A matches an external reference B if all values of all keys are identical.

Note 5: it is unlikely that a fragment value is identical to a global reference value; it will reference something different.

  • A model reference A matches a model reference B if all values of all keys are identical.

Note 6: the key type can be ignored since the fragment keys are always unique (e.g. all idShorts of submodel elements in a submodel or all submodel elements in a submodel element list or collection).

  • An external reference A matches a model reference B and vice versa if all values of all keys are identical.

  • The Reference/type and Reference/referredSemanticId are ignored for matching.

Note 7: since identifiables of the Asset Administration Shell are globally unique, model references are special cases of global references. The only difference is the handling of key types that are predefined for Asset Administration Shell elements. Other key types could be predefined, e.g. for IRDI-Paths etc. However, so far only generic key types are supported.

Note 8: if the values for attribute "referredSemanticId" of the two references compared are not identical then there is a mismatch between the two that should be resolved. However, the two are considered to match in the context of discovery.

Note 9 for model reference to model reference matching or external to external reference matching: if the key types are not identical although all key values follow the correct order of the key chain, then at least one of the references is buggy and a warning may be issued. Exception: one of the model references uses an abstract class as value for the key type, the other model reference uses a non-abstract class (e.g. SubmodelElement and Property).

The definition of XML Schema is used for matching

  • (Of string or names:) Two strings or names being compared must be identical.

  • Characters with multiple possible representations in ISO/IEC 10646 (e.g. characters with both precomposed and base+diacritic forms) match only if they have the same representation in both strings

  • No case folding is performed.

  • (Of strings and rules in the grammar:) A string matches a grammatical production if it belongs to the language generated by that production.

Examples for matching external references[6]:

(GlobalReference)0173-1#01-ADS698#010, (GlobalReference)0173-1#01-ADS700#010

value-matches

(GlobalReference 0173-1#01-ADS698#010, (FragmentReference)0173-1#01-ADS700#010

Examples for non-matching external references:

(GlobalReference)https://example.com/aas/1/1/1234859590, (FragmentReference)Specification, (FragmentReference)Bibliography

does not value-match

(GlobalReference)https://example.com/aas/1/1/1234859590, (FragmentReference)Specification, (FragmentReference)Bibliographie

since the values of the last fragment differ.

Examples for matching model references:

Although these two model references would match according to the matching rules, other rules are violated, i.e. that the ID of the submodel is unique. If the ID of a submodel is unique, it is not possible that there are two direct submodel element children with the same name (here: Specification). It is also not possible that two different versions of the same submodel are compared here, because we would then assume that the ID also contains the version information (see Clause Administrative Information Attributes). The matching algorithm would still identify these two model references as matching although one of them is buggy.

(Submodel)https://example.com/aas/1/1/1234859590, (File)Specification

matches

(Submodel)https://example.com/aas/1/1/1234859590, (Blob)Specification

Examples for matching model and external references:

(Submodel)https://example.com/aas/1/1/1234859590

matches

(GlobalReference)\https://example.com/aas/1/1/1234859590

Note 10: this kind of Submodel matching might occur if a SubmodelElement of type ReferenceElement is matched against a query for this element. It is not allowed to substitute the Submodel references within AssetAdministrationShell/submodels with an external reference!

(Submodel)https://example.com/aas/1/1/1234859590, (File)Specification (FragmentReference)Bibliography

matches

(GlobalReference)https://example.com/aas/1/1/1234859590, (FragmentReference)Specification, (FragmentReference)Bibliography

Submodel Instances and Templates

Can New or Proprietary Submodels be Formed?

It is in the interest of Industry 4.0 for as many submodels as possible, including free and proprietary submodels, to be formed (see [4], "Free property sets"). A submodel can be formed at any time for a specific Administration Shell of an asset. The provider of the Administration Shell can form in-house identifiers for the type and instance of the submodel in line with Clause Identification of Elements. All I4.0 systems are called on to ignore submodels and properties that are not individually known. Hence, it is always possible to deposit proprietary – e.g. manufacturer-specific or user-specific – information, submodels, or properties in an Administration Shell.

Note: it is the intention of the Administration Shell to include proprietary information, e.g. to link to company-wide identification schemes or information required for company-wide data processing. This way, a single infrastructure can be used to transport standardized and proprietary information at the same time. New information elements can also be conveyed and introduced (and standardized at a later stage).

Creating a Submodel Instance Based on an Existing Submodel Template

A public specification of a submodel template (e.g. via publication by Plattform Industrie 4.0) should be available to instantiate an existing submodel template. In special cases, a submodel can also be instantiated from a non-public submodel template, such as a manufacturer specification.

In November 2020, the first two submodel templates for the Asset Administration Shell were published, one for a nameplate [40] and one for generic technical data [39]. Others followed and will follow. Please see [45] for an overview of registered submodel templates.

The identifiers of concept definitions to be used as semantic references are already predefined in each submodel template. An instantiation of such a submodel merely requires the creation of properties with a semantic reference to the property definition and an attached value. The same applies to other subtypes of submodel elements.

The only thing that cannot be defined in the template itself is the unique ID of the submodel instance itself (it is not identical to the ID of the submodel template), as well as the property values, etc. Templates also define cardinalities, for example whether an element is optional or not. Submodel element lists typically contain more than one element: the template contains an exemplary element template; the other elements can be created by copy/paste from this template.

Events

Overview

Events are a very versatile mechanism of the Asset Administration Shell. The following subclauses describe some use cases for events. They summarize different types of events to depict requirements, introduce a SubmodelElement EventElement to enable declaration of events of an Asset Administration Shell. Further, the general format of event messages is specified.

Note: the concept of event is still in the experimental phase. Please be aware that backward compatibility cannot be ensured for future versions of the metamodel.

Brief Use Cases for Events Used in Asset Administration Shells

Event use cases are briefly outlined in the following:

  • An integrator has purchased a device. Later in time, the supplier of the device provides a new firmware. The integrator wants to detect the offer of a new firmware and wants to update the firmware after evaluating its suitability ("forward events"). A dependent Asset Administration Shell ("D4") detects events from a parent or type Asset Administration Shell ("D1"), which is described by the derivedFrom relation. An illustration of the use case is given in Figure 5.

  • An integrator/operator operates a motor purchased from a supplier. During operation, condition monitoring incidents occur. Both parties agree on a business model providing availability. The supplier wants to monitor device statuses which are located further in the value chain ("reverse events"). An illustration of the use case is given in Figure 5.

8 forward and revers events
Figure 5. Forward and Reverse Events
  • An operator is operating a certain I4.0 component over time. Changes that occasionally occur to these I4.0 components from different systems shall be tracked for documentation and auditing purposes. This can be achieved by recording events over time. An illustration of the use case is given in Figure 6.

9 tracking of changes via events
Figure 6. Tracking of Changes via Events
  • An operator is operating different I4.0 components, which are deployed to manufacturer clouds. The operator wants to integrate data from these components, according to DIN SPEC 92222. For this purpose, information needs to be forwarded to the operator cloud ("value push"). An illustration of the use case is given in Figure 7.

10 value push events across clouds
Figure 7. Value Push Events Across Clouds

Input and Output Directions of Events

We can distinguish between incoming and outgoing events. See Table 3 for more information on the event directions.

Table 3. Directions of Events
Direction Description

Out

The event is monitoring the Referable it is attached to. An outer message infrastructure, e.g. by OPC UA, MQTT or AMQP, will transport these events to other Asset Administration Shells, further outer systems and users.

In

The software entity, which implements the respective Referable, can handle incoming events. These incoming events will be delivered by an outer message infrastructure, e.g. OPC UA, MQTT or AMQP, to the software entity of the Referable.

Types of Events

The uses cases described in Clause Brief Use Cases for Events Used in Asset Administration Shells need different types of events. Each event type is identified by a semanticId and features a specialized payload.

Table 4 gives an overview of types of events. The possible directions of an event are described in Clause Input and Output Directions of Events.

Table 4. Types of Events
Group Direction Motivation / Conditions

Structural changes of the Asset Administration Shell

Out

  • CRUD[7] of Submodels, Assets, SubmodelElements, etc.


7. Create, Retrieve, Update, Delete

In

  • Detect updates on parent/type/derivedFrom Asset Administration Shell

Updates of properties and dependent attribute

Out

  • update of values of SubmodelElements

  • time-stamped updates and time series updates

  • explicit triggering of an update event

Operation element of Asset Administration Shell

Out

  • monitoring of (long-lasting) execution of OperationElement and updating events during execution

Monitoring, conditional, calculated events

Out

  • e.g. when voiding some limits (e.g. stated by Qualifiers with expression semantics)

Infrastructure events

Out

  • Booting, shutdown, out of memory, etc. of software entity of respective Referable (Asset Administration Shell, Submodel)

Repository events

In/ Out

  • Change of semantics of IRDIs (associated concept definition)

Security events

Out

  • logging events

  • access violations, unfitting roles and rights, denial of service, etc.

Alarms and events

Out

  • alarms and events management analog to distributed control systems (DCS)

Custom Event Types

Custom event types can be defined by using a proprietary, but worldwide unique, semanticId for this event type. Such customized events can be sent or received by the software entity of the respective referable, based on arbitrary conditions, triggers, or behavior. While the general format of the event messages needs to comply with this specification, the payload might be completely customized.

Event Scopes

Events can be stated with an observableReference to the Referables of Asset Administration Shell, Submodels, and SubmodelElements. These Referables define the scope of the events, which are to be received or sent. Table 5 describes the different scopes of an event.

Table 5. Event Scopes
Event attached to …​ Scope

AssetAdministrationShell

This event monitors/represents all logical elements of an Administration Shell, such as AssetAdministrationShell, AssetInformation, Submodels.

Submodel

This event monitors/represents all logical elements of the respective Submodel and all logical dependents.

SubmodelElementList and SubmodelElementCollection and Entity

This event monitors/represents all logical elements of the respective SubmodelElementCollection, SubmodelElementList or Entity and all logical dependents (value or statement resp.).

SubmodelElement (others)

This event monitors/represents a single atomic SubmodelElement, e.g. a data element which might include the contents of a Blob or File.


1. Such additional asset identifiers are contained in AssetInformation/specificAssetIds.
2. Note: in version V1.0 of this specification, idShort was optional for identifiables. This changed in V2.0: idShort was set to mandatory for all referables. With V3.0, idShort was again made optional.
3. Semantic mapping files are also used in ECLASS between ECLASS Classic and ECLASS Advanced: https://eclass.eu/support/technical-specification/data-model/basic-advanced-mapping
5. The example only contains arbitrary IRDIs and does not represent a real-world example.
6. The example only contains arbitrary IRDIs and does not represent a real-world example.