6. Skip to content

6. CIM UML Extension Rules and Recommendations

6.1 Overview

The CIM UML is an ever-evolving semantic information model. It is extended periodically based on work performed by the IEC TC57 working groups 13, 14, 16 and 21, and work performed by the CIMug through its various focus communities, projects, and working groups. CIM extensions originating from IEC TC57 working group are classified as “Standard” CIM extensions. CIM extensions originating from the CIMug are classified as “User-Defined” CIM extensions.

6.1.1 Application of CIM UML Extension Rules and Recommendations

Work on Standard CIM extensions is started with the full understanding that the extensions are intended to become part of the standard CIM and ultimately to be used to as the basis of new standard CIM profiles. Whereas work on User-Defined extensions is started because the CIM needs to be extended to address the needs and constraints of a particular user’s instance of the CIM. All User-Defined CIM extensions will not become part of the standard CIM. User-Defined CIM extensions must be evaluated to see if they can also be applied in the broader CIM user community as is or with some modifications.

For the reasons presented above, some extension rules and recommendations apply only to Standard CIM extensions; some only to User-Defined CIM extensions; and some to all CIM extensions. The language of the rules and recommendations is intended to be unambiguous so the users of this document will know to which class of CIM extensions each rule and recommendation applies.

6.1.2 Custom CIM Extensions

The objective of these recommendations is to allow for clear modularization of extensions such that they can be readily identified as extensions and migrated more easily to updated versions of the standard CIM,

Extensions to the CIM model should be included in the extension package just as any other CIM modeling except for the differences noted in this clause. The extension package should have the <<CIMExtension>> stereotype to identify all its contents as extensions to the CIM information model. The extension package should also introduce a new namespace.

The subpackage structure of the extensions may pattern after that of standard CIM packages, but the package structure should reflect the needs for individually managing and organising parts of the extensions.

It is recommended to utilize existing data types and CIM classes where possible. New classes can be created where new business objects concepts are introduced with their own lifecycle.

The typical case of adding a new extension class and associating with existing standard classes is can be modeled in a diagram within the extension package as shown in Figure 10 Example UML model for extension class with association to standard class. This situation does not require multiple inheritance.

Figure Example UML model for extension class with association to standard class

Note that the introduction of an association from a new extension class to an existing standard CIM class requires nothing special, just make the association as it is implicitly owned by the depending extension class’s package. It is more clear to put both ends of the association into the extension package as the namespace for both association ends will follow CIM package containment rules which rely upon package dependency.

In the case of a new association with both ends referencing existing classes or new attributes on existing classes, a method of using multiple inheritance is allowed and discussed below.

Name the new extension class with the same name as the standard CIM class. Give the new class a generalization relationship from the standard CIM class such that the standard CIM class is a specialisation of the extension class. Generally the extension class will have no base class and the standard CIM class will now have multiple inheritance. The generalisation relationship should have the <<CIMExtension>> stereotype.

[Should we also add a CIMExtension stereotype to the extension class to make it easily distinquished without having to look at the package containment?]

The new attributes or associations can be added to the new extension class and they will be inherited by the standard CIM class and in effect appearing as new properties of the standard class.

A new attribute is effectively added to an existing CIM class within the new extension package using a diagram within the extension package as shown in Figure 11 Example UML model for attribute extensions to standard CIM classes.

Figure Example UML model for attribute extensions to standard CIM classes.

A new association can be effectively between two standard CIM classes by introducing one of the classes as an extension class in the extension package then making the association to the other class. There is no guidance on which end to chose as the extension class and it may be driven by having already added one of the extension classes to the extension package for other purposes. A diagram in the extension package can be used as shown in Figure 12 Example UML model for association extensions to standard CIM classes. If both classes are already extension classes, the association should be added between the two extension classes for better modularity.

Figure Example UML model for association extensions to standard CIM classes

An extension class should be used only one time within a namespace. The extension class should have the <<CIMExtension>> generalization pointing to a standard CIM class of the same name. A particular extension is an extension to the one and only standard CIM class. A standard CIM class may have any number of <<CIMExtension>> generalization relationships where each should be from an extension class of the same name but with unique namespaces. The possiblity exists for extension classes extending other extension classes, though it is preferred to extend the standard CIM class if it exits.

6.2 General Extension Rules

General rules for IEC TC57, available in “TC57 CIM Naming_Rules_Draft_R00_2008-05-16v3.doc”, give the overall guidelines for naming conventions of UML models at any abstraction level. The rules defined in this technical report, dedicated to CIM UML information model, take precedence over the rules in the above document in case the rules differ.

Use English language for names.

Names shall describe the problem domain so it aids human understanding.

Words in concatenated names use camel notation (UpperCamelCase or lowerCamelCase rule).

Names contain alphanumeric characters only, i.e. [0..9, A..Z]. Space or special characters are not allowed, e.g.\< > & _ - “ ‘ ( ) [ ] { } ? ! ; : . , * etc.

Names always start with a letter, a numeric value is not allowed.

Make sure a new name for a package or class is unique within its package scope and preferably in the whole model to avoid any ambiguity.

Make sure to reuse an existing attribute name for a new attribute (e.g. sequenceNumber instead of sequence or seqNum or seqNumber).

It is discouraged to distinguished names by upper and lower case changes alone. We have a few examples of this, but the practice is discouraged.

RuleID Description
Rule163 CIM extensions shall be based on at least one business use case that describes a business need that will be satisfied by the extension.
Rule164 CIM extensions should be a specific as possible based on the business use case(s) it satisfies. Specific CIM extensions will give less room for interpretation which will result in better interoperability.
Rule165 Existing standard CIM shall not be changed for simply violating any CIM extension rules.
Rule166 A cost/benefit analysis must be submitted with CIM extensions that are not backwards compatible with the current standard CIM. The analysis must include an impact assessment for standardized message profiles.
Rule167 During development of Standard CIM extensions, custom rules may be temporarily used.
Rule168 Custom rules must no longer be in effect or enforced before merging Standard CIM extensions with the CIM.
Rule169 UML packages shall be used to structure CIM extensions into manageable and logical model parts.
Rule170 Before creating a new model element, the CIM should be searched to see if an element similar to the intended extension element already exists. If it does exist, it may influence the extension to the model.

6.3 Package Extension Rules

Package names start with upper case (UpperCamelCase rule). Package names must be unique across the whole CIM.

RuleID Description
Rule171 Standard CIM extensions shall exist within the top-level CIM (formerly TC57CIM) package.
Rule172 A single top-level package for User-Defined CIM extensions that exist outside of the top-level CIM (formerly TC57CIM) package shall be created at the root-level of the CIM model.
Rule173 The top-level User-Defined CIM extension package should have the stereotype **<<CIMExtension>>** to identify all its contents as extension to the standard CIM.
Rule174 The top-level User-Defined CIM extension package should introduce a new namespace.
Rule175

User-Defined CIM extensions shall exist either within a sub-package within the top-level User-Defined CIM extension package or within the CIM top-level package.

NOTE: The preferred approach is to have User-Defined CIM extensions contained within a sub-package within the top-level User-Defined CIM extension package. However, there are known instances where implementation constraints make it necessary to place some User-Defined CIM extensions within the top-level CIM (formerly TC57CIM) package.

Rule176 Before creating a CIM extension sub-package, the model should be searched to ensure no existing CIM package has the intended name of the CIM extension package.
Rule177

In instances where an existing CIM package has the intended name of the CIM extension package, the intended name of the CIM extension package shall be changed.

NOTE: Consider using another name or adding a prefix to the name of the new package.

Rule178 CIM extension package names shall use the Upper Camel Case naming convention.
Rule179 The sub-package structure of the extensions should be patterned after the Standard CIM sub-package structure as applicable.
Rule180 The “Inf” and “Doc” name prefix rules specified in section 5.3 shall apply to CIM extension packages.
Rule181 The “DetailedDiagram” rules specified in section 5.3 shall apply to CIM extension packages.
Rule182 The Informative packages rules specified in section 5.3 shall apply to CIM extension packages.
Rule183 The sub-package structure of the extensions should take into consideration how the extensions will be managed.

6.4 Class Extension Rules

Class names start with upper case (UpperCamelCase rule). Class names should use singular form. Class names must be unique across the whole CIM. Be aware there is a potential conflict of profile names and class names that may occur from the 62361-100 NDR standard for XSD naming rules, so the choice of profile names and class names should be made with this consideration.

RuleID Description
Rule184 Before creating a new extension class to represent a utility domain concept, the CIM should be searched to make sure the concept Is not already present in the CIM.
Rule185 The creation of new primitive data types should be avoided. As a semantic data model, the CIM is intended to represent utility domain concepts, not extensive data typing available in implementation technologies.
Rule186 The creation of CIM extension classes that represent synthesized utility domain concepts and not real domain objects should be avoided.
Rule187 Class rules specified in section 5.4 shall apply to CIM extension classes.
Rule188 The choice of new CIM extension class names should be made in consideration of potential conflicts with profile names. This conflict may occur based on the IEC62321-100 standard for XSD naming rules.
Rule189 User-Defined CIM extension classes should use a class name prefix, suffix, or a stereotype to facilitate model searches for the class.
Rule190 User-Defined CIM extension class names may include an underscore character.
Rule191 Relationships between User-Defined CIM extension classes and standard CIM classes should be generalisations whenever possible.

6.5 Attribute Extension Rules

Attribute names start with lower case (lowerCamelCase rule). Attribute names should use singular form. Attribute names are unique within a classifier. Inherited attribute names should be unique

RuleID Description
Rule192 Attribute rules specified in 5.5 shall apply to CIM extension attributes.
Rule193 Standard CIM extension attributes shall not be stereotyped.
Rule194 User-Defined CIM extension attributes that are part of a User-Defined CIM extension class shall not be stereotyped.
Rule195 User-Defined CIM extension attributes that are part of a standard CIM class shall be stereotyped.

6.6 Association Extension Rules

6.6.1 Association names

Association names are not used and should be left empty.

6.6.2 Association end names

Association end names are mandatory at both sides for an association.

Association end names start with upper case (UpperCamelCase rule).Historically, if association end had a multiplicity greater than 1, its name would end with an “s”. (Note that given that this has historically been the convention over the years, and many profiles actually use those association end names, it would be hard to change the convention and not include the “s” now for existing classes). However, for all new associations the singular form should be used independent of the cardinality at a role end.

In case the role is clear from the referenced class the class name can be used as association end name. However, a role may have a specific meaning that does not correspond to the class name. In that case the meaning shall be captured in the association end name.

In case there are multiple associations between two classes, it is essential to give different names to association ends of those associations. As a further generalisation of the previous sentence, it is also essential to give unique association end names for the opposite end class. Additionally, association end names should not duplicate attribute names on the opposite end class, though the likelihood of this is small given our other naming conventions.

Inherited association ends should have unique names.

RuleID Description
Rule196 CIM extension associations shall comply with association rules specified in section 5.6.
Rule197 In instances where a CIM extension association role has multiplicity greater than 1, its role name may be plural. This is allowed as a concession for backwards compatibility. For all new associations it is recommended that end role names be expressed in the singular.
Rule198 In instances where there are multiple associations between two classes, all role names shall be different (see Figure 6‑1).
Rule199 In instances where there is self-association, the two role names shall be different (see Figure 6‑2).
Rule200 In instances where the role of a class in an association is clear from the referenced class, the class name may be used as the association role name.
Rule201 In instances where the role of a class in an association does not correspond to the class name, the role of the class in the association shall be contained in its association role name.
Rule202 In instances where a class is in associations with multiple classes, the association role names may be duplicated if the role names on the other end of the associations are different (see Figure 6‑3).
Rule203 Inherited association ends shall have unique role names.
Rule204 Associations between CIM extension classes and high-level standard CIM classes should be minimized.

Figure 6‑1. Example of two associations between two classes

Figure 6‑2. Example of self-association

Figure 6‑3. Allowed duplication of association end names

6.7 Enumeration Extension Rules

Enumeration literal names should follow the same rules as attribute names (5.4.7), except in case some established conventions exist, e.g. SI unit symbols or currencies.

RuleID Description
Rule205

CIM extension enumerations names shall comply with class extension rules specified in section 6.4 and shall end with the suffix “Kind”.

NOTE: There are several standard CIM classes that do not comply with this naming convention. This is an instance where backwards compatibility supersedes a modeling rule.

Rule206 CIM extension enumerations shall comply with enumeration rules specified in section 5.7with the exception in cases where established conventions exist (e.g. SI unit symbols or currencies).