Entity Data Model
Get to know about the relational data- and object model used in UBIK® beginning from a rather figurative and abstract point of view. We will introduce the essential parts of the object model and show how these items are connected to a real system.
- 1 Introduction
- 2 From the plant picture to UBIK®
- 3 Relating objects
- 4 MetaClasses and Instances
- 5 Conclusion
In an industrial environment we quite often need to
- describe an industrial plant consisting of a bunch of different parts, each having a certain purpose and set of properties, and which are related in various ways
- manage process or maintenance data of the plant and its features
- do a high-performance cost-benefit analysis and create key performance indicators
Therefore we need to
→ „Dissemble“ the system into theoretical blocks representing the real as well as intangible parts of the system.
→ Identify the necessary properties of the blocks.
→ Think about how blocks are possibly related to each other.
→ Think about the functions and features of blocks.
Lets start with a simple picture and assume that our plant consists of a pump and an armature. Both equipments exhibit certain technical or other properties, which our datamodel must contain in some form. Additionally the datamodel has to provide mechanism to indicate the circumstances that both equipments are parts of the plant and maybe even be related to each other.
In this first exemplary plant, we take account of a pump and armature and find definitions as shown in the picture on the right. Looking closer at the PUMP block reveals its properties and property values, this information is explicitely depicted as
Of course, a real plant consists of multiple pumps, each described with the same set of properties (TAG, vendor, power, maintenance data). The real pumps in the plant are distinguished by different property values as given in the table.
We can redefine or extend our objectives by
- Design a descriptive model including all required blocks and properties of the system
- Specify the possible properties for the parts of the real system
From the plant picture to UBIK®
The transition from the plant picture into an object- / data - model logically happens via an intermediate layer and finally leads to our first definition
So far we have identified
An important aspect of the datamodel has not been discussed yet, namely how are the blocks (=MetaClasses) related to each other?
Assuming that all three pumps are clearly parts of the plant „UBIK1“, the descriptive model has to be extended in order to include this information as well. In our "table" view we account for this by adding a property to the PUMP block refering to the plant. This additional property represents the link information between the pumps #1 - #3 and the plant „UBIK1“.
Now we introduce two armatures with the properties from the descriptive model above. Assume that, due to the piping, pumps #1 and #2 are controlled by both armatures, whereas A200 regulates pump #3 only. This situation is depicted below already indicating, that the implementation of the relation requires a more complex structure. We find three pumps on the left side and two armatures on the right side of the relation, respectively. Managing this control relation in the Metamodel requires to introduce a relation block CONTROL with two MetaProperties „Armature#“ and „Pump#“
Lets have a closer look at the characteristics of the two methods relating objects:
Entity Relationship Model (ER model)
In software engineering, such an abstract descriptive model is called Entity–Relationship model (ER model) and describes the entities (=UBIK® MetaClasses) and relationships between them. Usually this information is depicted in an entity-relationship-diagram (ERD), which draws the corresponding data objects and relations as rectangles and lines between them, respectively. The MetaClass CONTROL can be drawn as diamond, signalling the additional block between these two MetaClasses, which is always needed for each relation of cardinality n : n.
About References and Relations
Concluding and summarizing the above discussion we finally depict the two possible types of relation in the UBIK® Metamodel.
Congratulations, we integrated another important issue in our data- and object model:
MetaClasses and Instances
So far MetaClasses define the structure of and possible relations between the objects in our data model. In the next step it will be shown how to create actual objects of these blueprints and how to deal with it.
Populating our data modell with real data from a plant means, that we create objects as defined by the MetaClasses. These objects are called instances, and leads us to the next definition.
MetaClass & MetaProperties
In the similar way as MetaClasses are related to each other, MetaProperties are related to MetaClasses. Hence, we obviously find that
- a MetaProperty can be related to multiple MetaClasses
- be used multiple times for defining a MetaClass' structure
MetaClass & Inheritance
We can build up a hierarchical tree of MetaClasses, where MetaClasses inherit properties.
MetaClass & Classification
MetaClasses can specify features and properties of other MetaClasses by using a "Classification" technique. The result can be described by
- "A piston pump is a pump and an element of the fluid technology." [gen]
- "Piston pump" is a child MetaClass of „Pump“ and classified as "Fluid technology" object. [techn.]
Each MetaProperty can be specified by its own attributes which are well-known from other systems.
- The descriptive model consists of MetaClasses and MetaProperties and relations between these objects.
- Each MetaClass is defined by
- a collection of MetaProperties
- the line of inheritance
- classification information
- A MetaProperty implements different features and settings.
- In this MetaModel we explicitely distinguish between the description (structure, relations,…) and instances (actual occurences) of data objects
- The MetaClasses might be on an equal hierarchy level from the descriptive point of view, whereas the instances are then related using references and relations