This invention relates to derivation of business system transfer functions, and in a more particular implementation, to derivation of transfer functions having predictive capability for integration into a business intelligence system.
Managing the operation of a business, such as an industrial, financial service or healthcare business, in a way that fulfills the organization's mission requires information, decision-making and control of the business' processes. To assist decision-makers, it could be desirable to provide them with a qualitative description of the operation of their business processes. It would also be helpful to provide a view into how the business processes might behave in the future. This information and prediction can help the decision maker to manage and control the business effectively.
It is taken as a given that it is impossible to know for certain what the future holds and a variety of automated techniques exist for making business forecasts and decisions, including various business simulation and automation techniques. These have accuracy limitations and these techniques are often applied in a quantitatively unstructured manner. For instance, a business analyst may have a notion that the business might be mathematically described in a particular way or that computer-automated statistical forecasting tools might be of use in predicting certain aspects of business performance based on the relationships between the outputs and the inputs of the business. In this case, the business analyst proceeds by selecting tools, determining the data input requirements of the selected tool, manually collecting the required data from the business, and then performing a forecast using the tool to generate an output result. The business analyst then determines whether the output result warrants making changes to the business. If so, the business analyst attempts to determine what aspects of the business should be changed, and then proceeds to modify these aspects in manual fashion, e.g., by manually accessing and modifying a resource used by the business. If the result of these changes does not produce a satisfactory result, the business analyst may decide to make further corrective changes to the business.
There are many drawbacks associated with the above-described ad hoc approach. One problem with the approach is that it puts a tremendous emphasis on different combinations and quantities of the inputs to get the desired combinations and quantities of the output, neglecting most often to elicit an exact and quantified relationship between the input and the output parameters (the relationship in mathematical or algorithmic expressions is known as ‘transfer function’) in the first place. It is typically not possible to analyze future scenarios, make decision assumptions and then intervene with the business system dynamically using such an approach.
In traditional approaches, the transfer functions are most commonly developed using closed form analyses, numerical analyses, or experimentation. The numerical and experimental methods often use regression analysis and design of experiments. Closed form solutions are generally available for only relatively simple and stable problems. These transfer functions are typically obtained by brainstorming the relevant parameters and using regression analysis and design of experiments (DOE) to fit these parameters to the numerical analysis or experimental data. The resulting transfer functions are usually in polynomial forms. A drawback to this process is that polynomial transfer functions require relatively large DOE's since the known physical relationships are not used and instead are derived by observation. These resulting equations are cumbersome and often provide little insight into physical relationships among the input and the output parameters. Moreover, there is absence of any judgmental framework to discern between the important and the not-so-important input parameters for the purpose of selection for entry into the transfer functions. Similarly there is no judgmental framework to discern between the actionable and the non-actionable input parameters, nor a means to interact dynamically with both the analytical and business process infrastructure.
Moreover, traditional approaches are not well suited for automatic and real-time generation of transfer functions for quicker prediction of the output parameters of the business system. This is due, in part, to the fact that complex modeling algorithms may require a substantial amount of time to run using a computer. More specifically, performing a run may include the time-intensive tasks of collating data from historical databases and other sources, “scrubbing” the data to transform the data into a desired form, and performing various calculations. The processing is further compounded for those applications that involve performing several iterations of calculations (for example, for those applications that seek to construct a probability distribution of the input or the output parameters by repeating analyses multiple times). This means that the analyst typically waits several minutes, or perhaps even several hours, to receive the output result. This tends to tie up both human and computer resources in the business, and may be generally frustrating to the analyst.
There is therefore an exemplary need to provide a more efficient technique for deriving business system transfer functions and interacting with them.
In one embodiment of the business system framework described herein, multiple interrelated business processes for accomplishing a business objective are provided. The interrelated business processes each have a plurality of resources that collectively perform a business task. A business information and decisioning control system is also provided. It includes a plurality of mathematical or algorithmic business system transfer functions in support of the business information and decisioning control system. A control module is configured to receive information provided by the multiple interrelated business processes in relation to a plurality of input parameters associated with the plurality of resources and at least one output parameter associated with the operation of the business process and configured to generate a plurality of mathematical or algorithmic business system transfer functions. A business system user interface is coupled to the control module and configured to allow a user to interact with the control module, the business system user interface including plural input mechanisms for receiving instructions from the user. The control module includes logic configured to generate the plurality of transfer functions using a business model, logic configured to store the set of transfer functions, a storage for storing the transfer functions, logic configured to receive a user's request for an output result, and logic configured to present the output result to the requesting user.
The above mentioned and other features will now be described with reference to the drawings of various embodiments of the business system decisioning framework. The drawings are intended to illustrate, but not to limit the invention. The drawings contain the following figures:
This disclosure pertains to a technique for working with a transfer function that quantifies a relationship between input and output parameters of a business system. Techniques for integrating that transfer function into a business intelligence system that includes human interactivity in a prospective manner are also described. By way of introduction, a business intelligence system generally refers to any kind of infrastructure for providing business analysis within a business. In the context of this business intelligence system, a decisioning control system that provides business forecasts is also described. The system is used to control a business that includes multiple interrelated processes. As used herein, a “business” may refer broadly to any enterprise for providing goods or services, whether for profit or used to achieve some other measured performance goal. Businesses may be a single entity, or a conglomerate entity that includes several different business groups or companies within the conglomerate.
To facilitate explanation, the business information and decisioning control system is referred to in the ensuing discussion by the descriptive phrase “digital cockpit.” A business intelligence interface of the digital cockpit will be referenced to as a “cockpit interface.”
More specifically, each of the processes (106, 108, . . . 110) can include a collection of resources. The term “resources” as used herein has broad connotation and can include any aspect of the process that allows it to transform input items into output items. For instance, process 106 may draw from one or more engines 112. An “engine” 112 refers to any type of tool used by the process 106 in performing the allocated function of the process 106. In the context of a manufacturing environment, an engine 112 might refer to a machine for transforming materials from an initial state to a processed state. In the context of a finance-related environment, an engine 112 might refer to a technique for transforming input information into processed output information. For instance, in one finance-related application, an engine 112 may include one or more equations for transforming input information into output information. In other applications, an engine 112 may include various statistical techniques, rule-based techniques and artificial intelligence techniques. A subset of the engines 112 can be used to generate decisions at decision points within a business flow. These engines are referred to as “decision engines.” The decision engines can be implemented using manual analysis performed by human analysts, automated analysis performed by automated computerized routines, or a combination of manual and automated analysis. Rather than a decision engine, human intervention is also possible.
Other resources in the process 106 include various procedures 114. In one implementation, the procedures 114 represent general protocols followed by the business in transforming input items into output items. In another implementation, the procedures 114 can reflect automated protocols for performing this transformation.
The process 106 may also generically include “other resources” 116. Such other resources 116 can include any feature of the process 106 that has a role in carrying out the function(s) of the process 106. An exemplary “other resource” may include staffing resources. Staffing resources refer to the personnel used by the business 102 to perform the functions associated with the process 106. For instance, in a manufacturing environment, the staffing resources might refer to the workers required to run the machines within the process. In a finance-related environment, the staffing resources might refer to personnel required to perform various tasks involved in transforming information or “financial products” (e.g., contracts) from an initial state to a final processed state. Such individuals may include salesman, accountants, actuaries, etc. Still other resources can include various control platforms (such as Supply Chain, Enterprise Resource Planning, Manufacturing-Requisitioning and Planning platforms, etc.), technical infrastructure, etc.
In like fashion, process 108 includes one or more engines 118, procedures 120, and other resources 122. Process 110 includes one or more engines 124, procedures 126, and other resources 128. Although the business 102 is shown as including three processes (106, 108, . . . 110), this is merely exemplary; depending on the particular business environment, more than three processes can be included, or less than three processes can be included.
The digital cockpit 104 collects information received from the processes (106, 108, . . . 110) via communication path 130, and then processes this information. Such communication path 130 may represent a digital network communication path, such as the Internet, an Intranet network within the business enterprise 102, a LAN network, etc. The digital cockpit 104 also includes a cockpit control module 132 coupled to a cockpit interface 134. The cockpit control module 132 includes one or more models 136. A model 136 transforms information collected by the processes (106, 108, . . . 110) into an output using a transfer function or plural transfer functions. Mathematical or algorithmic description of transfer function will be presented in greater details below.
Other functionality provided by the cockpit control module 132 can perform data collection tasks. Such functionality specifies the manner in which information is to be extracted from one or more information sources and subsequently transformed into a desired form. The information can be transformed by algorithmically processing the information using one or more models 136, or by manipulating the information using other techniques. More specifically, such functionality is generally implemented using so-called Extract-Transform-Load tools (i.e., ETL tools).
A subset of the models 136 in the cockpit control module 132 may be the same as some of the models embedded in engines (112, 118, 124) used in respective processes (106, 108, . . . 110). In this case, the same transfer functions used in the cockpit control module 132 can be used in the day-to-day business operations within the processes (106, 108, . . . 110). Other models 136 used in the cockpit control module 132 are exclusive to the digital cockpit 104 (e.g., having no counterparts within the processes themselves (106, 108, . . . 110)). In the case where the cockpit control module 132 uses the same models 136 as one of the processes (106, 108, . . . 110), it is possible to store and utilize a single rendition of these models 136, or redundant copies or versions of these models 136 can be stored in both the cockpit control module 132 and the processes (106, 108, . . . 110).
A cockpit user 138 interacts with the digital cockpit 104 via the cockpit interface 134. The cockpit user 138 can include any individual within the business 102 (or potentially outside the business 102). The cockpit user 138 frequently will have a decision-maker role within the organization, such as chief executive officer, risk assessment analyst, general manager, an individual intimately familiar with one or more business processes (e.g., a business “process owner”), and so on.
The cockpit interface 134 presents various fields of information regarding the course of the business 102 to the cockpit user 138 based on the outputs provided by the models 136. For instance, the cockpit interface 134 may include a field 140 for presenting information regarding the past course of the business 102 (referred to as a “what has happened” field, or a “what-was” field for brevity). The cockpit interface 134 may include another field 142 for presenting information regarding the present state of the business 102 (referred to as “what is happening” field, or a “what-is” field for brevity). The cockpit interface 134 may also include another field 144 for presenting information regarding the projected future course of the business 102 (referred to as a “what may happen” field, or “what-may” field for brevity).
In addition, the cockpit interface 134 presents another field 146 for receiving hypothetical case assumptions from the cockpit user 138 (referred to as a “what-if” field). More specifically, the “what-if” field 146 allows the cockpit user 138 to enter information into the cockpit interface 134 regarding hypothetical or actual conditions within the business 102. The digital cockpit 104 will then compute various consequences of the identified conditions within the business 102 and present the results to the cockpit user 138 for viewing in the “what-if” display field 146.
After analyzing information presented by fields 140, 142, 144, and 146, the cockpit user 138 may be prepared to take some action within the business 102 to steer the business 102 in a desired direction based on some objective in mind (e.g., to increase revenue, increase sales volume, improve processing timeliness, etc.). To this end, the cockpit interface 134 includes another field (or fields) 148 for allowing the cockpit user 138 to enter commands that specify what the business 102 is to do in response to information (referred to as “do-what” commands for brevity).
The “do-what” commands can affect a variety of changes within the processes (106, 108, . . . 110) of
The business 102 provides other mechanisms for affecting changes in the processes (106, 108, . . . 110) besides the “do-what” field 148. Namely, in one implementation, the cockpit user 138 can directly make changes to the processes (106, 108, . . . 110) without transmitting instructions through the communication path 150 via the “do-what” field 148. In this case, the cockpit user 138 can directly visit and make changes to the engines (112, 118, 124) in the respective processes (106, 108, . . . 110). Alternatively, the cockpit user 138 can verbally instruct various staff personnel involved in the processes (106, 108, . . . 110) to make specified changes.
Whatever mechanism is used to affect changes within the business 102, such changes can also include modifications to the digital cockpit 104 itself. For instance, the cockpit user 138 can also make changes to the models 136 used in the cockpit control module 132. Such changes may comprise changing the parameters of a model 136, or entirely replacing one model 136 with another model 136, or supplementing the existing models 136 with additional models 136. Moreover, the use of the digital cockpit 104 may comprise an integral part of the operation of different business processes (106, 108, . . . 110). In this case, cockpit user 138 may want to change the models 136 in order to affect a change in the processes (106, 108, . . . 110).
An Extract-Transform-Load (ETL) module 206 extracts information from the business data warehouses 202 and the external sources 204, and performs various transformation operations on such information. The transformation operations can include: 1) performing quality assurance on the extracted data to ensure adherence to pre-defined guidelines, such as various expectations pertaining to the range of data, the validity of data, the internal consistency of data, etc; 2) performing data mapping and transformation, such as mapping identical fields that are defined differently in separate data sources, eliminating duplicates, validating cross-data source consistency, providing data convergence (such as merging records for the same customer from two different data sources), and performing data aggregation and summarization; 3) performing post-transformation quality assurance to ensure that the transformation process does not introduce errors, and to ensure that data convergence operations did not introduce anomalies, etc. The ETL module 206 also loads the collected and transformed data into a data warehouse 208. The ETL module 206 can include one or more selectable tools for performing its ascribed tasks, collectively forming an ETL toolset. For instance, the ETL toolset can include one of the tools provided by Informatica Corporation of Redwood City, Calif., and/or one of the tools provided by DataJunction Corporation of Austin, Tex. Still other tools can be used in the ETL toolset, including tools specifically tailored by the business 102 to perform unique in-house functions.
The data warehouse 208 may represent one or more storage devices. If multiple storage devices are used, these storage devices can be located in one central location or distributed over plural sites. Generally, the data warehouse 208 captures, scrubs, summarizes, and retains the transactional and historical detail used to monitor changing conditions and events within the business 102. Various known commercial products can be used to implement the data warehouse 208, such as various data storage solutions provided by the Oracle Corporation of Redwood Shores, Calif.
Although not shown in
The architecture 200 can also include a digital cockpit data mart (not shown) that culls a specific set of information from the data warehouse 208 for use in performing a specific subset of tasks within the business enterprise 102. For instance, the information provided in the data warehouse 208 may serve as a global resource for the entire business enterprise 102. The information culled from this data warehouse 208 and stored in the data mart (not shown) may correspond to the specific needs of a particular group or sector within the business enterprise 102.
The information collected and stored in the above-described manner is fed into the cockpit control module 132. The cockpit control module 132 can be implemented as any kind of computer device, including one or more processors 210, various memory media (such as RAM, ROM, disc storage, etc.), a communication interface 212 for communicating with an external entity, a bus 214 for communicatively coupling system components together, as well as other computer architecture features that are known in the art. In one implementation, the cockpit control module 132 can be implemented as a computer server coupled to a network 216 via the communication interface 212. In this case, any kind of server platform can be used, such as server functionality provided by iPlanet, produced by Sun Microsystems, Inc., of Santa Clara, Calif. The network 216 can comprise any kind of communication network, such as the Internet, a business Intranet, a LAN network, an Ethernet connection, etc. The network 216 can be physically implemented as hardwired links, wireless links (e.g., radio frequency links), a combination of hardwired and wireless links, or some other architecture. It can use digital communication links, analog communication links, or a combination of digital and analog communication links.
The memory media within the cockpit control module 132 can be used to store application logic 218 and record storage 220. For instance, the application logic 218 can constitute different modules of program instructions stored in RAM memory. The record storage 220 can constitute different databases for storing different groups of records using appropriate data structures. More specifically, the application logic 218 includes analysis logic 222 for performing different kinds of analytical tasks. For example, the analysis logic 222 includes historical analysis logic 224 for processing and summarizing historical information collected from the business 102, and/or for presenting information pertaining to the current status of the business 102. The analysis logic 222 also includes predictive analysis logic 226 for generating business forecasts based on historical information collected from the business 102. Such predictions can take the form of extrapolating the past course of the business 102 into the future, and for generating error information indicating the degrees of confidence associated with its predictions. Such predictions can also take the form of generating predictions in response to an input “what-if” scenario. A “what-if” scenario refers to a hypothetical set of conditions (e.g., cases) that could be present in the business 102. Thus, the predictive logic 226 would generate a prediction that provides a forecast of what might happen if such conditions (e.g., cases) are realized through active manipulation of the business processes (106, 108, . . . 110).
The analysis logic 222 further includes optimization logic 228. The optimization logic 228 computes a collection of model results for different input case assumptions, and then selects a set of input case assumptions that provides preferred model results. More specifically, this task can be performed by methodically varying different variables defining the input case assumptions and comparing the model output with respect to a predefined goal (such as an optimized revenue value, or optimized sales volume, etc.). Such optimization may be performed automatically by computer optimization routines, manually with computer assistance (such as having the computer suggest alternative cases to test) or manually without computer assistance. The case assumptions that provide the “best” model results with respect to the predefined goal are selected, and then these case assumptions can be actually applied to the business processes (106, 108, . . . 110) to realize the predicted “best” model results in actual business practice.
Further, the analysis logic 222 also includes pre-loading logic 230 for performing data analysis in off-line fashion. More specifically, processing cases using the models 136 may be time-intensive. Thus, a delay may be present when a user requests a particular analysis to be performed in real-time fashion. To reduce this delay, the pre-loading logic 230 performs analysis in advance of a user's request. The pre-loading logic 230 can perform this task based on various considerations, such as an assessment of the variation in the response surface of the model 136, an assessment of the likelihood that a user will require specific analyses, etc.
The storage logic 220 can include a database 232 that stores various models scripts. Such models scripts provide instructions for running one or more analytical tools in the analysis logic 222. As used in this disclosure, a model 136 refers to an integration of the tools provided in the analysis logic 222 with the model scripts provided in the database 232. In general, such tools and scripts can execute regression analysis, time-series computations, cluster analysis, and other types of analyses. A variety of commercially available software products can be used to implement the above-described modeling tasks. To name but a small sample, the analysis logic 222 can use one or more of the family of Crystal Ball products produced by Decisioneering, Inc. of Denver Colo., one or more of the Mathematica products produced by Wolfram, Inc. of Champaign Ill., one or more of the SAS products produced by SAS Institute Inc. of Cary, N.C., etc.
The storage logic 220 can also include a database 234 for storing the results pre-calculated by the pre-loading logic 230. As mentioned, the digital cockpit 104 can retrieve results from this database when the user requests these results, instead of calculating these results at the time of request. This reduces the time delay associated with the presentation of output results, and supports the high-level aim of the digital cockpit 104, which is to provide timely and accurate results to the cockpit user 138 when the cockpit user 138 requests such results. The database 234 can also store the results of previous analyses performed by the digital cockpit 104, so that if these results are requested again, the digital cockpit 104 need not recalculate these results.
The application logic 218 also includes other programs, such as display presentation logic 236. The display presentation logic 236 performs various tasks associated with displaying the output results of the analyses performed by the analysis logic 222. Such display presentation tasks can include presenting probability information that conveys the confidence associated with the output results using different display formats. The display presentation logic 236 can also include functionality for rotating and scaling a displayed response surface to allow the cockpit user 138 to view the response surface from different “vantage points,” to thereby gain better insight into the characteristics of the response surface. Additional information regarding exemplary functions performed by the display presentation logic 236 will be provided later.
The application logic 218 also includes development toolkits 238. A first kind of development toolkit 238 provides a guideline used to develop a digital cockpit 104 with predictive capabilities. More specifically, a business 102 can comprise several different affiliated companies, divisions, branches, etc. A digital cockpit 104 may be developed in for one part of the company, and thereafter tailored to suit other parts of the company. The first kind of development toolkit 238 provides a structured set of consideration that a development team should address when developing the digital cockpit 104 for other parts of the company (or potentially, for another unaffiliated company). The first kind of development toolkit 238 may specifically include logic for providing a general “roadmap” for developing the digital cockpit 104 using a series of structured stages, each stage including a series of well-defined action steps. Further, the first kind of development toolkit 238 may also provide logic for presenting a number of tools that are used in performing individual action steps within the roadmap. U.S. patent application Ser. No. 10/418,428 (Attorney Docket No. 85CI-0012), filed on 18 Apr. 2003 and entitled, “Development of a Model for Integration into a Business Intelligence System,” provides additional information regarding the first kind of development toolkit 238. A second kind of development toolkit 238 can be used to derive the transfer functions used in the predictive digital cockpit 104. This second kind of development toolkit 238 can also include logic for providing a general roadmap for deriving the transfer functions, specifying a series of stages, where each stage includes a defined series of action steps, as well as a series of tools for use at different junctures in the roadmap. Record storage 220 includes a database 240 for storing information used in conjunction with the development toolkits 238, such as various roadmaps, tools, interface page layouts, etc.
Finally, the application logic 218 includes “do-what” logic 242. The “do-what” logic 242 includes the program logic used to develop and/or propagate instructions into the business 102 for affecting changes in the business 102. For instance, as described in connection with
In one implementation, the “do-what” logic 242 is used to receive “do-what” commands entered by the cockpit user 138 via the cockpit interface 134. Such cockpit interface 134 can include various graphical knobs, slide bars, switches, etc. for receiving the user's commands. In another implementation, the “do-what” logic 242 is used to automatically generate the “do-what” commands in response to an analysis of data received from the business processes (106, 108, . . . 110). In either case, the “do-what” logic 242 can rely on a coupling database 244 in developing specific instructions for propagation throughout the business 102. For instance, the “do-what” logic 242 in conjunction with the database 244 can map various entered “do-what” commands into corresponding instructions for affecting specific changes in the resources of business processes (106, 108, . . . 110).
The mapping described above can rely on rule-based logic. For instance, an exemplary rule might specify: “If a user enters instruction X, then affect change Y to engine resource 112 of process 106, and affect change Z to procedure 120 of process 108.” Such rules can be stored in the couplings database 244, and this information may effectively reflect empirical knowledge garnered from the business processes (106, 108, . . . 110) over time (e.g., in response to observed causal relationships between changes made within a business 102 and their respective effects). Effectively, then, this coupling database 244 constitutes the “control coupling” between the digital cockpit 104 and the business processes (106, 108, . . . 110), which it controls in a manner analogous to the control coupling between a control module of a physical system and the subsystems, which it controls. In other implementations, still more complex strategies can be used to provide control of the business 102, such as artificial intelligence systems (e.g., expert systems) for translating a cockpit user 138's commands to the instructions appropriate to affect such instructions.
The cockpit user 138 can receive information provided by the cockpit control module 132 using different devices or different media.
The exemplary workstation 246 includes conventional computer hardware, including a processor 252, RAM 254, ROM 256, a communication interface 258 for interacting with a remote entity (such as network 216), storage 260 (e.g., an optical and/or hard disc), and an input/output interface 262 for interacting with various input devices and output devices. These components are coupled together using bus 264. An exemplary output device includes the cockpit interface 134. The cockpit interface 134 can present an interactive display 266, which permits the cockpit user 138 to control various aspects of the information presented on the cockpit interface 134. Cockpit interface 134 can also present a static display 268, which does not permit the cockpit user 138 to control the information presented on the cockpit interface 134. The application logic for implementing the interactive display 266 and the static display 268 can be provided in the memory storage of the workstation 246 (e.g., the RAM 254, ROM 256, or storage 260, etc.), or can be provided by a computing resource coupled to the workstation 246 via the network 216, such as display presentation logic 236 provided in the cockpit control module 132.
Finally, an input device 270 permits the cockpit user 138 to interact with the workstation 246 based on information displayed on the cockpit interface 134. The input device 270 can include a keyboard, a mouse device, a joy stick, a data glove input mechanism, throttle input mechanism, track ball input mechanism, a voice recognition input mechanism, a graphical touch-screen display field, various kinds of biometric input devices, various kinds of biofeedback input devices, etc., or any combination of these devices.
Window 306 provides information regarding the past course (i.e., history) of the business 102, as well as its present state. Window 308 provides information regarding both the past, current, and projected future condition of the business 102. The cockpit control module 132 can generate the information shown in window 308 using one or more models 136. Although not shown, the cockpit control module 132 can also calculate and present information regarding the level of confidence associated with the business predictions shown in window 308. Additional information regarding the presentation of confidence information is presented in section E of this disclosure. Again, the predictive information shown in windows 306 and 308 is strictly illustrative; a great variety of additional presentation formats can be provided depending on the business environment in which the business 102 operates and the design preferences of the cockpit designer. Additional presentation strategies include displays having confidence bands, n-dimensional graphs, and so on.
The cockpit interface 134 can also present interactive information, as shown in window 310. This window 310 includes an exemplary multi-dimensional response surface 312. Although response surface 312 has three dimensions, response surfaces having more than three dimensions can be presented. The response surface 312 can present information regarding the projected future course of business 102, where the z-axis of the response surface 312 represents different slices of time. The window 310 can further include a display control interface 314, which allows the cockpit user 138 to control the presentation of information presented in the window 310. For instance, in one implementation, the display control interface 314 can include an orientation arrow that allows the cockpit user 138 to select a particular part of the displayed response surface 312, or which allows the cockpit user 138 to select a particular vantage point from which to view the response surface 312.
The cockpit interface 134 further includes another window 316 that provides various control mechanisms. Such control mechanisms can include a collection of graphical input knobs or dials 318, a collection of graphical input slider bars 320, a collection of graphical input toggle switches 322, as well as various other graphical input devices 324 (such as data entry boxes, radio buttons, etc.). These graphical input mechanisms (318, 320, 322, 324) are implemented, for example, as touch sensitive fields in the cockpit interface 134. Alternatively, these input mechanisms (318, 320, 322, 324) can be controlled via other input devices, or can be replaced by other input devices. Exemplary alternative input devices were identified above in the context of the discussion of input device(s) 270 of
Generally speaking, the response surface 312 (or other type of presentation provided by the cockpit interface 134) can provide a dynamically changing presentation in response to various events fed into the digital cockpit 104. For instance, the response surface 312 can be computed using a model 136 that generates output results based, in part, on data collected from the processes (106, 108, . . . 110) and stored in the data warehouses 208. As such, changes in the processes (106, 108, . . . 110) will prompt real time or near real time corresponding changes in the response surface 312. Further, the cockpit user 138 can dynamically make changes to “what-if” assumptions via the input mechanisms (318, 320, 322, 324) of the control panel 316. These changes can induce corresponding lockstep dynamic changes in the response surface 312.
By way of summary, the cockpit interface 134 provides a “window” into the operation of the business 102, and also provides an integrated command and control center for making changes to the business 102. The cockpit interface 134 also allows the cockpit user 138 to conveniently switch between different modes of operation. For instance, the cockpit interface 134 allows the user to conveniently switch between a “what-if” mode of analysis (in which the cockpit user 138 investigates the projected probabilistic outcomes of different case scenarios) and a “do-what” mode of command (in which the cockpit user 138 enters various commands for propagation throughout the business 102). While the cockpit interface 134 shown in
In a what-if/do-what portion 408 of the method 400, in step 410, a cockpit user 138 examines the output fields of information presented on the cockpit interface 134 (which may include the above-described what-has, what-is, and what-may fields of information). The looping path between step 410 and the historical database 406 generally indicates that step 410 utilizes the information stored in the historical database 406.
Presume that, based on the information presented in step 410, the cockpit user 138 decides that the business 102 is currently headed in a direction that is not aligned with a desired goal. For instance, the cockpit user 138 can use the what-may field 144 of cockpit interface 134 to conclude that the forecasted course of the business 102 will not satisfy a stated goal. To remedy this problem, in step 412, the cockpit user 138 can enter various “what-if” hypothetical cases into the digital cockpit 104. These “what-if” cases specify a specific set of conditions that could prevail within the business 102, but do not necessarily match current conditions within the business 102. This prompts the digital cockpit 104 to calculate what may happen if the stated “what-if” hypothetical input case assumptions are realized. Again, the looping path between step 412 and the historical database 406 generally indicates that step 412 utilizes the information stored in the historical database 406. In step 414, the cockpit user 138 examines the results of the “what-if” predictions. In step 416, the cockpit user 138 determines whether the “what-if” predictions properly set the business 102 on a desired path toward a desired target. If not, the cockpit user 138 can repeat steps 412 and 414 for as many times as necessary, successively entering another “what-if” input case assumption, and examining the output result based on this input case assumption.
Assuming that the cockpit user 138 eventually settles on a particular “what-if” case scenario, in step 418, the cockpit user 138 can change the business processes (106, 108, . . . 110) to carry out the simulated “what-if” scenario. The cockpit user 138 can perform this task by entering “do-what” commands into the “do-what” field 148 of the cockpit interface 134. This causes the digital cockpit 104 to propagate appropriate instructions to targeted resources used in the business 102. For instance, command path 420 sends instructions to personnel used in the business 102. These instructions can command the personnel to increase the number of workers assigned to a task, decrease the number of workers assigned to a task, change the nature of the task, change the amount of time spent in performing the task, change the routing that defines the “input” fed to the task, or other specified change. Command path 422 sends instructions to various destinations over a network, such as the Internet (WWW), a LAN network, etc. Such destinations may include a supply chain entity, a financial institution (e.g., a bank), an intra-company subsystem, etc. Command path 424 sends instructions to engines (112, 118, 124) used in the processes (106, 108, . . . 110) of the business 102. These instructions can command the engines (112, 118, 124) to change its operating parameters, change its input data, change its operating strategy, as well as other changes.
In summary, the method shown in
Steps 412, 414 and 416 collectively represent a manual routine 426 used to explore a collection of “what-if” case scenarios. In another implementation, the manual routine 426 can be supplemented or replaced with an automated optimization routine 428. The automated optimization routine 428 can automatically sequence through a number of case assumptions and then select one or more case assumptions that best accomplish a predefined objective (such as maximizing profitability, minimizing risk, etc.). The cockpit user 138 can use the recommendation generated by the automated optimization routine 428 to select an appropriate “do-what” command. Alternatively, the digital cockpit 104 can automatically execute an automatically selected “do-what” command without involvement of the cockpit user 138.
In any event, the output results generated via the process 400 shown in
To summarize the discussion of
Second, an airplane cockpit has various gauges and displays for providing substantial quantities of past and current information pertaining to the airplane's flight, as well as to the status of subsystems used by the airplane. The effective navigation of the airplane demands that the airplane cockpit presents this information in a timely, intuitive, and accessible form, such that it can be acted upon by the pilot or autopilot in the operation of the airplane. In a similar fashion, the digital cockpit 104 of a business 102 also can present summary information to assist the user in assessing the past and present state of the business 102, including its various “engineering” processes (106, 108, . . . 110).
Third, an airplane cockpit also has various forward-looking mechanisms for determining the likely future course of the airplane, and for detecting potential hazards in the path of the airplane. For instance, the engineering constraints of an actual airplane prevent it from reacting to a hazard if given insufficient time. As such, the airplane may include forward-looking radar to look over the horizon to see what lies ahead so as to provide sufficient time to react. In the same way, a business 102 may also have natural constraints that limit its ability to react instantly to assessed hazards or changing market conditions. Accordingly, the digital cockpit 104 of a business 102 also can present various business predictions to assist the user in assessing the probable future course of the business 102. This look-ahead capability can constitute various forecasts and “what-if” analyses.
In the overview of the business systems as described in relation to
An exemplary transfer function used in the digital cockpit 104 can represent a mathematical equation or algorithmic relationship or any other function fitted to empirical data collected over a span of time. Alternatively, an exemplary transfer function can represent a mathematical equation or algorithmic relationship or any other function derived from “first principles” (e.g., based on a consideration of economic principles). Other exemplary transfer functions can be formed based on other considerations. In operation, a transfer function translates one or more input(s) into one or more output(s) using a translation function. The translation function can also be implemented using a mathematical or algorithmic model or other form of mapping strategy. For instance, a transfer function of the engine 112 of FIG. I simulates the behavior of an engine 112 by mapping a set of process inputs to projected process outputs. The behavior of these engines 112 therefore can be described, controlled and monitored using these transfer functions.
In another implementation, a transfer function of the digital cockpit 104 maps one or more independent variables (e.g., one or more X variables) to one or more dependent variables (e.g., one or more Y variables). For example, referring to
In yet another implementation, there are scenario building applications where transfer functions are at the heart of conversion of different inputs into outputs. Such scenario building cases may typically include “what-if” and “do-what” situations. The term “what-if” encompasses any kind of projection of “what may happen” given any kind of input assumptions. In one such case, a user may generate a prediction by formulating a forecast based on the past course of the business. The prediction can be generated using the transfer functions to predict a particular value of the output parameter based on a number of particular values of the input parameters. Here, the input assumption is defined by the actual course of the business. In another case, a user may generate a prediction by inputting a set of assumptions that could be present in the business (but which do not necessarily reflect the current state of the business), which prompts the system to generate a forecast of what may happen if these assumptions are realized. Here, the forecast assumes more of a hypothetical “what if” character (e.g., “If X is put into place, then Y is likely to happen”) or “do-what” character (e.g., “What values of X are required when a particular value of Y is desired?”).
In still another case, the cockpit control module 132 can include functionality for automatically analyzing information received from the processes (106, 108, . . . 110), and then automatically generating “what-if” or “do-what” commands for dissemination to appropriate target resources within the processes (106, 108, . . . 110) based on automatic transfer function building functionalities. As will be described in greater detail below, such automatic control can include mapping various input conditions to various instructions to be propagated into the processes (106, 108, . . . 110). Such automatic control of the business 102 can therefore be likened to an automatic pilot provided by a vehicle. In yet another implementation, the cockpit control module 132 generates a series of recommendations regarding different courses of actions that the cockpit user 138 might take, and the cockpit user 138 exercises human judgment in selecting a transfer function from among the recommendations (or in selecting a transfer function that is not included in the recommendations).
In functional block 513, the relationship between the output parameter and the input parameters is mathematically or algorithmically described and displayed using the transfer function. Continuing further, in functional block 514, multiple business scenarios are built up using the transfer functions developed in step 505. Two exemplary scenarios are “what-if” and “do-what” as illustrated in step 515 and step 516 respectively. In the next step 517, the transfer functions are applied to accomplish other functionalities of the digital cockpit 104 such as prediction of output results as in functional block 518, selection and control of output results as in functional block 519 and pre-calculation of output results as in functional block 520. At the end, the method 500 is complete only when the transfer functions are tested and verified as in functional block 521. Each of these steps will be explained in more details below.
As mentioned above, the method 500 starts with the identification of a business system view (step 501) having a number of processes wherein each of the processes (106, 108, . . . 110) as in
The Y variable mentioned above can be a function of multiple X variables and a subset of these multiple X variables may be “actionable”. An X variable is said to be “actionable” when it corresponds to an aspect of the business 102 that the business 102 can deliberately manipulate. For instance, presume that the output Y variable is a function, in part, of the size of the business's 102 sales force. A business 102 can control the size of the workforce by hiring additional staff, transferring existing staff to other divisions, laying off staff, etc. Hence, the size of the workforce represents an actionable X variable.
In operation, one or more of the X variables can be varied through the use of any control mechanism of the digital cockpit 104 such as the control window 316 shown in
Moreover, the digital cockpit 104 can also be configured in such a manner that a cockpit user's 138 variation of one or more of these inputs will cause the outputs to change perceptively and meaningfully. Hence, through an appropriate display visualization technique as will be explained later, the user 138 can gain added insight into the behavior of the system's transfer functions. In one implementation, the digital cockpit 104 is configured to allow the cockpit user 138 to select the variables that are to be assigned to the axes of the response surface 312 of
Referring back to
Referring to
In one embodiment, methods based on simulating (step 506) the business process based on the usage of the resources in the business process are used to select the input parameters that are critical to the output parameters and to conjoin the value gained with each of the selected input parameters and finally to determining the elasticity of the output parameter with regard to the selected input parameters. More specifically, such simulation techniques include discrete event simulations (step 507), agent based simulation (step 508), continuous simulations, Monte Carlo simulations (step 509), etc. In other embodiments, non-simulation based techniques are used. For instance, regression analysis techniques (step 510), design of experiments (step 511), time series analyses (step 522), artificial intelligence analyses (step 523), extrapolation and logic analyses, etc yield transfer functions that mathematically or algorithmically describe a relationship between an output parameter and a number of input parameters using the transfer function. In another embodiment, an automation logic as part of step 512 calculates a transfer function from input and output data without human participation. This functionality will be explained in more details below.
Once a relationship between the output parameters and the input parameters may be determined, the next significant step is to display the input parameters, the output parameters and the transfer functions as in step 513 of
Probability distribution curves as illustrated in
To elaborate further, the response surface 600 of
Generally, different factors can contribute to uncertainty in the predicted output result. For instance, the input information and assumptions fed to the digital cockpit 104 may have uncertainty associated therewith. Such uncertainty may reflect variations in various input parameters associated with different tasks within the method 500, variations in different constraints that affect the method 500, as well as variations associated with other aspects of the method 500. This uncertainty propagates through the digital cockpit 104, and results in uncertainty in the predicted output result. The probabilistic distribution in the output of the method 500 can represent the actual variance in the collection of information fed into the method 500. In another implementation, uncertainty in the inputs fed to the digital cockpit 104 can be simulated (rather than reflecting variance in actual sampled business data). In addition to the above-noted sources of uncertainty, the prediction strategy used by the digital cockpit 104 may also have inherent uncertainty associated therewith. Known modeling techniques can be used to assess the uncertainty in an output result based on the above-identified factors and appropriate action can be taken.
In the specific context of transfer function building, the digital cockpit 104 provides a prediction of an output parameter value in response to the input parameters, as well as a level of confidence associated with this prediction. For instance, the digital cockpit 104 can generate a forecast that a particular combination of input parameters, output parameters and transfer function, in other words, ‘an input case assumption’ will result in a cycle time that consists of a certain amount of hours coupled with an indication of the statistical confidence associated with this prediction. That is, for example, the digital cockpit 104 can generate an output that informs the cockpit user 138 that a particular parameter setting will result in its output such as a cycle time of 40 hours, and that there is a 70% confidence level associated with this prediction (that is, there is a 70% probability that the actual measured cycle time will be 40 hours).
In an exemplary situation, a cockpit user 138 may be dissatisfied with this predicted result for one of two reasons (or both reasons). First, the cockpit user 138 may find that the predicted cycle time is too long. For instance, the cockpit user 138 may determine that a cycle time of 30 hours or less is required to maintain competitiveness in a particular business environment. Second, the cockpit user 138 may feel that the level of confidence associated with the predicted result is too low. For a particular business environment, the cockpit user 138 may want to be assured that a final product can be delivered with a greater degree of confidence. This can vary from business application to business application. For instance, the customers in one financial business environment might be highly intolerant to fluctuations in cycle time, e.g., because the competition is heavy, and thus a business with unsteady workflow habits will soon be replaced by more stable competitors. In other business environments, an untimely output product may subject the customer to significant negative consequences (such as by holding up interrelated business operations), and thus it is desirable to predict the cycle time with a relatively high degree of confidence. Displaying the transfer functions help a user 138 in speculating different scenarios and take preparatory or corrective actions in anticipation.
A comparison of probability distribution curve 612 and probability distribution curve 610 allows a cockpit user 138 to assess the accuracy of the digital cockpit's 104 predictions and take appropriate corrective measures in response thereto. In one case, the cockpit user 138 can rely on his or her business judgment in comparing distribution curves 610 and 612. In another case, the digital cockpit 104 can provide an automated mechanism for comparing salient features of distribution curves 610 and 612. For instance, this automated mechanism can determine the variation between the mean values of distributions curves 610 and 612, the variation between the shapes of distributions 610 and 612, and so on.
In accordance with one embodiment, business 102 and the markets within which it operates are examples of typical business systems. The input and the output parameters of these systems can be linear in nature at times and non-linear at other times. In another implementation, the input and the output parameters may be stochastic in nature or may be dynamic. Moreover, not all observations in these systems are mathematically describable. When they are mathematically describable, open and closed form transfer functions may be derived. An open form transfer function describes the relationship between a set of input and output parameters such that only the output parameters are influenced by the input parameters and not vice versa. On the other hand, a closed form transfer function describes the relationship between a set of input and output parameters such that a part or whole of the output parameters are fed back into the system to influence the input parameters during successive operations of the system. For example, an open form transfer function may describe the conversion relationship between a particular raw material inputs of a factory into the final goods produced. On the other hand, a closed form transfer function may describe the conversion relationship between the gas burning rate and the heat output of a thermostat-controlled heater. In this instance, the heat output at any point of time influences the gas-burning rate partly or wholly. In essence, the present embodiment is a framework applicable to the functional areas of a business where augmentation of business judgment with quantitative methods and systems is beneficial.
Referring back to the visual representation of these transfer functions in
As mentioned earlier, business system 100 may typically include a collection of subsystems and components and,these subsystems and components of the may have their known transfer functions and control couplings that determine their respective behavior. In keeping with this system-subsystem viewpoint, the digital cockpit 104 can determine whether a response surface can be simplified by breaking it into multiple transfer functions that can be used to describe the component parts of the response surface. For example, consider
The system and sub-system analysis feature described above has the capacity to improve the overall response time of the digital cockpit 104. For instance, an output result corresponding to the flat portion 602 can be calculated relatively quickly, as the transfer function associated with this region would be relatively straightforward, while an output result corresponding to the rapidly changing portion 604 can be expected to require more time to calculate. By expediting the computations associated with at least part of the response surface 600, the overall or average response time associated with providing results from the response surface 600 can be improved (compared to the case of using a single complex model to describe all portions of the response surface 600). The use of a separate transfer function to describe the flat portion 602 can be viewed as a “shortcut” to providing output results corresponding to this part of the response surface 600. In addition, providing separate transfer functions to describe the separate portions of the response surface 600 may provide a more accurate modeling of the response surface (compared to the case of using a single complex model to describe all portions of the response surface 600).
In operation, the subsystems and the component systems also iteratively follow the same steps of building a transfer function as is done at the system level. To recount, the steps are—developing a number of sub-processes and component processes that are part of the business process; identifying a number of input parameters associated with one or more of the resources used in the identified sub-processes and component processes; identifying one or more output parameter associated with the operation of the of sub-processes and the component processes; collecting operational data that associate the input parameters with the output parameter based on an actual operation of the sub-processes and the component processes; determining at least one relationship between the output parameter and the input parameters based on the operational data; and mathematically or algorithmically describing the relationship between the at least one output, parameter and the input parameters using sub-process transfer function.
Whatever be the level of abstraction such as system or subsystem, there are different techniques for representing the granularity of analysis, uncertainty, changeability and desirability associated with the transfer functions derived by the method 500 of
The digital cockpit 104 takes the nature of the response surface 600 and thereby the underlying transfer function into account when deciding what calculations to perform. For instance, the digital cockpit 104 need not perform fine-grained analysis for the flat portion 602 of
In another embodiment, the digital cockpit 104 will make relatively fine-grained calculation for the portion 604 that rapidly changes, because a single value in this region is in no way representative of the response surface 600 in general. Other regions in
One way to assess the changeability of the response surface 600 is to compute a partial derivative of the response surface 600 (or a second derivative, third derivative, etc.). A derivative of the response surface 600 will provide an indication of the extent to which the response surface changes. In yet another embodiment, the mapping includes mapping over a region of interest constructed based on a predetermined range or a predetermined scale of values of the input parameters or the output parameter. As it is determined that there is a non linear “Y” response for a given “x” or “xs”, more analytical scenarios are made with finer changes in the xs.
Like changeability, the display mechanism of the transfer function includes ways to illustrate the feature of uncertainty. Referring to
Any two-dimensional curve in
It should be noted that objects 608, 610, and 612 in
In yet another embodiment, instead of confidence bands, different levels of uncertainty may be visually represented by changing the size of the displayed object (where an object represents an output response curve). In this instance, the probability associated with the output results is conveyed by the size of the objects rather than a spatial distribution of points. This technique simulates the visual uncertainty associated with an operator's field of view while operating a vehicle. More specifically,
In another embodiment, an alternative technique may be used for representing uncertainty in a response surface, such as, by using display density (not shown) associated with the display surface to represent uncertainty. Again, on different slices of time, different response curves representing different transfer functions may be represented. As time progresses further into the future, the uncertainty associated with the output of the digital cockpit 104 increases, and the density of the response curves decreases in proportion. That is, the foremost response curve will have maximum density and the further one moves less dense is that object. This has the effect of fading out of objects that have a relatively high degree of uncertainty associated therewith. This concept of using density of a response curve as a visual aid to illustrate uncertainty associated with a business situation has been elaborated in greater details in the discussion relating to
Referring back to control window 316 of
Like changeability and uncertainty, another feature of the transfer function building and displaying method that can be monitored and manipulated is desirability. By successively varying the collection of input parameters in the cockpit interface 134, the cockpit user 138 can identify particularly desirable portions of the response surface in which to operate the business method 500. One aspect of “desirability” pertains to the generation of desired target results. For instance, as discussed above, the cockpit user 138 may want to find that portion of the response surface that provides a desired value of the output parameter such as cycle time (e.g., 40 hours, 30 hours, etc.). Another aspect of desirability pertains to the probability associated with the output results. The cockpit user 138 may want to find that portion of the response surface that provides adequate assurance that the method 500 can realize the desired target results (e.g., 70% confidence 80% confidence, etc.).
In another implementation, another aspect of desirability pertains to the generation of output results that are sufficiently robust to variation. This will assure the cockpit user 138 that the output results will not dramatically change when only a small change in the case assumptions and/or “real world” conditions occurs. Taken all together, it is desirable to find the parts of the response surface that provide an output result that is on-target as well as robust (e.g., having suitable confidence and stability levels associated therewith). The cockpit user 138 can use “what-if” analysis to identify those parts of the response surface that the business distinctly does not want to operate within. The knowledge gleaned through this kind of use of the digital cockpit 104 serves a proactive role in steering the business away from a an undesired direction, such as for example, accepting an order it can not fulfill, stocking out, exhausting capital and etc. business environment that it has ventured into due to unforeseen circumstances or towards a predetermined business goal when the environment is conducive.
According to one embodiment, a transfer function that quantifies a relationship between input and output parameters of a business system and is integrated into a business intelligence system lends itself to business analysis within a business (step 514). The business analysis that is featured according to this embodiment pertains to business prediction. Generally, the term “prediction” is used broadly in this application and the forecast assumes more of a hypothetical “what if” character (e.g., “If X is put into place, then Y is likely to happen”) or “do-what” character (e.g., “What values of X are required when a particular value of Y is desired?”).
Drawing a parallel with a physical cockpit of an airplane once more, an airplane cockpit has various forward-looking mechanisms for determining the likely future course of the airplane, and for detecting potential hazards in the path of the airplane. For instance, the engineering constraints of an actual airplane prevent it from reacting to a hazard if given insufficient time. As such, the airplane may include forward-looking radar to look over the horizon to see what lies ahead so as to provide sufficient time to react. In the same way, a business 102 may also have natural constraints that limit its ability to react instantly to assessed hazards or changing market conditions. Accordingly, the digital cockpit 104 of a business 102 also can use the transfer function to present various business predictions to assist the user in assessing the probable future course of the business 102. Referring to
In one embodiment, the predictive or forward looking capability of transfer functions can be used to perform “what-if” analysis (step 515). Referring to
Now referring to
For instance, to simulate a “what-if” scenario, the cockpit user 138 adjusts the input devices (318, 320, 322, 324) to select a particular permutation of X variables. X variables may be actionable or non-actionable. The digital cockpit 104 responds by simulating how the business 102 would react to this combination of input X variables as if these X variables were actually implemented within the business 102. The digital cockpit's 104 predictions can be presented in the window 310, which displays an n-dimensional response surface 312 that maps the output result Y variable as a function of other variables, such as time, and/or possibly one of the X variables. Thus, in a “what-if” simulation mode, the cockpit user 138 can experiment with different permutations of these X variables.
In another implementation, an input case assumption can also include one or more assumptions that are derived from selections made. In response, the digital cockpit 104 simulates the effect that this input case assumption will have on the business method 500 by generating a “what-if” output result using one or more transfer function(s). The output result can be presented as a graphical display that shows a predicted response surface, e.g., as in the case of response surface 312 of window 310 (in
More specifically, the “do-what” field 148 can include an assortment of interface input mechanisms (not shown), such as various graphical knobs, sliding bars, text entry fields, etc. (In addition, or in the alternative, the input mechanisms can include other kinds of input devices, such as voice recognition devices, motion detection devices, various kinds of biometric input devices, various kinds of biofeedback input devices, and so on.) The business 102 includes a communication path 150 for forwarding instructions generated by the “do-what” commands to the processes (106, 108, . . . 110). Such communication path 150 can be implemented as a digital network communication path, such as the Internet, an intranet within a business enterprise 102, a LAN network, etc. In one embodiment, the communication path 130 and communication path 150 can be implemented as the same digital network.
Referring to
In operation, “what-if” or “do-what” scenario building involves selecting a set of input assumptions, such as a particular combination of X variables associated with a set of input parameters provided on the cockpit interface 134 in a number of predetermined scenarios. Moreover, “what-if” or “do-what” scenario building involves generating predictions (step 518) based on various input assumptions using the transfer functions, which provide one, or more output variable(s) Y. In one embodiment, there are multiple techniques to generate the output variable Y, such as Monte Carlo simulation techniques, discrete event simulation techniques, continuous simulation techniques, and other kinds of techniques using transfer functions to run different case computations. These computations may involve sampling probabilistic input assumptions in order to provide probabilistic output results. In this context, the method 500 entails combining and organizing the output results associated with different cases and making the collated output probability distribution available for downstream optimization and decisioning operations.
In yet another embodiment, the method 500 includes analyzing whether the output result satisfies various criteria. For instance, comparing the output result with predetermined threshold values, or comparing a current output result with a previous output result provided in a previous iteration of the loop shown in the “what-if” or “do-what” scenarios. Based on the determination criterion, the method 500 may decide that a satisfactory result has not been achieved by the digital cockpit 104. In this case, the method 500 returns to step 502 and 503, where a different permutation of input parameters is selected, followed by a repetition of steps 504, 505, and 513. This thus-defined loop is repeated until steps 515 and 516 determine that one or more satisfactory results have been generated by the method 500 (e.g., as reflected by the result satisfying various predetermined criteria). Described in more general terms, the loop defined by steps 502, 503, 504, 505, 513, 515 and 516 seek to determine the “best” permutation of input parameters, where “best” is determined by a predetermined criterion (or criteria).
Various considerations can be used in sequencing through input considerations in step 505 and its sub-steps 506, 507, 508, 509 and 510 of
An assumption was made in the above discussion that the cockpit user 138 manually changes the input parameters in the cockpit interface 134 primarily based on his or her business judgment. That is, the cockpit user 138 manually selects a desired permutation of input settings, observes the result on the cockpit interface 134, and then selects another permutation of input settings, and so on. However, in another embodiment, the digital cockpit 104 can automate this trial and error approach by automatically sequencing through a series of input settings (step 512). Such automation was introduced in the context of step 428 of
In one embodiment, an automated optimization routine 428 can be manually initiated by the cockpit user 138, for example, by entering various commands into the cockpit interface 134. In another embodiment, the automated optimization routine 428 can be automatically triggered in response to predefined events. For instance, the automated optimization routine 428 can be automatically triggered if various events occur within the business 102, as reflected by collected data stored in the data warehouses 208 (such as the event of the collected data exceeding or falling below a predefined threshold). Alternatively, the analysis shown in
To elaborate further the automatic transfer function building application, reference is made again to
In yet another implementation of the automatic transfer function building functionality as illustrated in
As part of the automatic transfer function building scenario, in yet another embodiment, the digital cockpit 104 utilizes the transfer functions to model and monitor the business in “real time” or “near real time” manner. In this embodiment, the digital cockpit 104 receives information from the business 102 and forwards instructions to the business 102 in real time or near real time. Further, if configured to run in an automatic mode, the digital cockpit 104 automatically analyzes the collected data using one or more transfer function(s) and then forwards instructions to processes (106, 108, . . . 110) in real time or near real time. In this manner, the digital cockpit 104 can translate changes that occur within the processes (106, 108, . . . 110) to appropriate corrective action transmitted to the processes (106, 108, . . . 110) in real time or near real time in a manner analogous to an auto-pilot of a moving vehicle. In the context used here, “near real time” generally refers to a time period that is sufficient timely to steer the business 102 along a desired path, without incurring significant deviations from this desired path. Accordingly, the term “near real time” will depend on the specific business environment in which the digital cockpit 104 is deployed; in one exemplary embodiment, “near real time” can refer to a delay of several seconds, several minutes, etc. Like in the previous examples, the algorithms used in this embodiment to build the system, sub-system and the component transfer functions ensure that the systems and its sub-system and the component respond to the need of “real time” or “near real time” scenario generation in a manner expected.
Referring back to
For instance, in one embodiment, the step 518 involves prediction and consolidation of the output results generated by the digital cockpit 104. Such prediction and consolidation may include generating a number of output parameters for various input parameters, organizing the output results into groups, eliminating certain solutions and finally arriving at an optimized set of predicted values. Step 518 may also extend into codifying the output results for storage to enable the output results to be retrieved at a later point in time as described in relation to step 520 later.
In another embodiment, all the information in relation to the transfer functions are fed back into the components responsible for selection of different parameters and thereby overall control of the system as in step 519. Referring to
According to yet another exemplary embodiment, the described method for building transfer functions is capable of generating pre-calculation of output results for presentation in a digital cockpit at a later point of time as in step 520. In this embodiment, the method generates a set of output results using a business model, where the generating of the set of output results is performed prior to a request by a user for the output results. The output results are then stored for future reproduction and use. More specifically, as discussed in connection with
Application of the transfer functions to build different functionalities as explained above are the steps that lead finally to testing and validating of the transfer functions as in step 521 of
According to yet another exemplary embodiment, the digital cockpit 104 may include a user interface to provide access to a control module of the digital cockpit 104. Typically, the control module of the digital cockpit 104 is configured to receive information provided by business processes in relation to a number of input parameters associated with one or more of the resources used in the business and at least one output parameter associated with the operation of the business and configured to generate a number of mathematical or algorithmic business system transfer functions.
The user interface typically includes a primary display layer that presents a testbed environment for the business information and decisioning control system. The primary display layer is constructed to present a stochastic simulation of the output parameter(s) based on the mathematical or algorithmic transfer functions. The transfer functions for relatively complex systems may be modeled using dynamic algorithmic simulation models and displayed in a primary display layer. The stochastic testbed environment is built to model and describe the behavior of a real-life business system. The models displayed and tested on the primary display layer then help in making suitable decisions about the business system.
To elaborate further, a financing decision for a specific ‘deal’ in an asset financing business may be an example of a business systems and process being simulated for making a number of decisions. In this exemplary financing decision situation, a decision maker in an asset financing business takes a customer's financial information, asset information, proposed structure of financing and other information to arrive at a yes/no decision as to financing a specific deal. In that context, a deal signifies a transaction that requires a set of available initial information to be processed and a set of output decision information. For example, a fruit vendor aged 35 years with 10 years' prior experience based in a semi-urban area and applying for a business expansion credit utilizing fruit processing equipment may constitute one deal for a financing agency. Whether to finance him or not is an outcome of the asset financing decision. In the process of arriving at the final decision, various process steps such as legal assessments, risk assessments, asset valuations are performed.
Referring back to
The methods and systems described herein are not limited to the specific business objects mentioned above only. In other embodiments, there may be other business objects taken up for simulation such as different types of users, a database, another simulation, or an intelligent decision-making application, or a combination of the above. The ground rule however followed in all such instances is that the display and other behavioral properties of the business objects are to be modeled in the simulation progressing on the primary display layer 800.
Furthermore, the primary display layer 800 may adjust itself depending on what level of detail of the animation is being channeled out. In one embodiment, the animation may be slow and rich with relatively more graphical details. In another embodiment, the animation may be fast and showing only minimal necessary statistics. In such cases, typically there is no need to continuously display the animation layout since that may tend to appear like a static picture. The need however may be to display relevant statistical charts and tables and to update them frequently.
Although the present methods and systems are described with reference to a simulation based primary display layer 800 of a testbed environment, the principles associated with them are not limited to only one of such primary display layers. Once the simulation testbed environment is in place, there are several other embodiments possible. In one embodiment, the simulation in the primary display layer 800 is run without a cockpit-like graphical user interface (GUI). In such an embodiment, the simulation model is not an interactive model and most of the input may be provided through an input data file, for instance. This may limit the ability of a typical user to interact with the models both before and during the simulation run, especially if the models are simulated on a platform that the user is not very familiar with. In another embodiment, where the application is in gaming-like educational environments, or is used to train people within a combined automated/manual decision-making setting, it may be difficult or may need additional computational resources to build all the desired models.
In one embodiment, the simulation represented in the primary display layer 800 may be controlled by a cockpit-like GUI external to the simulation engine. This is especially desirable for platforms that do not provide any means of platform-native support for modern graphical user interfaces, and therefore depend on external inputs for control. While the simulation model in this embodiment specializes only on simulating the operation of the business system, the runtime interactive GUI may be functionally delegated to a decoupled module attached to the simulation engine.
Thus, the external cockpits mentioned above are typically command and control cockpits that form the interface between the primary display layer 800 or the transfer function and a human decision maker and/or other auto-decisioning agents. In one embodiment, the external cockpit is structurally decoupled from the primary display layer 800 or the transfer function. The decoupled external cockpit takes on the responsibility of monitoring, interacting with, and decisioning for the simulation presented on the primary display layer 800 by allowing interaction by a decision-making human being. The cockpit is considered ‘decoupled’ because it is not an integral part of the simulation test bed itself, and is not part of the display of the simulation testbed or its primary display layer. Instead, the cockpit is configured to accept output from the simulation, and to pass control parameters into the simulation. By making the cockpit a separate process, it can be started, stopped, displayed, and configured independently of the underlying simulation testbed.
Referring to
Continuing with the exemplary external visual cockpit 900 presented in
While it is possible that the primary display layer 800 of
In one exemplary instance, a high-level workflow simulation model can be controlled using the external cockpit graphical user interface 900 of
To facilitate the interaction of the user with the animation layout 800 using the visual cockpit 900, in one embodiment, there may be two completely separate screens showing the animation layout and visual cockpit. In another embodiment of the user interface, the visual cockpit may overlap and partially cover the animation layout as shown in
The embodiments described here provide a variable transparency or translucency for the layers placed over the primary display of the simulation. This allows effective visibility of the descriptive power of the primary display layer while still providing access to the controls available through the cockpit. As models get more visually complex and interactive, effective use of screen real estate becomes increasingly important, especially when the models are meant to run in animated mode. The usable screen space is used wisely and designed to be collaborative between areas set aside for animation, primary performance measures or other statistics, vis-à-vis the interactive controls on a cockpit that are used for parameter calibration or decision-making throughout the simulation. In one embodiment, the solution implemented is to superimpose the interactive external visual cockpit over the primary display layer 800 of
An interactive mask is defined as a translucent overlay embedded with some controls on it to receive inputs from a user. To provide an interface between the transfer function or the simulation model that acts as the testbed environment and a user, an interactive mask is overlaid on the primary display layer 800. This mask is semi-transparent most of the time and/or in most regions over a computer screen except for those that are sensitive to user-interaction. These sensitive user-interaction zones may be called interaction zones on the computer screen. Over these interaction zones, a user may typically be able to interact with the visual cockpit and still follow the animation and statistics of the simulation on the animation layout 800 by seeing through the mask.
The degree of transparency, translucency and opaqueness or in other words the state of visibility of a part or whole of an interactive mask is adaptable and adjustable depending upon user preferences. In one embodiment, the entire cockpit window is mostly kept transparent, for instance, with 80% transparency level, thereby enabling the user to be visually aware that there is a visual cockpit layer superimposed on the opaque animation layout 800. The user also comes to know intuitively or through explicit instructions that he can make the visual cockpit layer active or let it come alive by being less transparent when the user is moving the mouse over the areas that are sensitive to interaction.
In another embodiment, any other combinations of partial or complete translucent settings, or selective see-through areas, with either the entire cockpit or individual controls may be chosen. In essence, the visual cockpit layer becomes more visible (less transparent) when the user actually desires to interact with the model, but becomes more transparent at other times, allowing the animation layout 800 in the background to display the performance measures. For instance, when a user wants to view any ongoing animation aspect related to the resources 806 of
At another time, when the user actually desires to interact with the model and incorporate behavioral changes on the resources 806, he may move his computer mouse or a similar input device to the vicinity of the display of the resources 806. In another instance, the user may click his mouse or similar input device in the vicinity of the display of the resources 806. In response, the visual cockpit layer 900 becomes active, turning less transparent, and the controls 905 and 908 become ready to receive inputs.
In another embodiment, only the interactive zones including the relevant interactive controls such as the buttons, levers, and input fields may be kept opaque and the rest of the background may be rendered transparent. This allows the controls on the visual cockpit 800 to be identifiable, yet the rest of the animation layout 800 remains largely unobstructed. In yet another embodiment, the entire cockpit window and all of the controls are kept virtually invisible until a user-event triggers an action to do otherwise. This allows the entire model animation to be unobstructed most of the time, while allowing for clear means of interaction. Note that the interactive zone need not be circular, and will not normally be indicated by a visible border in the display. The controls within the interactive zone will simply become more opaque in order to indicate their availability to the user.
In different embodiments presented above, there are many ways to display a particular simulation depending on the level of detail and aspect of focus desired. In a like manner, there are also multiple ways to command and control a given testbed environment. These different command schemes are referred to as “control scenarios” of a simulation. Regardless of the translucency and overlay options for the GUI, the interface design and functionality of the cockpit change with respect to the kind of analysis being performed and the aspects of the simulation being controlled. Typically such aspects of the simulation may include time-crunching activity durations vis-à-vis resource allocation rules vs. staffing levels vs. cost sensitivity vs. decision algorithmic vs. market conditions, etc. In another embodiment, the interface design and functionality of the cockpit may depend on several other factors. These factors may include the level of detail of the animation desired, the type of the user or the use-cases or the points of view into the system. In other instances, the interface design and functionality of the cockpit may depend on availability of any external decision-making agents other than the user who is directly interfacing with this particular mask such as an automated decision engines, other users and the like. Each variation of the masks that provide different access or behavior of the cockpit display represents a different control scenario.
In operationalizing the concept of control scenarios, the translucent mask(s) overlaid with the animation layout 800 play an important role in alternating between various alternative control scenarios without modifying on the underlying simulation testbed platform. As an illustration, when interacting with a particular simulation situation, a user may typically make a choice about what control(s) may come alive and become more dominant. In one embodiment, various control configurations may include only the controls that are being interacted with. In another embodiment, various control configurations may include the controls that are being interacted with and a few others that are notionally or semantically related. In another embodiment, various configurations may include all controls that could possibly be interacted with. The choice will depend on whether the users would desire/prefer to have a visual reminder of what semantic relationships exist between various alternative controls vs. being more interested in minimizing layout clutter.
Every viable combination of the above factors constitutes a simulation control scenario. Each control scenarios results in customized behavior of the visual cockpit due to the differences in the way the user may interact with the underlying simulation. Ideally, different masks, or at least different variations around some key themes, are placed over the animation layout 800 in such a way that the relevant subset of active controls are interlaced with the semantically related areas of the visual cockpit 900. ‘Semantically related’ controls are those that address the same or related functions or activities within the simulation testbed.
The translucent mask(s) as mentioned above when placed over the layout of the animated simulation model enables the user to chose among various alternative menus representing various control scenarios without having to modify the underlying simulation model.
In a typical example, various alternative ways of making the same decision may be illustrated through the use of translucent masks and external decision making agents, under four different control scenarios, each discussed further below. The context here is one of the stages that financial deals flow through in an organization while they are progressing along the workflow. The process in this example may be called “Create Financial Solution” (CFS) process. Typically, CFS includes complex and labor-intensive operations, where up to five different kinds of resources may evaluate the data that has been collected on that deal in previous stages, and decide how to structure, a financing proposal, or even whether to submit a proposal or not. In addition to the overall dynamic/runtime calibration facilities that the visual cockpit 900 provides, a user can typically also choose between four modes while running the simulation with respect to doing short-circuit risk-evaluation for a deal as part of the CFS activity. The four modes may be structured such that they are graded over an increasing order of intelligence introduced in the user interface using different combinations of controls or in other four different control scenarios. The four different control scenarios show the exact same area of the system, but offer four different combinations of the controls on the visual cockpit layout 900. The screen design and interactive components used to input decisions from the user are dependent on the details of the scenario that is active at any point of time.
A first exemplary instance of the CFS simulation may be a traditional decision-making (DM) mode where no short-circuit risk-evaluation is made and all throughput is routed internal to the testbed environment, in a relatively unsophisticated fashion. In this instance, there is no user interaction required, and no additional decision control buttons show up in the visual cockpit 900 overlaying the animation layout 800.
A second exemplary instance of the CFS simulation may be a stepwise user-DM mode where a user is presented with the details of each deal and asked to make a decision about it. In this case, the user is allowed to choose among a few alternative ways to treat a particular deal such as ‘skip this step due to this particular deal being found as not risky’, ‘go through the usual labor-intensive process due to the risk-evaluation process on this deal being inconclusive in either direction’, or ‘immediately drop this deal due to it being found as too risky’ and the like.
A third exemplary instance of the CFS simulation may be a stepwise mode where an external programmatic DM agent is brought in to automatically make the risk-evaluation decisions, and a user can observe the decision-making process for each deal before proceeding with the run. In this case, the user is allowed to step through individual decisions, but not allowed to make manual decisions or change the decisions made. In this instance, the user is merely allowed to observe in detail the simulation going on in the system. He typically is presented with a control button to proceed with the acceptance and execution of the decisions made by an external auto-decisioning agent.
A fourth exemplary instance of the CFS simulation may be an auto-decisioning mode where the same external programmatic DM agent makes and continually introduces the decisions into the model, without waiting for any kind of interaction from the user. In this case too there is no user interaction required, so no additional decision control buttons show up in the visual cockpit 900 overlaying the animation layout 800.
In another embodiment, translucent masks and control scenarios are utilized to enable layers of intelligent agents to be stacked on top of each other. In one such embodiment, the bottom most layer is typically limited to describing the behavior of the system and it does not contain any sophistication in terms of decision-making algorithms. Layers that are built on top of the bottom most layer that are increasingly intelligent in terms of functionalities for detection and correction of certain situations in the testbed, automatic decisioning, as well as a high-level wing-to-wing command and control.
In another embodiment the concepts of control scenarios and translucent masks are further leveraged such that the increasing order of intelligence can be stratified over a number of display layers of intelligent agents stacked on top of each other. In the embodiments presented above in FIGS. 8 to 11, only two display layers (the primary display layer 800 for the simulation and the control cockpit) of the user interface have been described. In other embodiments however there may be multiple intermediate layers inserted between the primary display layer 800 and the visual cockpit layer.
For instance, in one embodiment, the business system user interface may include at least one secondary display layer that presents interpretation of at least one of signals, trends, warning and conclusions generated by the primary display layer. Such a secondary display layer may show aggregated or interpretive output. Such a layer will also be referred to as a “monitoring” layer. While such a layer has an essentially descriptive function, the information presented represents an analysis of the lower level simulation output data. As with the control cockpit described above, such a monitoring layer may preferably be decoupled from the underlying testbed. The display of the monitoring layer may be located at a position relevant to the appropriate supporting data in the primary display layer, so as to provide a visual link between the summary or interpretive information presented in the, secondary display layer, and the portion of the primary display layer associated with the supporting data. For example, a secondary display layer associated with the costs associated with personnel might be overlaid on the primary display layer at a location associated with the operation of that personnel. However, it should be understood that such a secondary display layer need not be presented as an overlay. The various transparency techniques discussed herein with respect to the control cockpit layer may also be applied to the secondary layer.
In yet another embodiment, the business system user interface may further include a tertiary display layer that presents a number of suggested business decisions developed based on the signals, trends, warning and conclusions generated by the primary display layer or the interpretation presented by the at least one secondary display layer. Such a decisioning layer may have the authority to exert some level of control over the underlying simulation by altering certain control parameters of the testbed simulation in response to the output received by the decisioning layer from the testbed. However, decisioning layers may also be configured simply to suggest possible control changes in response to the information that they receive, and leave the choice of whether or not to implement those control changes to the user. The user would be free to implement such changes via the control cockpit as discussed above. As with the secondary display layer, the tertiary or decisioning layer may also be located as an overlay at an appropriate position over the primary display layer, and may have the various transparency properties described herein. Alternatively, the decisioning layers (also referred to as decisioning agents) need not be visually displayed at all.
It is evident that in a multiple layer configuration of the testbed environment as presented above, the masks placed on top of the primary display layer 800 may play an important role in alternating between various control scenarios without making any modifications on the underlying simulation testbed platform. When dealing with intricate systems surrounded by complex decision analytics, one such system may tend to be functionally polarized between two extreme functional possibilities. One such exemplary function is simulating the system in a stochastic fashion to describe the random effects, time dependency and dynamic interactions among components. The second exemplary function is making decisions to drive, optimize, correct the system, recover from disasters, or taking proactive action to make the system more robust to a spectrum of possible future states.
In another embodiment, there may more than two display layers. In one such embodiment, there may be an exemplary bottom-most level that is purely descriptive. In contrast, there may be a top most layer that is prescriptive or decision suggesting in nature. One such layer may typically include a control cockpit. In addition to these two layers, there may be a number of intermediate layers arranged between the bottom most and the top most layer mentioned above. These intermediate layers, comprising one or more monitoring or decisioning layers, when considered from bottom to top, may have an increasing degree of prescriptive attributes such as ability for detection, ability of decision support, automatic decision making and like. The same layers, from bottom to top may have a decreasing degree of descriptive attributes.
In one such exemplary embodiment, there may be four display layers. The first primary display layer presents the simulation testbed environment, which may mostly be limited to describing the system and capturing its dynamics like the primary display layer 800 as shown in
In yet another embodiment, a relatively simple monitoring anomaly detection agent may be visualized in the form of a translucent mask that sits between the stochastic primary display layer 800 and the visual cockpit layer. In a typical exemplary simulation, visual signals on the animation layout 800 may point to the fact that due to the current settings imposed by the cockpit, the testbed environment has accumulated more than 100 business deals in its call queue. This situation may physically happen in real life when the sales resources spend a disproportionately large amount of time generating new leads as compared to a time when they are working on leads already generated. In the event of such an occurrence, the anomaly detection agent detects the anomaly and raises some visual as well as programmatic flags to be noticed by the human decision-maker as well as other auto-decisioning agents that might be active in the integrated system.
In a typical embodiment with multiple display layers, each layer can be implemented in various degrees of fidelity. Degree of fidelity of a particular layer may be understood in terms of a number of factors such as level of detail in a simulation model, flexibility of design, comprehensiveness and shades of gray for rules to raise various kinds of alarms, the complexity and elegance of an auto-decision-making optimization model and the like. In another embodiment, each layer may use various approaches, such as discrete event simulation, agent-based simulation, constraint programming, mathematical programming or heuristic optimization. In most of the different embodiments, it is possible to use a software component as a building block and if necessary, replace one with another suitable one operable at the same level, conforming to the same interfaces and without having to rewrite the rest or the whole of the system afresh.
In terms of a software architecture used to support the construction of the multiple display layers of increasing intelligence and decision supporting functions, one of the options may be to stack the layers vertically and coordinate them to deliver the desired functionalities. In addition to the stacking of the display layers presented above, in another embodiment, it is also possible to develop a network of software components such as data objects, structure, agents in a parallel or naturally segregated or disbursed manner in accordance with the semantic relationships between various areas in the testbed. Each of such various software components may focus on a different aspect of the simulation, yet may enable communication with the others in an attempt to work together and converge towards better solutions.
As such, the simulation mask described above evolves into becoming the GUI tier of such an intelligent/interactive agent, constituting a layer between the simulation engine of the digital cockpit of
A digital cockpit 104 has been described that includes a number of beneficial features, including “what-if” functionality, “do-what” functionality, the pre-calculation of output results, and the visualization of uncertainty in output results.
Although the systems and methods herein have been described in language specific to structural features and/or steps acts, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or steps described above. Rather, the specific features and steps disclosed above are exemplary forms of implementing the systems and methods claimed below.
This application is a continuation-in-part of U.S. patent application Ser. No. 10/339,166, filed on Jan. 9, 2003, entitled “Digital Cockpit,” which is incorporated by reference herein in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 10339166 | Jan 2003 | US |
Child | 11322036 | Dec 2005 | US |