Embodiments are generally related to the field of business workflow management. Embodiments are also related to business process modeling techniques. Embodiments are additionally related to the provision of real-time business process suggestions and recommendations utilizing business process modelers.
A business process and/or workflow can be a collection of related structured activities or tasks that produce a specific service or product (serve a particular goal) for a particular customer. Driven by the increasing demand in business agility and cost efficiency, many businesses are seeking ways to compose distributed services into the business processes. Business process modeling is a time consuming manual process, which typically requires a business analyst to spend a significant amount of effort and carry out multiple iterations to define efficient and effective business processes.
Business process catalogues permits the business analysts to search for existing business processes based on categories, keywords, providers, etc. Such approach assumes the existence of meta-data (e.g., tags, categories and etc.) that accurately describes the business processes, however, this assumption cannot be met in a real world scenario. In most cases, business analysts attempt several combinations of keywords to determine the business processes, which is not intuitive to them. Business analysts can benefit from real time suggestions of next steps and/or complete business processes during modeling.
For example, a business analyst may provide connected components and the system can then suggests similar business processes from the business process catalogue. The analyst can select one of the suggested processes. The analyst can continue adding more edge(s) and/or component(s) if the suggestion does not meet the requirement of the analyst. The system can dynamically adjust suggestions considering the newly provided information. Such real time suggestion assist the business analysts efficiently finish modeling by only providing partial information.
A business process modeler can be employed to display the next-step syntactic components statically as icons as shown in
Several conventional business process modelers have been developed to provide support for displaying the static syntactic components and act as a template which is a placeholder for creating new business process or update the existing business process. The limitation of the existing business modelers is that the business analyst needs to be a domain specialist to create the business process. Hence, it is not possible to create the unique business process complaint with the business standards unless and until the analyst is aware of the particular business function.
In one conventional approach, a web based business process modeling tool can be implemented on top of a web-based editor (e.g., an ORYX editor) which has a pre-defined syntactic component. The problem associated with such approach is that the business analyst needs to be a domain specialist to create the business model and the business model provides similar set of static suggestions for all the elements. Another conventional business process modeling tool changes the type of task by hovering over the element and chooses new task type. Such an approach does not suggest analyst regarding next potential service or element semantically rather it just lists all the syntactic elements available in the system. Also, the system does not provide similar workflows available in the system and the analyst must be an expert in business process modeling.
Based on the foregoing, it is believed that a need exists for an improved system and method for providing real-time business process suggestion and recommendation utilizing a business process modeler, as will be described in greater detailed herein.
The following summary is provided to facilitate an understanding of some of the innovative features unique to the disclosed embodiments and is not intended to be a full description. A full appreciation of the various aspects of the embodiments disclosed herein can be gained by taking the entire specification, claims, drawings, and abstract as a whole.
It is, therefore, one aspect of the disclosed embodiments to provide for an improved business workflow management systems and methods.
It is another aspect of the disclosed embodiments to provide for an improved business process modeling techniques.
It is a further aspect of the disclosed embodiments to provide for an improved system and method for providing a real-time business process suggestion.
It is yet a further aspect of the disclosed embodiments to provide for an improved system and method for providing an interactive business recommendation utilizing a business process modeler.
The aforementioned aspects and other objectives and advantages can now be achieved as described herein. A system and method for providing a real-time business process suggestion and recommendation utilizing a business process modeler is disclosed herein. A dynamic input from a business analyst can be incorporated utilizing a real-time suggestion engine. A real-time search can be performed by organizing a number of business processes in a tree structure where each leaf node represents a business process and each branch node represents a set of components that are shared by the business processes in a sub tree. A semantic execution path search can be performed to provide a real-time match between the partial business process and a catalogue of existing business processes by determining a constituent component and a score based on a reachability rule. The edges and/or components can be added and/or deleted to effectively organize the existing business processes based on previous suggestion to speed up a future suggestion. A business process modeler can be configured with an auto-completion based recommendation to display a potential service with respect to the business process as an icon and an expansion recommendation to display a major component and a relative sequence in the business process while creating a workflow.
A constituent component in the partial business process can be determined and a most constituent component can be searched in the tree for the branch node(s). If no such node is found, the constituent component can be compared with all the direct children business processes of the root and the business processes that share components with the partial business processes can be returned. The constituent components can be marked for every business process in the sub tree of the branch node. The reachability rule can be extracted and compared with the partial business process to generate the score, where a higher score determines a better match. If the complete business process lacks one reachability rule, a pre-defined number can be added to the score. The list of business processes can be returned in an ascending order of the scores. The user can add and delete edges/components based on previous results, which can significantly improve the efficiency especially when the system possesses a large set of business processes in its repository.
The business process modeler can be customized to display the recommended services for the newly created workflow to achieve a complete end-to-end product. A registered service from a service composition platform can be employed to generate the next potential service. The registered service can be stored in a database and loaded in the business process modeler. Each service can be fetched from the database and can be created as a bean class before the service is loaded into the business process modeler. Internally, each class can be added and mapped based on heuristics so that a corresponding next service can be invoked based on a mapping value and displayed in the business process modeler when the business analyst select the service from the business modeler. Such auto completion feature saves enough time in business process creation.
An expansion recommendation link can be selected to provide suggestion for the created business process after completing the business process by dragging and dropping the required processes in the business modeler. The expansion based recommendation guides the business analyst to complete the business process and to identify the next set of services. The expansion recommendation functionality compares a mapping file which includes services that are available in the business process modeler. The mapping file can be created based on heuristics. The expansion recommendation also provides the recommended service as an alternative for a specific created service and similar workflow that exists in the repository.
The accompanying figures, in which like reference numerals refer to identical or functionally-similar elements throughout the separate views and which are incorporated in and form a part of the specification, further illustrate the present invention and, together with the detailed description of the invention, serve to explain the principles of the present invention.
The embodiments will now be described more fully hereinafter with reference to the accompanying drawings, in which illustrative embodiments of the invention are shown. The embodiments disclosed herein can be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like numbers refer to like elements throughout. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As will be appreciated by one skilled in the art, the present invention can be embodied as a method, data processing system, or computer program product. Accordingly, the present invention may take the form of an entire hardware embodiment, an entire software embodiment or an embodiment combining software and hardware aspects all generally referred to herein as a “circuit” or “module.” Furthermore, the present invention may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium. Any suitable computer readable medium may be utilized including hard disks, USB Flash Drives, DVDs, CD-ROMs, optical storage devices, magnetic storage devices, etc.
Computer program code for carrying out operations of the present invention may be written in an object oriented programming language (e.g., Java, C++, etc.). The computer program code, however, for carrying out operations of the present invention may also be written in conventional procedural programming languages such as the “C” programming language or in a visually oriented programming environment such as, for example, Visual Basic.
The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer. In the latter scenario, the remote computer may be connected to a user's computer through a local area network (LAN) or a wide area network (WAN), wireless data network e.g., WiFi, Wimax, 802.xx, and cellular network or the connection may be made to an external computer via most third party supported networks (for example, through the Internet using an Internet Service Provider).
The embodiments are described at least in part herein with reference to flowchart illustrations and/or block diagrams of methods, systems, and computer program products and data structures according to embodiments of the invention. It will be understood that each block of the illustrations, and combinations of blocks, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general-purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the block or blocks.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function/act specified in the block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions/acts specified in the block or blocks.
As illustrated in
The following discussion is intended to provide a brief, general description of suitable computing environments in which the system and method may be implemented. Although not required, the disclosed embodiments will be described in the general context of computer-executable instructions such as program modules being executed by a single computer. In most instances, a “module” constitutes a software application.
Generally, program modules include, but are not limited to, routines, subroutines, software applications, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types and instructions. Moreover, those skilled in the art will appreciate that the disclosed method and system may be practiced with other computer system configurations such as, for example, hand-held devices, multi-processor systems, data networks, microprocessor-based or programmable consumer electronics, networked PCs, minicomputers, mainframe computers, servers, and the like.
Note that the term module as utilized herein may refer to a collection of routines and data structures that perform a particular task or implements a particular abstract data type. Modules may be composed of two parts: an interlace, which lists the constants, data types, variable, and routines that can be accessed by other modules or routines, and an implementation, which is typically private (accessible only to that module) and which includes source code that actually implements the routines in the module. The term module may also simply refer to an application such as a computer program designed to assist in the performance of a specific task such as word processing, accounting, inventory management, etc.
The interface 253, which is preferably a graphical user interface (GUI), also serves to display results, whereupon the user may supply additional inputs or terminate the session. In an embodiment, operating system 251 and interface 253 can be implemented in the context of a “Windows” system. It can be appreciated, of course, that other types of systems are possible. For example, rather than a traditional “Windows” system, other operation systems such as, for example, Linux may also be employed with respect to operating system 251 and interface 253. The software application 254 can include a business process suggestion and recommendation module 252 for providing a real-time business process suggestion and recommendation utilizing a business process modeler 385. Software application 254, on the other hand, can include instructions such as the various operations described herein with respect to the various components and modules described herein such as, for example, the method 400, 600, and 800 depicted in
Business Process Modeling (BPM) in systems engineering is the activity of representing processes of an enterprise, so that the current process may be analyzed and improved. BPM is typically performed by business analysts and managers who are seeking to improve process efficiency and quality. The business process suggestion and recommendation module 252 provides a real-time match between the partial business process and a catalogue of existing business processes. The system 300 further includes a real-time engine 305, a score generation unit 310, and a business process modeling unit 335 connected to the data-processing system 200 via a network 352.
Note that the network 352 may employ any network topology, transmission medium, or network protocol. The network 352 may include connections such as wire, wireless communication links, or fiber optic cables. Network 352 can also be an Internet representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational, and other computer systems that route data and messages.
The real-time engine 305 incorporates a dynamic input 315 from a business analyst 249. A real-time search 350 can be performed by organizing a number of business processes in a tree structure 355 where each leaf node 360 represents a business process and each branch node 365 represents a set of components that are shared by the business processes in a sub tree. The score generation unit 310 marks a constituent component 320 and extracts and compares a reachability rule 325 with the partial business process to generate a score 330 for every business process. The score generation unit searches the branch node(s) 365 that includes a most constituent component 320 in the tree 355. If no such node is found, the constituent components 320 in the partial business can be compared with all direct children business processes of the root and the business processes that share components with the partial business processes can be returned.
If a complete business process lacks one reachability rule 325, a pre-defined number can be added to the score 330. The score generation unit 310 returns the list of business processes in an ascending order of the scores 330. The score generation unit 310 modifies the scores 330 of the business processes when the user adds more edge(s) and if it adds new reachability rule(s) 325 to the partial business process. The user can add and delete more components based on previous results, which can significantly improve the efficiency especially when the system 300 possesses a large set of business processes in its repository. The business process modeling unit 335 can be configured to include an auto-completion based recommendation module 340 and an expansion recommendation module 345. The auto-completion based recommendation module 340 displays a potential service with respect to the business process as an icon and the expansion recommendation module 345 displays a major component and a relative sequence in the business process while creating a workflow.
The constituent components 320 in the partial business process can be determined and search in the tree 355 for the branch node(s) 365 that contain the most constituent components 320, as shown at block 440. If no such node is found, compare with all the direct children business processes of the root and return the business processes that share components with this partial business processes. The business processes in the sub trees of the branch node(s) 365 can be obtained for every business process. The constituent components 320 can be marked and their reachability rules 325 can be extracted and compared with the partial business process to generate the score 330, where a higher score means a better match, as indicated at block 450.
1->2:1; 1->5:1; 1->4:2
2->4:1
4->2:1 (1)
Suppose the system 300 determines two candidate business processes 560 as shown in
1->2:1; 1->5:1; 1->4:2
2->4:2
4->2:2 (2)
and BPy can be described in the following rules.
1->2:1; 1->5:2; 1->4:4
2->4:3
4->2:2 (3)
The score can be calculated as Σk1εn, k2εm|Li,(k1,k2)−Lj(k1,k2)|, where Li,(k1,k2) represents the shortest path of k1->k2 in the partial business process and Lj,(k1,k2) represents the shortest path of k1->k2 in one complete business process. The score of BPx is 2 and the score of BPx is 6. If a complete business process lacks one reachability rule 325 (for example, it does not have x->y), a pre-defined number can be added to the score. Thereafter, as shown at block 460, the list of business processes can be returned in ascending order of scores 330. As a result, BPx ranks higher than BPy in the return list.
The existing business processes can be effectively organized and built on previous suggestions to speed up future suggestions while modeling business process by adding/deleting edges and/or components, as illustrated at block 470. For example, when the user adds more edge(s) and if it adds new reachability rule(s) 325 to the partial business process, modify the scores 330 of the business processes as shown at block 460. When the user adds more component(s), start from the branch node(s) identified in block 440 and repeat steps from block 440 to 460. When the user delete component(s), traverse back from the current branch node(s) identified in block 440 to the new branch node and then repeat step in block 450 and 460.
The next potential services for ‘ocr’ can be displayed in the business process modeler 750, as indicated at block 660. When the analyst selects CrowdVerification followed by fileStorage, the diagram can be represented as mentioned in
The expansion based recommendation unit guides the business analyst 249 to complete the business process to identify the next set of services or similar workflow. The analyst selects each required service from the business process modeler 385 and completes the workflow. For example, the analyst can select OCR and FileStorage, as depicted in
Each service includes the mapping and is created based on heuristics. The mapping file can be compared for each created service which then provides the recommended workflow for the selected services. The recommended service can also be provided as an alternative for the specific created service, as shown at block 830. For example, in
It will be appreciated that variations of the above-disclosed and other features and functions, or alternatives thereof, may be desirably combined into many other different systems or applications. Also, that various presently unforeseen or unanticipated alternatives, modifications, variations or improvements therein may be subsequently made by those skilled in the art which are also intended to be encompassed by the following claims.