AUTOMATICALLY EVOLVING A PROCESS MODEL

20230367282 · 2023-11-16

Assignee

Inventors

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] FIG. 1 is a block diagram schematically illustrating systems for automatically evolving a process model according to examples.

[0032] FIG. 2 is a flow chart schematically illustrating methods of automatically evolving a process model according to examples.

[0033] FIGS. 3a-3d schematically illustrate a process model to be evolved and possible consistent and/or sound process models derivable from said evolvable process model depending on new constraints, according to examples.

DETAILED DESCRIPTION OF THE INVENTION AND OF PARTICULAR EMBODIMENTS

[0034] FIG. 1 is a block diagram schematically illustrating systems for automatically evolving a process model according to examples. The evolvable process model 105 may include process-elements and relationships between process-elements, as it will be described in detail with respect to other figures. The evolvable process model 105 may have been retrieved from e.g. a repository of evolvable process models 105 and/or may have been outputted by previous execution of corresponding “evolving” method. Once retrieved or received or obtained, the evolvable process model 105 may have been stored in execution memory until corresponding evolving method according to present disclosure is performed as many times as required until the evolvable process model 105 has been evolved completely or as desired. The evolvable process model 105 may be e.g. a Single-Entry Single-Exit (SESE) model. The evolvable process model 105 may describe control-flow aspects and other process model aspects known in the prior art, such as e.g. the ones defined by standard BPMN 2.0 or any other available standard.

[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] FIG. 2 is a flow chart schematically illustrating methods of automatically evolving a process model according to examples. As generally shown in the figure, such “evolving” methods may be initiated (e.g. at block 200) upon detection of a starting condition such as e.g. a request for starting the method or an invocation of the method from an operator of the system or the like. Since evolving methods according to FIG. 2 are performable by systems according to previous figure, number references from FIG. 1 may be reused in following description of FIG. 2.

[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 FIG. 1. Functional details and considerations explained about said module 102 may thus be similarly attributed to method block 201. Evolving methods may further include (e.g. at block 202) 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 105 depending on the one or more new constraints. The set of optimization conditions may comprise maximization of constraints satisfaction corresponding to satisfaction of the one or more new constraints and of previous constrains from previous executions of the method. This optimization functionality implementable at e.g. block 202 may be performed by e.g. optimization module such as module 103 previously described with reference to FIG. 1. Functional details and considerations explained about said module 103 may thus be similarly attributed to method block 202.

[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 FIG. 1. Functional details and considerations explained about said module 104 may thus be similarly attributed to method block 203.

[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] FIGS. 3a-3d schematically illustrate an evolvable process model 300a, and some possible consistent and/or sound process models derivable from said evolvable process model 300a depending on new constraint(s). That is, a partial solution space of possible solutions is shown.

[0060] Any model in the solution space may also be an evolvable process model. FIG. 3a shows an example of process model to be evolved 300a and FIGS. 3b-3d illustrate different possible evolutions of the process model 300a within the solution space of possible consistent and/or sound process models derivable from 300a depending on a new constraint (defined by user input). Model to be evolved 300a is shown with a process-element indicating start of the process 301 and another process-element indicating end of the process 309.

[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 FIG. 3a, block of B 305 represents {B, A} (i.e. block containing activities 305, 306). In FIG. 3c, block of B 305 represents {B, C, A, D} (i.e. block containing activities 304, 305, 306, 310). A branch selector identifies all the activities that are in a sequential relation with the activities of the given selector S inside the SESE-block(S). For example, in FIG. 3c, branch of B 305 represents the set {B, C, D} (i.e. branch or sequence containing activities 304, 305, 310).

[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 FIGS. 3b-3d. As a way of example, it may be assumed that cost function considers, in order of relevance, minimizing number of violated constraints (or maximizing number of constraints satisfaction) and minimizing number of new indirectly inferred relationships. In the initial state 300a, the cost would be (2, 0), since activity C 304 and activity D 310 are not after activity A 306, and the user input has not explicitly specified that activity C 304 and/or D 310 have to be after the block of activity A 306, which implies that activities C 304 and D 310 have not to be after activity B 305, which is actually happening in the initial situation 300a.

[0066] The optimization method may then explore alternative models in the solution space, such as e.g. the ones illustrated by FIGS. 3b-3d. In explored state 300b of FIG. 3b, the cost function evaluates to (0, 2), since activities C 304 and D 310 are after activity A 306, but activities C 304 and D 310 are also after activity B 305. In explored state 300c of FIG. 3c, the cost function evaluates to (2, 2), since activities C 304 and D 310 are after activity B 305, but activities C 304 and D 310 are not after activity A 306. In explored state 300d of FIG. 3d, the cost function evaluates to (0, 0), since activities C 304 and D 310 are after activity A 306 and activities C 304 and D 310 are not after activity B 305. Accordingly, process model 300d of FIG. 3d may be selected as best solution since its function has the lowest pair of values in comparison with the other explored states in solutions space.

[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.