The invention relates to methods of analysing specifications of multi stage processes, to optimise such processes, or for other purposes, to programs or systems arranged to carry out such analysis, to processes described by specifications subjected to such analysis, to templates for such processes, to services using such programs and to programs for analysing such processes in use.
Conventional commercial processes can typically be seen as a mixture of data processing stages or transactions on data accessed from data stores, and human actions such as a customer deciding which product to buy, and entering address and credit card details, or a human operator telephoning a supplier for example. Each data processing stage can involve a software program which queries a database. In a typical case, one stage could be concerned with taking customer orders, and could maintain a database of customer orders. A separate program could be responsible for issuing orders to suppliers, and could access the same database. There can be many stages in more complex processes. Problems can arise from errors in any program or in the data it needs. Despite many advances in software development, it is still impractical to test for correct operation in every set of circumstances. Also, in some cases, the performance of the process can be limited by the performance of the databases. There are a number of ways to address this, including providing upgraded hardware servers, or more servers, or by upgrading the database software for example.
Some of the issues and difficulties in designing and implementing mixed transactions are described in patent publication WO 0171621, such as coordination of computer resources necessary to implement even a single business process. In every large business, numerous incompatible computing platforms, operating systems, networking protocols, databases, and custom applications coexist. The various environments must be integrated in order to implement a new business process. In recent years, Message-Oriented-Middleware (MOM) products have been used to aid in the integration of disparate computing systems. Typically, such middleware products provide interfaces to applications by capturing, analysing, and exchanging information via “events.” This mechanism allows business analysts to integrate many diverse application platforms to work together. While middleware products allow business applications to communicate together, they do not ease the task of automating new business processes. Middleware products are often ineffective in reusing a business structure or business knowledge between applications. Instead, when such a business structure or knowledge must be reused, a new application must be created from scratch.
When structures or knowledge must be reused, many businesses have turned to object-oriented development environments to meet this need. Since reusability is an important element in the object-oriented paradigm, this approach should allow new applications to be developed by reusing objects created in earlier applications. Unfortunately, because of the technical nature of object creation, definition, and refinement, many of reusability advantages of the object-oriented paradigm are inaccessible to the typical business process analyst. The solution proposed in the above mentioned patent publication is a set of tools that allow the graphical definition of top-down workflow process models. Once defined, these models are completely useable enterprise applications that can be deployed in real-time without interrupting current business operations.
Another example shown in U.S. Pat. No. 6,473,748 discusses a rule based or expert system approach using middleware such as CORBA software objects and an object request broker. Problems associated with implementing business rules for an enterprise include the following. For example, the human reasoning behind a rule, or the “essence” of the rule, is often changed in transitioning from human-oriented user requirements to actual software code. Another potential problem is that the same logical rules may be implemented in several different software applications in an inconsistent manner. When rules are implemented as software code, the identification of specific business rules within a software application, or across several software applications, is often difficult or impossible. The solution proposed is separating business rules from application logic. This architecture effects the implementation of software business rules in a single location, for sharing across software applications as needed. Software business rules are created and maintained by business experts directly, rather than requiring programmers to translate the rules to software code. U.S. patent application 2003/0167194 shows a method of generating a process definition. It discusses workflow systems (i.e. process management packages) for controlling processes that are definable and governed by a series of policies and procedures, for example insurance claim processing, mortgage loan processing and engineering change orders. Workflow systems are based on procedure definitions that define which process activities must be performed and the sequence in which the activities must be performed. The procedure is defined using activity nodes connected via arcs, which represent activities of a process. Examples of activity node types are work nodes that typically perform, or initiate, a service and route nodes that are used to define the routing within the process. The activity nodes may incorporate rules that define entry conditions for the activity node and exit conditions that need to be checked after the activity node is completed. However, in practice a large number of aspects associated with businesses activities that are essential for a business solution escape a process-based formalisation. To counter this, the patent application proposes generating a process definition for execution by a process management system comprising a processor for generating a sequence of activities using information associated with messages exchanged between at least two business entities as part of a business process, wherein the sequence of activities correspond to the business process. It can involve monitoring messages exchanged between the at least two business entities.
U.S. Patent Application 20020049621 relating to decision dynamics, shows analysing a process in terms of the elements that are the drivers of the process. A process is evaluated in terms of one or more scheduling drivers and process drivers, the metrics around the drivers are measured and the measured values related to key performance indicators of the drivers and the overall process. The metrics of the drivers can be correlated to past performance to determine if the attributes of the drivers being measures should be changed. It is appropriate for evaluating the processes of a business organization where the processes can be defined by one of the following five process flows.
1) Research Process Flow (RPF). RPF represents independent activities which start and end exclusively of each other and do not trigger the starting of other activities. An example of this process flow is a market research firm which conducts research on several unrelated projects.
2) Research and Development Process Flow (R&DPF). R&DPF configures independent related groups of activities which start and end exclusively of other groups of activities, or loosely related to other groups of activities. Each group is comprised of activities related to each other by the finishing of one activity triggering the beginning of the next activity(s) within the group. An example of this process flow is a research and development laboratory of a drug company.
3) Development Process Flow (DPF). DPF configures groups of activities which start and end in relation to one another. The exact beginning or ending of a group of activities is frequently not known. Rather, there is a loose causality relationship that triggers the beginning and/or ending of related groups. All groups of activities are related by the purpose to perform work on a common entity. Optional triggering of potential activities may depend on other objects in the system, such as resources.
4) Project Process Flow (PPF). PPF configures individual groups of activities not related to other groups of activities within the system. Each group is comprised of activities which are related to each other because the finishing of one activity triggers the beginning of one or more activities within the group. An example is a law firm or consulting office working on several different legal or business problems for several different clients.
5) Operations and Maintenance Process Flow (O&MPF). O&MPF is an array of sequentially occurring activities with the completion of each activity triggering one or more activities. An example of this process flow is a manufacturing line for the manufacturing of an article in a factory. Nevertheless, difficulties remain in making processes reliable and efficient.
It is an object of the invention to provide an improved program or an improved method or apparatus for the same.
A first aspect of the invention provides:
A computer program arranged to analyse a specification for a process, the process involving two or more stages and involving processing of stored data, the program being arranged to:
Monitoring a process at its output or at intermediate points is usually necessary in order to control or refine the process or the resources needed for the process. However monitoring often involves a considerable cost, so there is great benefit in being able to measure this cost at the time of specifying the monitoring in the process design. Measuring the cost can enable the cost to be reduced or the monitoring to be optimised for a given cost.
Making the monitoring efficient is even harder in the common situation where coordination of different computer resources used at different stages of the process is necessary to implement even a single process. Often in practice there are numerous incompatible computing platforms, operating systems, networking protocols, databases, and custom applications coexisting. Implementing processes in environments with many such incompatibilities, can be made easier by embodiments of the invention.
The term “process” is used here as encompassing commercial or technical processes or any other type of process. Commercial processes can encompass internet based trading of products or services, and financial information processing and so on. Technical processes can encompass control of any kind of physical systems, such as air traffic control, manufacturing process control, communications network management and so on.
Additional features, for dependent claims, include rearranging the process to reduce the cost of monitoring. Another such feature is this identifying of monitoring points involving identifying branch points in the process. Another such feature is the rearranging involving reducing a number of the branch points. Another such feature is the determining of cost involving determining a cost of resources in processing and communicating monitor information to a central location. This can include the cost to the underlying system of including the monitors. Another such feature is the monitoring involving recording rates of choice and entry and exit times at branch points. Another such feature is the process having a combination of automated and non automated steps. Another such feature is rearranging automated steps in accordance with semantics preserving rules.
Another aspect of the invention provides a computer program arranged to analyse a specification for a process, the process involving two or more stages, and involving processing of stored data, the program being arranged to:
Another aspect of the invention provides:
A computer program arranged to analyse a specification for a process, the process involving two or more stages, and involving processing of stored data, the program being arranged to:
This is notable where the cost of database accesses is considerable, or where the time taken to access data is limiting performance of the process for example, or where the database is becoming overloaded by too many access requests.
Additional features, for dependent claims, include reducing an amount of accesses by rearranging process, or by optimising over a lifecycle of the data requested, or by identifying when a later data access can be brought forward and combined with an earlier data access. Further such features include identifying a probability of the later data access becoming redundant, and using that and the cost saved by the combining, to determine whether to implement the combining.
Another aspect of the invention provides
A computer program arranged to analyse a specification for a process, the process involving two or more stages, and involving processing of stored data, the program being arranged to:
As database locking can cause many queries to fail and therefore cause many retries, it can severely limit database performance. Hence there is great benefit in being able to optimise the locking to reduce it while still having enough to maintain consistency, and to ensure there is no sharing of data where this is unwanted. This is especially beneficial for large scale databases such as those distributed over many servers, or those distributed geographically.
Additional features, for dependent claims, include deriving dependency diagrams from the specification including any write dependencies on a read action, and the inference involving deriving data dependencies and reducing these dependencies. Further such features include rearranging the process to minimise the dependencies, and deriving a scope of locking from the dependencies. Further such features include the inference involving using associated declaration to reorder and combine queries. Further such features include the process having steps for control of a physical system. Further such features include analysing the process using information derived from the process in use. This can be useful to further check or optimise the process in use rather than that specified. This can be useful in various ways. For example, it may determine that users are entering data in different formats to those anticipated, or in different quantities, or that other aspects or the human interface are being used differently to the ways anticipated in the specification of the process.
Another aspect of the invention provides:
A process specification which has been created using (optimised or checked by) the analysis program set out above. This reflects that the commercial value may be greater in the output of the analysis program than the sale value of the analysis program itself.
Another aspect of the invention provides a method corresponding to the program.
Another aspect of the invention provides:
A process template for application to various processes, the template having been created using (optimised or checked by) the analysis program set out above. The template is intended to encompass higher level specifications such as process guidelines, process architectures, empty shell type structures, specifications with prompts for aiding completion, and many other forms.
Another aspect of the invention provides a method of offering a process analysis service using the program as set out above. This reflects that the services enabled by the use of the program could be more valuable than the sale value of the program itself.
Other advantages will be apparent to those skilled in the art. The abovementioned optional features may be combined together or combined with any aspect of the invention.
Embodiments will now be described by way of example with reference to the drawings in which:—
The design control logic is arranged to follow instructions from the user to design the process, based on the process requirements and constraints. The design control logic is arranged to assist the user in a number of ways. Firstly it can aid the designer in producing a specification, by suggesting possible options which are available and consistent with the process requirements, and the part-completed specification. Secondly, the logic can analyse the specification or the part-completed specification, and check it for consistency, optimize the specification, to remove redundancies, to compress the specification, and to ensure interoperability with entities external to the process, such as underlying computer systems and communication systems, existing and new data bases, human interfaces for the process, and so on.
The logic can be arranged to check and optimise the part-complete specification. If there are any inconsistencies, the control logic can be used to flag a potential error to the user through the GUI. Optionally, the logic could be arranged to propose changes to correct the inconsistency, based on selecting from predetermined modules or stages, or other methods.
The control logic can also be arranged to look for non-optimal features in the process. These can include elements which are redundant, or which involve unnecessary coercion for example. Unnecessary coercion is defined as instances where data formats need to be converted unnecessarily, for example converting integers to long integers and back again for a logic test which makes no use of the long format. A common case involves data entry in a format which needs to be changed every time the data is used. If the data type could be changed to a more suitable format at the outset, many unnecessary conversion processing steps can be removed. An example is storing a date as a text string which must be re-parsed every time it is used.
The end result of the design process is an output from the design control logic which can include a completed specification of the process, and typically programs for stages of the process. The process design program can be implemented in any conventional software language running on conventional hardware such as workstations typically linked to file servers by a local area network. The format of the output will depend on the type of process and the environment for which it is designed. In the case of an example of an internet based product supply process, the specification could be in the form of a text document specifying programs, interfaces and data base accesses and human interfaces to customers and to staff of the organisation running the service. The text document could refer to programs or program modules written in conventional languages such as Java, weakly typed languages including C, or strongly typed functional languages such as “Miranda” or “Haskell” for example. Checking of the individual programs can be carried out using conventional techniques at compile time, including type inference techniques for example and some checks can be carried out at run-time.
The different stages can involve computerised processing of data or manual or human processing of data, or a mixture. The data can represent almost anything, depending on the application of the process. One example might be processing an order for a product advertised on the internet. The user input could be an order for the product, together with a reference identifying the product, and an address and other details to enable payment and delivery. The various stages could make use of existing programs or procedures for arranging manufacture of the product or supply of parts for the product for example, or handling payment. The data base could be an inventory control data base, or a customer order data base for example, using conventional data base techniques. The data base could run on conventional servers, using a relational data base management system and query language such as SQL. The information input by the customer could include information such as address and postal code information. The data type of such a postal code could be considered as a compound data type including string types and integer types. This could be checked for consistency with the city field of the address for example, to ensure a correct postal code has been entered. It is much more efficient to catch errors such as incorrect postal codes at this early stage, rather than later in the process. The postal code information could be used at later stages in the process, for example in a program for arranging a delivery sequence or schedule. This could make use of existing programs for scheduling.
Such programs are likely to be written in a language incompatible with other programs in other stages. Nevertheless, it may be impractical to rewrite the functions of such existing programs, and therefore it is necessary to make use of them in the overall process. The designer of the process can use various methods to check the overall operation of the process to overcome problems caused by incompatibilities.
During operation of the process, it will be become clear which of many possible paths in the process are actually being used, or overused. The process monitoring element can be arranged to alter the process, or suggest alterations to a designer, depending on how the process is used in practice. For example, it may determine that users are entering data in different formats to those anticipated, or in different quantities, or that other aspects or the human interface are being used differently to the ways anticipated in the specification of the process. The monitoring element can look at actual data, rather than using the estimated data of the specification. Furthermore, this element can help identify paths in the process which are never used, and can propose that these be removed, or altered to make them more useful for example. The most used paths in the specification can optionally be re optimised, at the expense of less used paths. Potential limitations such as processing delays or processing power of stages can be assessed based on real life information, rather than the estimates in the specification.
An example involves monitoring how often exceptions are used. In some cases, exception handling code can expand to a disproportionate amount, e.g. 70%. But exception handling is typically the least well tested code, routine testing concentrates on the expected paths, not the exceptions. Hence if the most used exceptions can be identified, mainstream paths can be created so that they are no longer handled as exceptions. Reliability can be enhanced as a result.
The cost models store 130 is arranged to generate and store cost frames for a transaction from the medium that implements that transaction. This is to address the problem that costs of a complex transactional system may be difficult to specify where there are large numbers of cost types and cost amounts. If the media associated with a transaction is known, for example a data base access, a phone call, a fax transmission, an internet access, then a cost value can be assigned automatically based on typical costs for that medium, without the additional effort or complication of determining individual costs for such transactions or slightly varying transactions many times over.
At step 220 the cost of the selected monitoring points is determined in terms of operating costs such as processing costs and the cost of transmitting the monitoring results to a central location such as the element 150 of
At step 250 for each database access, a search is made for earlier accesses of the same data. The search can be made downstream to find later accesses of the same data as desired. IF the data gathering can be shifted to a single point by combining accesses, then interaction with the database can be minimised. At step 260, a further optional step is to determine a probability of the combined data access becoming needless. The cost benefit of the combined access is also determined. At step 270 a decision is made whether to implement the combined data access.
Notably this can help enable the design process to be carried out without the designer needing to be concerned about database optimisation. The designer can start with database accesses as needed and later allow automated optimisation.
Furthermore, by using associated declaration to do the reordering and combining of queries, a search can be made for optimal arrangements of queries given the locking that is in place.
An example will now be explained. A simple business process is as follows
A database only needs to be locked if it is being read from and or written to and a decision based upon the read and/or success of write is being made in this case. By locking the database, other processes can not access it. The process above locks the database for the complete process (as might be written by many programmers of business process) and this means that if there are many other identical (but with different customers) processes attempting to run then they will be blocked, despite the fact that no meaningful access of the database is being made. It can be rewritten (as per the process design program of the embodiment) so that it becomes
There are now three points at which other processes can access the database, enabling significantly greater potential sharing of the database of goods in stock (especially when things like credit card authorization and shipping management can take in order of seconds compared with database lock and unlock in the order of micro seconds. If a dealer did not hand optimise this (as opposed to the machine based automation) then it would severely limit the number of accesses and therefore sales they could make.
Applications and Other Remarks
The advantages discussed above can apply to any process, including processes which involve a mixture of automated and non-automated steps, mixtures of data processing data base access steps and human inputs. In principle it can apply to processes for controlling physical systems, or for processes relating to service delivery, including services of providing value added information from raw data.
Examples of implementation of the design program or programs making up the process can include program objects that can be invoked via different programmatic paradigms e.g. API (application program interface, CLI (command line interface) and others, and can be invoked on a variety of different platforms including, but not limited to, a JAVA platform, an XML platform, a COM (common object model) platform and an ODBC (open database connectivity) platform for example. Embodiments of the present invention can be implemented as a computer program product that includes a computer program mechanism embedded in a computer readable storage medium. The program can take the form of instructions, rules, objects, look up tables, hardware descriptions, combinations of these and other forms. The computer program product could contain program modules. These program modules may be stored on a CD-ROM, magnetic disk storage product, or any other computer readable data or program storage product. The software modules in the computer program product may also be distributed electronically, via the Internet or otherwise, by transmission of a computer data signal (in which the software modules are embedded) on a carrier wave.
The advantages can also be obtained by offering a process analysis service using the program, which could prove more valuable than selling the program or a system. As the benefits will cascade down to users of the processes, in terms of more reliable and effective processes, another valuable aspect is a method of offering a service using a process created or optimised by an example of the above mentioned program. As has been described above, a computer program analyses a specification for a process, by analysing automatically the specification of the process to identify a set of monitoring points, and determine automatically a cost of the monitoring. Measuring the cost can enable the cost to be reduced or the monitoring to be optimised for a given cost. The analysis can include identifying database accesses, and determine automatically how to reduce the amount of database accesses to improve database performance. It can also analyse automatically the specification to identify database accesses which involve database locking, and infer automatically how to reduce the scope and range of the locking, to improve database performance. Other variations and applications can be conceived by those skilled in the art which are intended to be within the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
0415469.6 | Jul 2004 | GB | national |