The present disclosure refers to a method and a system for propagation of amendments in the configuration of technical equipment, e.g., transformers, generators, mills, and other automated machines or devices, by transfer of an amended configuration of a master, having a specific apparatus or device to a non-limited number of duplicates of the master.
Many production plants have large subunits which are very similar but not identical to each other. As an example there may be several boilers in a chemical plant. Those boilers would be similar to a large extent but some aspects would be different. One aspect wherein subunits will be similar relates to their structure (e.g., the number, types, and arrangement of devices of which the subunit is made). An aspect which will almost always differ is the naming of the tags and signals.
An optimal workflow would be to finish the configuration of the first subunit, to test and optimize it, and then to copy and adapt the configuration for use with further subunits of the same type. But this is a slow process, since the work on the second subunit can only be started after the first one has finished.
The process today is that the first subunit is configured, and then this configuration is copied to the other subunits, while the optimization and test of the configuration takes place after the copying. This leads to shorter overall project execution times but to a higher engineering effort because all units have to be optimized and tested separately.
Accordingly, a challenge today is that the changes which are done to the first subunit during the test and optimization phase cannot be simply and automatically propagated to the other subunits for the following reasons:
The result is that all changes which are done to the master after copying should be done to the duplicate again.
A method is disclosed for propagation of changes in a configuration of technical equipment, comprising: transferring a changed configuration of a master device having a specific apparatus or device to a non-limited number of duplicates of said master; detecting conflicts with a propagation of changes, a propagation from the master to at least one duplicate being executed by transferring a selected subset of the configuration of the master including changes; and propagating at least some of the changes which have been done with the master from the master to the at least one duplicate in a semi-automated or fully automated manner, with possible conflicts being indicated automatically by a graphic or textual display.
A system is also disclosed for propagation of changes in a configuration of technical equipment wherein two groups of objects are compared, where a second of the two groups has been created by copying a first of the two groups of objects but where, after copying, one or both groups of the two groups of objects have been changed, the system comprising: a) an input for receiving data which identifies roots of the master and the duplicate for matching; b) a comparing element for comparing and synchronizing matching objects in the first group and in the second group; and c) a display for identifying possible conflicting changes in the first group and the second group, if any.
By way of examples of various preferred embodiments disclosed herein, which are shown in the attached drawings, advantages of the invention shall be illustrated and described in more detail.
In this regard, the invention is not limited to the embodiments and configurations shown and illustrated in the figures but extended to other embodiments and configurations within the scope of the claims.
As shown in the drawings:
The present disclosure is directed to a method and/or system which can avoid any excess of the efforts involved in a system today, and achieve systematically a standardization of the configuration of respective subunits of a plant.
An exemplary method is characterized in that any changes which have been done in the master are propagated from the master to the copies in a semi-automated or fully automated manner whereas possible conflicts are indicated automatically by means of graphic display.
Accordingly, an exemplary method is characterized in that the propagation of changes done in the master comprises the following:
Generally, the final decision should be taken by the engineer using the system, but the decision is prepared by the system whereas the term “master” and “duplicate” can, for example, refer to a large set of data objects being organized in one or more hierarchies wherein each object can have a common and a specific set of information items.
In such a case, the common information can include, e.g., an identifier like the name, a designation of the type of the object, and the creation time of the object; while the specific information, can depend on the type of the object, e.g., for an object representing a device of a certain kind, the specific information can include, among others, the configuration parameters applicable to this kind of device.
One exemplary preferred embodiment of a method disclosed herein is characterized in that with the matching step the respective data source is analyzed in order to identify whether it is master or duplicate, whereby a logical link between the objects of the master and the duplicate is present.
According to a more detailed exemplary embodiment of a method, preferably, for example, a three-way match is used wherein the master is saved in a compare master directly after copying the master data.
Changes done to the master can result in a data set master′ and changes done to any of the copies can result in a data set copy′ whereas both master′ and copy′ will be compared to the original version, the compare master, in order to identify if changes have been made to the master and/or the copies, whereas at any time when changes with the master are propagated to the duplicate, the current state of the master, master′ is stored as the compare master as basis for later synchronization.
Preferably according to another exemplary embodiment the so-called compare master is stored as an action log whereas this action log is provided to detect and to determine the side on which a change has been made even if it has been deleted in the duplicate. This action log can be considered an embodiment of a method as disclosed herein, and of a system as disclosed herein.
Another exemplary advantageous embodiment of the method provides for the matching to be based on a set of prioritized rules. The method will apply the rule with the highest priority first, and only objects not matched so far will be considered for matching with lower-priority rules. An example of a matching rule is equality of the name of the objects. Another example is that the names are not identical but similar to a certain degree. Furthermore, metrics can be used such as the type of the object, the number of matching children, the position in the tree, property values and more, and suitable combinations of these.
The user can choose which rules should be used for matching and in which order. The user can also configure the individual rules when those offer parameters.
An example is the following rule: “match by similar name”. One useful parameter may then be a “threshold” where objects are never matched when their names differ by e.g. more than 4 characters. If the engineer knows that in his project the naming is not a good way to match, he can deselect this option and choose other algorithms instead.
Hence, after the matching step, potential matches are presented to the engineer as a preferred user of the system. Furthermore it is possible to attach a weight (like “92% match”) to each match in order to point out the quality of the match to the user who may review these matches.
Either the user may manually match pairs of objects which have not been matched by the system or the user may unmatch pairs of objects which have been falsely matched. The matching step is configurable by the using engineer.
A preferred exemplary embodiment of the method provides that conflicts are resolved by the user since exemplary embodiments are also able to detect conflicts and shows these to the user. There may be simple conflicts where, e.g. both in master and in a copy a single value item has been changed to two different values. There may also be more complex conflicts where multiple changes that belong together should be propagated together. E.g., when a function block has been inserted in a control diagram and its inputs and outputs have been connected, none of these single changes makes sense to propagate on its own. The combination of these changes is called a change group. If change groups are overlapping in the master and in the copy, this presents a conflict.
A further part of the disclosure relates to a system to which the method is applied. Accordingly, this document discloses a system for propagation of changes in the configuration of technical equipment, where two groups of objects are compared, in which the second group has been created by copying the first group but after copying one or both groups of objects have been changed.
Such a system can provide for the method an appropriate means for propagation of changes in the configuration of technical equipment whereas in a first step a user or the system identifies roots of a master and copy or copies to the matching step; then in a second step the system identifies matching objects in the first group and in the second group for comparison and synchronization; in a third step the system compares objects matched in the second step and detects changes in the first group and the second group and conflicts in the changes in the first group and the second group; and finally in a fourth step the system presents the found changes and conflicts to the user for change propagation and conflict resolution.
According to an exemplary preferred embodiment, the identification of matching objects is not based only on the objects having the same ID or the same name but also on the use of other algorithms having similar names and the same type or the same number and types of children. There may be algorithms that are specifically tailored to a standardized naming scheme.
Accordingly the user decides which algorithms are to be applied for the matching step and in which order they are to be applied whereas the user parameterizes the algorithms if possible to do so.
Preferably an exemplary embodiment of the system can use a three-way comparison to determine if an identified change has been performed in the first group or in the second group.
According to another preferred exemplary embodiment, the system analyzes the two groups of objects being located in the same data set or in different data sets for changes and communicates or displays these changes to the user by means of any communication media (e.g., display), where any changes detected are done either on a structural level or for example an object-data level.
A further preferred exemplary embodiment of the system is characterized in that multiple changes are grouped if these changes depend on each other.
According to another preferred exemplary version, the system can propagate changes to links between objects in the master. The new target of the link in the duplicate is the object in the duplicate that corresponds to the new target of the link in the master as determined in the matching step. For example, if in the master an object A references an object B and is changed to reference an object C, then in the copy object A′ will be changed from referencing B′ to referencing C′ even though the names or identifiers of these objects are different from the objects to which they correspond to in the master.
Likewise it can be advantageously provided by the system that the user may filter for relevant changes by choosing relevant change cases, where each change case is a type of change which may occur for a certain type of object.
The disclosed system can offer proposals to the user regarding which changes should be propagated and which should not.
If objects are arranged in a hierarchical fashion, as shown in
There are many tools, such as directory comparing elements (e.g., specifically programmed processors with memory), which compare two trees. In nearly all cases, the comparison is done based on name or ID. Also, in exemplary embodiments determining a master-duplicate relationship is not done.
The matching step is configurable by the user. The user can choose which algorithms should be used for matching and in which order. The user can also configure the individual algorithms when those offer parameters. An example is the algorithm “match by similar name”. One useful parameter could then be a “threshold” where objects are never matched when they differ by more than 4 characters. If the engineer knows that in his project the naming is not a good way to match, this option can be deselected and other algorithms can be chosen instead.
In the comparison step, there are different types of changes to be considered. One type of change is structural changes. As shown for example in
Since changes occur concurrently in the master and the duplicate and no action log is written, there is no way of determining whether this object has been created in the master or if it has been deleted in the duplicate. Hence an action log can be used as a compare master to detect the side on which a change has been made.
For the comparison step, this might be negligible information, but for the next step, the change propagation, this can be crucial information: If the object has been added in the master, this change should be propagated to the duplicate. If it has been deleted in the duplicate, it is assumed that this has been done deliberately and the object should not be added back to the copy.
To be able to differentiate the two situations, the exemplary embodiments can make use of the concept of a three-way match. In
After copying the master data (step 1), the master itself is saved either in a file or to some other kind of storage medium (step 2). Then the master or the duplicate or both are changed (step 3), resulting in master′ and duplicate'.
When the user now applies the system as disclosed herein, the master′ will be compared to the original version of the master which is called “compare master” (step 4a). The compare master will also be compared to the duplicate′ (step 4b).
With the information contained in the compare master, it is now possible to find out which changes have been done to the duplicate and which to the master. This method can be far superior to methods like comparing time stamps.
Every time changes are propagated to the duplicate′ (step 5), a new export of the current master′ to compare master′ can also be done (step 6).
In
The comparison step is configurable by the user, in that the user can choose which types of changes are to be detected. In almost any case, the user would not like to compare the name or the creation date.
To make this easily configurable, the concept of “change cases” has been introduced herein. For a function diagram, there are around 100 change cases. They range from “constant value has changed” and “diagram formatting has changed” over “execution order has changed” to “function block has been added”.
Change cases can be defined for every object type once. The user chooses during runtime which change cases to see and which should be ignored.
Furthermore exemplary embodiments are also able to detect conflicts and to show these to the user. There may be direct conflicts where, e.g. both in the master and in the duplicate, a constant value has been changed. The more complex cases are found by checking if change groups are overlapping.
Here
In
It will be appreciated by those skilled in the art that the present invention can be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The presently disclosed embodiments are therefore considered in all respects to be illustrative and not restricted. The scope of the invention is indicated by the appended claims rather than the foregoing description and all changes that come within the meaning and range and equivalence thereof are intended to be embraced therein.
This application claims priority as a continuation application under 35 U.S.C. §120 to PCT/EP2010/006164 filed as an International Application on Oct. 8, 2010 designating the U.S., the entire content of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2010/006164 | Oct 2010 | US |
Child | 13858293 | US |