AUTOMATICALLY EVOLVING A PROCESS MODEL
20230367282 · 2023-11-16
Assignee
Inventors
- Jose Carmona Vargas (Sant Feliu de Llobregat, ES)
- Lluís Padró Cirera (Vilassar de Mar, ES)
- Marc Solé Simó (Sant Just Desvern, ES)
- Josep Sanchez Ferreres (Barcelona, ES)
Cpc classification
International classification
Abstract
Methods are provided of automatically evolving a process model including process-elements and relationships between process-elements. The method comprises receiving user input defining one or more new constraints to be satisfied by the evolved process model. The method further comprises performing an optimization method to find a best solution of a cost function depending on a set of optimization conditions, over a solution space of possible consistent and/or sound process models derivable from the process model to be evolved depending on the one or more new constraints. The set of optimization conditions comprises maximization of constraints satisfaction corresponding to satisfaction of the one or more new constraints and of previous constrains from previous executions of the method. The method still further comprises updating the process model with the obtained best solution. Computer programs and systems are also provided that are suitable for performing such methods.
Claims
1. A method of automatically evolving a process model including process-elements and relationships between process-elements, the relationships being defined as a relationship between the process-elements that cause a satisfaction of user-defined constraints by a process model to be evolved, and the user-defined constraints comprising logical rules or criteria indicated by a user, the method comprising: receiving, by a processor, one or more user-defined constraints to be satisfied by the process model; performing, by a processor, an optimization method to find a best solution of a cost function depending on a set of optimization conditions, over a solution space of possible consistent and/or sound process models derivable from the process model depending on the received one or more user-defined constraints, the optimization method comprising: solving a problem of constraint satisfaction over the solution space of possible consistent and/or sound process models, and performing a multi-objective search method over the solution space of possible consistent and/or sound process models; and the set of optimization conditions comprising: maximizing constraint satisfaction corresponding to a satisfaction of the received one or more user-defined constraints and of previous constraints from previous executions, prioritizing the maximized constraints satisfaction with respect to any other optimization condition in the set of optimization conditions, and minimizing indirectly inferred relationships between process-elements derivable from the process model at least depending on the received one or more user-defined constraints, the indirectly inferred relationships comprising a relationship that is not explicitly defined by a constraint but preserves a soundness of the process model in evolution along with directly inferred relationship(s); and updating, by a processor, the process model with the obtained best solution.
2. (canceled)
3. (canceled)
4. The method according to claim 1, wherein performing the multi-objective search method includes performing an A* algorithm over the solution space of possible consistent and/or sound process models.
5. (canceled)
6. (canceled)
7. The method according to claim 1, wherein the set of optimization conditions further comprises prioritizing minimizing new indirectly inferred relationships between process-elements with respect to any other optimization condition in the set of optimization conditions except the maximized constraints satisfaction.
8. The method according to claim 7, wherein the set of optimization conditions further comprises maximizing preservation of previously indirectly inferred relationships between process-elements in the process model from previous executions of the method.
9. The method according to claim 8, wherein the set of optimization conditions further comprises prioritizing the maximization of preserved previously indirectly inferred relationships between process-elements with respect to any other optimization condition in the set of optimization conditions except the maximized constraints satisfaction and the minimized new indirectly inferred relationships between process-elements.
10. The method according to claim 1, wherein: the set of optimization conditions further comprises maximizing new and previous relationships between process-elements with default relationship value; the new relationships with default relationship value corresponding to new relationships between process-elements derivable from the process model to be evolved depending on the one or more user-defined constraints, to which default relationship value is attributable; and the previous relationships with default relationship value corresponding to previous relationships between process-elements from previous executions of the method, to which default relationship value has been attributed.
11. The method according to claim 10, wherein the set of optimization conditions further comprises deprioritizing the maximization of new and previous relationships with default relationship value with respect to any other optimization condition in the set of optimization conditions.
12. A computer program product comprising a computer a computer readable storage medium and program instructions stored on the computer readable storage medium for execution by at least one or more processors, the program instructions comprising: receiving one or more user-defined constraints to be satisfied by a process model to be evolved, the one or more user-defined constraints comprising logical rules or criteria indicated by a user; performing an optimization method to find a best solution of a cost function depending on a set of optimization conditions, over a solution space of possible consistent and/or sound process models derivable from the process model depending on the received one or more user-defined constraints, the optimization method comprising solving a problem of constraint satisfaction over the solution space of possible consistent and/or sound process models, and performing a multi-objective search method over the solution space of possible consistent and/or sound process models; the set of optimization conditions comprising maximizing constraints satisfaction corresponding to satisfaction of the received one or more user-defined constraints and of previous constraints from previous executions of the method, prioritizing the maximized constraints satisfaction with respect to any other optimization condition in the set of optimization conditions, and minimizing indirectly inferred relationships between process-elements derivable from the process model at least depending on the received one or more user-defined constraints, the indirectly inferred relationships comprising a relationship that is not explicitly defined by a constraint but preserves a soundness of the process model in evolution along with directly inferred relationship(s); and updating the process model with the obtained best solution.
13. (canceled)
14. (canceled)
15. A system for automatically evolving a process model including process-elements and relationships between process-elements, the relationships being defined as a relationship between the process-elements that cause satisfaction of user-defined constraints by a process model to be evolved, and the user-defined constraints comprising logical rules or criteria indicated by a user, the system comprising: a receiving module configured to receive one or more user-defined constraints to be satisfied by the process model; an optimization module configured to perform an optimization method to find a best solution of a cost function depending on a set of optimization conditions, over a solution space of possible consistent and/or sound process models derivable from the process model depending on the received one or more user-defined constraints, the optimization method comprising solving a problem of constraint satisfaction over the solution space of possible consistent and/or sound process models, and performing a multi-objective search method over the solution space of possible consistent and/or sound process models; and the set of optimization conditions comprising maximizing constraints satisfaction corresponding to a satisfaction of the received one or more user-defined constraints and of previous constraints from previous executions of the method, prioritizing the maximized constraints satisfaction with respect to any other optimization condition in the set of optimization conditions, and minimizing indirectly inferred relationships between process-elements derivable from the process model at least depending on the received one or more user-defined constraints, the indirectly inferred relationships comprising a relationship that is not explicitly defined by a constraint but preserves soundness of the process model in evolution along with directly inferred relationship(s); and an updating module configured to update the process model with the obtained best solution.
16. The method according to claim 9, wherein: the set of optimization conditions further comprises maximizing new and previous relationships between process-elements with default relationship value; the new relationships with default relationship value corresponding to new relationships between process-elements derivable from the process model to be evolved depending on the one or more user-defined constraints, to which default relationship value is attributable; and the previous relationships with default relationship value corresponding to previous relationships between process-elements from previous executions of the method, to which default relationship value has been attributed.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0030] Non-limiting examples of the disclosure will be described in the following, with reference to the appended drawings, in which:
[0031]
[0032]
[0033]
DETAILED DESCRIPTION OF THE INVENTION AND OF PARTICULAR EMBODIMENTS
[0034]
[0035] Such systems 100 may comprise a receiving module 102, an optimization module 103 and an updating module 104. The receiving module 102 may be configured to receive user input 101 defining one or more new constraints to be satisfied by the evolvable process model 105 once evolved. The optimization module 103 may be configured to perform an optimization method to find a best solution of a cost (or optimization) function depending on a set of optimization conditions, over a solution space of possible consistent and/or sound process models derivable from the evolvable process model 105 depending on the new constraint(s) as defined by user input 101. The set of optimization conditions may comprise maximization of constraints satisfaction or, in other words, minimization of constraints violation or dissatisfaction. The condition of maximizing constraints satisfaction may correspond to satisfaction of new constraint(s) defined by user input and of previous constrain(s) from previous executions of the method. The updating module 104 may be configured to update the process model 105 with the obtained best solution.
[0036] Functionality of performing the optimization method (executable by optimization module 103) may comprise performing a problem of constraint satisfaction over the solution space of possible consistent and/or sound process models derivable from the evolvable process model 105 depending on the new constraint(s).
[0037] Functionality of performing the optimization method (executable by optimization module 103) may include performing a multi-objective search method over the solution space of possible consistent and/or sound process models derivable from the evolvable process model 105 depending on the new constraint(s). In particular, functionality of performing the multi-objective search (executable by optimization module 103) may include performing an A* algorithm over the solution space of possible consistent and/or sound process models derivable from the evolvable process model 105 depending on the new constraint(s).
[0038] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions may further comprise prioritizing the maximization of constraints satisfaction with respect to any other optimization condition in the set of optimization conditions. In other words, the optimization method may be performed attributing maximum priority or weight to maximization of constraints satisfaction (or minimization of constraints dissatisfaction) with respect to remaining conditions in the set of optimization conditions.
[0039] In some examples, the new constraint(s) may be satisfied by different possible consistent and/or sound process models with different new indirectly inferred relationships between process-elements. That is, different possible sound process models in the solution space with one(s) or other(s) new inferred relationships (i.e. not defined in user input) may satisfy new constraint(s) defined by user input. In this case, functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises minimization of new indirectly inferred relationships between process-elements derivable from the evolvable process model 105 depending on the new constraint(s). User input may define new constraint(s) that the process model ideally should accommodate, in terms of new indirectly inferred relationship(s) between process-elements. New constraint(s) may be “translated” into new indirectly inferred relationship(s) between process-elements in the process, and this translation may be performed in different ways by deriving different new indirectly inferred relationship(s) between process-elements. The condition of minimizing new indirectly inferred relationships between process-elements thus pursues to identify possible process model(s) in the solution space with smallest number of new indirectly inferred relationships.
[0040] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises prioritizing the minimization of new indirectly inferred relationships between process-elements with respect to any other optimization condition in the set of optimization conditions except the maximization of constraints satisfaction. That is, in some examples, first maximum priority or weight may be attributed to maximization of constraints satisfaction and second maximum priority (below first maximum priority) may be attributed to minimization of new indirectly inferred relationships, with respect to remaining conditions in the set of optimization conditions which may have lower priority than first and second maximum priorities.
[0041] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises maximizing preservation of previously indirectly inferred relationships between process-elements in the evolvable process model from previous executions of the method. Previously indirectly inferred relationships are those already existing in the model to be evolved because they have been derived in previous executions of the proposed method. Maximizing preservation of previously indirectly inferred relationships may thus refer to keep maximum number of relationships between process-elements indirectly inferred in previous executions of the method (e.g. during whole evolving of the process model).
[0042] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises prioritizing the maximization of preserved previously indirectly inferred relationships between process-elements with respect to any other optimization condition in the set of optimization conditions, except the maximization of constraints satisfaction and the minimization of new indirectly inferred relationships between process-elements. That is, in some implementations, first maximum priority or weight may be attributed to maximization of constraints satisfaction, second maximum priority (below first maximum priority) may be attributed to minimization of new indirectly inferred relationships and third maximum priority (below second maximum priority) may be attributed to maximizing preservation of previously indirectly inferred relationships, with respect to remaining conditions in the set of optimization conditions which may have lower priority than first, second and third maximum priorities.
[0043] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises maximizing new and previous relationships with default relationship value/rule. New relationships with default relationship value/rule may correspond to new relationships between process-elements derivable from the evolvable process model 105 depending on the new constraint(s), to which default relationship value/rule is attributable. Previous relationships with default relationship value/rule may correspond to previous relationships between process-elements from previous executions of the method, to which default relationship value/rule has been attributed. Default relationship value/rule may be defined as predefined resolution to be implemented in the process model whenever user input does not explicitly define particular resolution. For example, if user input defines addition of particular activity with no further explicit specification, default relationship value/rule may cause addition of the particular activity sequentially after last added activity, or in parallel with respect to last added activity, etc. depending on predefined default relationship values/rules available for that aim. Maximizing new and previous relationships between process-elements with default relationship value/rule may thus refer to keep maximum number of new and previous relationships between process-elements implemented according to predefined default relationship value/rule.
[0044] Functionality of performing the optimization method (executable by optimization module 103) may take into account that the set of optimization conditions further comprises deprioritizing the maximization of new and previous relationships with default relationship value with respect to any other optimization condition in the set of optimization conditions. In other words, maximization of new and previous relationships with default relationship value/rule may be the optimization condition with smallest priority or weight in the set of optimization conditions.
[0045]
[0046] Evolving methods may further include (e.g. at block 201) receiving user input 101 defining one or more new constraints to be satisfied by the evolved process model. This functionality implementable at e.g. block 201 may be performed by e.g. receiving module such as module 102 previously described with reference to
[0047] Evolving methods may further include (e.g. at block 203) updating the evolvable process model 105 with the obtained best solution. This updating functionality implementable at e.g. block 203 may be performed by e.g. updating module such as module 104 previously described with reference to
[0048] Evolving methods may further include (e.g. at decision block 204) verifying whether an ending condition is satisfied, in which case the method may proceed to terminate its execution (e.g. block 205) and, otherwise, the method may loop back to e.g. block 201 for receiving new user input 101 and accordingly perform new iteration. Ending condition may refer to e.g. a state of the process model corresponding to final state, completely evolved state, user indication denoting completion of the model, etc.
[0049] Evolving methods may terminate (e.g. at block 205) when an ending condition has been detected (at e.g. decision block 204) such as e.g. request for ending the method or an invocation of the method from an operator of the system or the like.
[0050] As used herein, the term “module” may be understood to refer to software, firmware, hardware and/or various combinations thereof. It is noted that the modules are exemplary. The modules may be combined, integrated, separated, and/or duplicated to support various applications. Also, a function described herein as being performed by a particular module may be performed by one or more other modules and/or by one or more other devices instead of or in addition to the function performed by the described particular module.
[0051] The modules may be implemented across multiple devices, associated or linked to corresponding methods of automatically evolving a process model proposed herein, and/or to other components that may be local or remote to one another. Additionally, the modules may be moved from one device and added to another device, and/or may be included in both devices, associated to corresponding methods of automatically evolving a process model proposed herein. Any software implementations may be tangibly embodied in one or more storage media, such as e.g. a memory device, a floppy disk, a compact disk (CD), a digital versatile disk (DVD), or other devices that may store computer code.
[0052] The methods of automatically evolving a process model according to present disclosure may be implemented by computing means, electronic means or a combination thereof. The computing means may be a set of instructions (e.g. a computer program) and then the methods of automatically evolving a process model may comprise a memory and a processor, embodying said set of instructions stored in the memory and executable by the processor. These instructions may comprise functionality or functionalities to execute corresponding methods of automatically evolving a process model such as e.g. the ones described with reference to other figures.
[0053] In case the methods of automatically evolving a process model are implemented only by electronic means, a controller of the system may be, for example, a CPLD (Complex Programmable Logic Device), an FPGA (Field Programmable Gate Array) or an ASIC (Application-Specific Integrated Circuit).
[0054] In case the methods of automatically evolving a process model are a combination of electronic and computing means, the computing means may be a set of instructions (e.g. a computer program) and the electronic means may be any electronic circuit capable of implementing corresponding method-steps of the methods of automatically evolving a process model proposed herein, such as the ones described with reference to other figures.
[0055] The computer program(s) may be embodied on a storage medium (for example, a CD-ROM, a DVD, a USB drive, a computer memory or a read-only memory) or carried on a carrier signal (for example, on an electrical or optical carrier signal).
[0056] The computer program(s) may be in the form of source code, object code, a code intermediate source and object code such as in partially compiled form, or in any other form suitable for use in implementing the methods of automatically evolving a process model according to present disclosure. The carrier may be any entity or device capable of carrying the computer program(s).
[0057] For example, the carrier may comprise a storage medium, such as a ROM, for example a CD ROM or a semiconductor ROM, or a magnetic recording medium, for example a hard disk. Further, the carrier may be a transmissible carrier such as an electrical or optical signal, which may be conveyed via electrical or optical cable or by radio or other means.
[0058] When the computer program(s) is/are embodied in a signal that may be conveyed directly by a cable or other device or means, the carrier may be constituted by such cable or other device or means. Alternatively, the carrier may be an integrated circuit in which the computer program(s) is/are embedded, the integrated circuit being adapted for performing, or for use in the performance of, the methods of automatically evolving a process model proposed herein.
[0059]
[0060] Any model in the solution space may also be an evolvable process model.
[0061] In the particular example shown, new constraint may be expressed as “block of C is after A” which means that the activities C 304 and D 310 have to be performed after activity A 306. Evolvable process models may be SESE models and may include process-elements such as e.g. activities 304, 305, 306, 310, “parallel” or AND gateways 302, 308, “conflict” or “choice” gateways 303, 307, 311, 312, and relationships between said process-elements. A selector may identify a subset of activities in the process. The simplest one may be activity selector, which refers to a single activity. By mixing selectors and verbs that represent constraints, relationships between process-elements may be defined. Other basic selectors may be branch selector and block selector. Selectors may recursively work on other selectors, and are well-defined for Single-Entry Single-Exit (SESE) process models.
[0062] User input may define constraints to be satisfied by the evolving process model, and may be defined over a language that enables establishing constraints between process-elements or groups of process-elements. To identify arbitrary groups that should be related, this language may incorporate the notion of selectors as defined in other parts of the disclosure.
[0063] Selectors may have a basic form like “branch of SELECTOR” and “block of SELECTOR”. In SESE models, any activity is inside a block of activities whose entry point are gateways of the same type, or the start and end events respectively, and no edges can go from the activities inside the block to outside elements and vice versa. The expression SESE-block(S) may denote the activities of the smallest SESE block that includes the activities in S. Gateways 302 and 308 are AND (or “parallel”) gateways, while gateways 303, 307, 311 and 312 are XOR (or “conflict” or “choice”) gateways. Other types of gateway such as the ones available in e.g. BPMN 2.0 or any other known standard may also possible and considerable in the context of present disclosure.
[0064] The block selector of a selector SEL, where SEL represents set of activities S is simply the SESE-block(S). For instance, in
[0065] Once user has provided input defining constraint “block of C is after A” referred to model 300a, optimization process may start analysing corresponding solution space, such as the one partially represented by
[0066] The optimization method may then explore alternative models in the solution space, such as e.g. the ones illustrated by
[0067] Although only a number of examples have been disclosed herein, other alternatives, modifications, uses and/or equivalents thereof are possible. Furthermore, all possible combinations of the described examples are also covered. Thus, the scope of the disclosure should not be limited by particular examples, but it should be determined only by a fair reading of the claims that follow.