Automated risk transfer system
In computer-implemented methods, systems and program products for estimating financial modeling outcomes, financial data are segmented into a number of categories and scenario data for a set of model scenarios are processed to obtain an estimated model outcome distribution. The categories are mutually exclusive and collectively exhaustive of the financial data while the model may be developed by learning from the data. Multiple model tests are performed with samples of the financial data until a cumulative model outcome distribution is within a pre-determined acceptable tolerance limit from a distribution of fully assessed model outcomes obtainable by performing a single test of the scenarios using all of the financial data.
This application is a continuation of U.S. patent application Ser. No. 09/688,983 filed Oct. 17, 2000, the disclosure of which is incorporated herein by reference. The subject matter of this application is also related to the subject matter of U.S. Pat. No. 5,615,109 for “Method of and System for Generating Feasible, Profit Maximizing Requisition Sets”, by Jeff S. Eder, the disclosure of which is also incorporated herein by reference.
BACKGROUND OF THE INVENTIONThis invention relates to a method of and system for developing and continuously operating an automated, on-line risk transfer system.
Managing a business in a manner that creates long term value is a complex and time-consuming undertaking. This task is complicated by the fact that traditional financial systems do not provide sufficient information for managers in the Knowledge Economy to make the proper decisions. Many have noted that traditional accounting systems are driving modern managers to make the wrong decisions and the wrong investments. Accounting systems are “wrong” for several reasons. One of the most obvious reasons—they track tangible assets while ignoring intangible assets. Intangible assets such as the skills of the employees, intellectual property, business infrastructure, databases, management processes, relationships with customers and relationships with suppliers are not measured with current accounting systems. This oversight is critical because in the present economy the success of an enterprise is determined more by its ability to use its intangible assets than by its ability to amass and control the physical ones that are tracked by traditional accounting systems. The absence of intangible asset information is particularly notable in high technology companies that are highly valued for their intangible assets and their options to enter new markets.
Even when intangible assets have been considered in risk analysis, the limitations in the existing methodology have severely restricted the utility of the information that has been produced. All known prior efforts to value individual intangible assets have been restricted to independent valuations of different types of assets with only limited attempts to measure the actual impact of the asset on the enterprise that owns it. Some of the intangible assets that have been valued separately in this fashion are: brand names, customers and intellectual property. Problems associated with the known methods for valuing individual intangible assets include:
-
- 1. Interaction between intangible assets is ignored. For example, the value of a brand name is in part a function of the customers that use the product—the more prestigious the customers, the stronger the brand name. In a similar fashion the stronger the brand name, the more likely it will be that customers will stay a long time. Valuing either of these assets in isolation will not provide a meaningful valuation; and;
- 2. The value of an intangible asset is a function of the benefit that it provides the enterprise. Therefore, measuring the value of an intangible asset requires a method for measuring the actual impact of the asset on the enterprise—something that is missing from all known existing methods.
Another aspect of the increasing importance of “intangible” assets is the fact that the primary risks faced by most companies have now shifted from hard asset damage (fire, flood, etc.) to soft asset impairment or loss. A recent study found that between June 1993 and May 1998, ten percent of the Fortune 1000 lost more than one quarter (25%) of their total shareholder value in one month. Almost two thirds of these “large losses” were caused by problems related to intangible assets.
The deficiencies of traditional accounting reports exacerbate the difficulty companies' face when reporting problems with intangible assets because:
-
- 1. The absence of regular reporting means that all problems with intangible assets come “out of the blue”; and
- 2. The absence or regular reporting makes it difficult to monitor company efforts to correct the problems.
Given the absence of reporting on many of the intangible assets driving the success of companies in the Knowledge Economy, it should not be surprising to learn that traditional accounting systems are also deficient in reporting significant information relevant to the liability side of the balance sheet. Traditional financial statements footnote or in some cases ignore large potential liabilities including: loss from litigation, environmental clean-up costs and shortfalls on leasing revenues. The absence of routine reporting on these risks does not alter the fact that they have a material, negative impact on the value of the company that has these risks. Recent studies completed at Oxford University have confirmed that “off balance sheet risk” has a negative impact on market value for firms that have these risks.
This negative impact of these risks on market value can be substantial. A recently completed study found that exposure to future, un-booked liabilities for environmental cleanup reduced share price by an average of 16% for electric utilities targeted by the Clean Air Act Amendments of 1990. It is worth noting that as more information became public regarding the actual cost of the environmental cleanup and pollution abatement the reduction in share price moderated. A transparent analysis of the liability associated with the environmental cleanup would have given the market the information required to more rapidly reach the proper conclusion regarding the impact of these new costs.
In addition to risks from intangible asset impairment and unrecognized liabilities, companies face other risks that are more readily analyzed. These risks are shown in Table 1.
These risks are usually analyzed using a standardized risk analysis product such as Dun and Bradstreet's Risk Assessment Manager™ for credit risk and Barra's Cosmos™ System for portfolio risk. The analyses of the risks listed in Table 1 are generally completed in isolation so their impact on the overall firm is not clear and opportunities for natural “self hedging” aren't apparent.
Another problem associated with developing risk programs for isolated assets is that they have generated severe losses for firms that didn't fully understand the potential liability their “risk reduction programs” were creating. One of the most common mechanisms for minimizing the risks shown in Table 1 is to hedge the exposure using a derivative or option to “lock in” the maximum amount of exposure the firm is faced with over a given time period. In some cases, when the risk factors moved in a direction opposite to the direction being hedged (i.e. interest rates dropped when they were expected to increase) the firm hedging its risk experience a far greater loss than any loss ever envisioned under the worst case analysis of their risk exposure.
Unexpected losses aren't the biggest shortcoming of traditional risk management systems. Because traditional risk management systems are driven by a statistical analysis of prior history, they are generally limited to dealing with events that vary within parameters that have already been experienced. The problem with this is that most large losses are caused by events that fall outside the bounds of normal experience (i.e. hundred-year floods and once-in-a-lifetime events).
It is also worth noting that the limitations of the general ledger accounting systems discussed previously (lack of information about intangible assets and off balance sheet risk) also extend to the risk analyses that are completed based largely on the information provided by general ledger systems. These same limitations also extend to the all known efforts to analyze and/or simulate the impact of changes in the business on financial performance and risk. Put simply—it is impossible to analyze the impact on risk with no prior information. The lack of detailed information on intangible assets and their impact on risk has also limited simulation products such as the Dynamic Financial Analysis (DFA) and the Small Business Financial Manager to projecting the impact of changes in revenue, expense or balance sheet items (tangible assets and financial liabilities) on financial performance. Given the growing importance of intangible assets to financial performance and risk, the utility of these systems is very limited. In a similar manner the lack of quantitative information on the impact of intangibles on financial performance has limited the usefulness of simulation products such as Tango that incorporate generic information regarding intangibles.
The complexity and relatively high cost of obtaining people that understand how to use the traditional risk analysis systems has generally limited the analysis and active management of risk to larger companies. This is ironic because large companies are the ones that are in the best position to absorb the risks that are being managed while smaller companies that don't have the resources to survive a large loss are left even more vulnerable by their inability to examine their risks in detail. Clearly, an automated system for developing comprehensive risk management programs for companies of all sizes would be beneficial.
However, even when comprehensive risk analyses are available the numerous coverage restrictions, general lack of precision in the policies and the high cost of traditional insurance dissuade many from obtaining the coverage that could, in some cases, save their companies from financial ruin. The multi-line, multi-period insurance policies some firms are selling only partially alleviate these problems. At the same time, the lack of precision in the risks being covered is understandable in so far as the insurers have only very limited information about the actual risks being faced by the companies they are insuring. A system that provided the insurers with continuous, detailed information regarding the risks faced by their clients would clearly help alleviate this problem.
Another barrier to effective use of insurance and risk reduction products like derivatives is the time required to analyze and purchase them. In some cases the need arises and disappears before the traditional systems and labor intensive review systems can respond. If the risk does not materialize, then everything is fine. If it does, then the company may go out of business before it faces the next risk. In either event, the large amount of time required to obtain these products leaves many companies exposed to risks that they could easily avoid if a more automated system was available.
The underlying cause of all these problems is that insurance and most financial services are delivered in a manner that is similar to the U.S. manufacturing sector twenty five years ago when obtaining the right product required an army of people to sift through a variety of quotes, place an order and then monitor the orders to make sure what was ordered actually arrived on time. The manufacturing and retail sectors have replaced their old, labor-intensive systems with electronic supply chain systems that tightly link them with their suppliers. Using these systems, suppliers provide the specific products and services that are required for smooth operation “just-in-time”. A similar system that would enable financial service firms to provide financial “products” like insurance, foreign exchange, capital and credit tailored to the specific situation on a “just-in-time” would clearly be beneficial. The system could also work in real time providing
One of the biggest problems with achieving this goal has been that there has been no agreed upon method for analyzing risk, liquidity and foreign exchange requirements and for communicating that information to financial service firms. It is worth noting at this point that while XML is widely touted as a panacea for inter-firm communication it is only useful in establishing the language for the communication—not the substance of what is being communicated. To satisfy all the potential providers of financial services, the substance of the communication regarding risk, liquidity and foreign exchange requirements would have to overcome the limitations of traditional systems that:
1) Ignore intangible assets;
2) Ignore real options;
3) Analyze individual assets in isolation, and
4) Ignore or footnote contingent liabilities and other off balance sheet risk;
In light of the preceding discussion, it is clear that it would be desirable to have an automated, real time system that could quantify and communicate information to financial service providers regarding the full spectrum of risk transfer (and liquidity) needs for an enterprise in a way that that was supported by a detailed, rigorous evaluation of all the elements of the enterprise that create business value and business risk. Ideally, this system would allow financial service firms to provide “just in time” and/or real time financial products and services in a manner that is customized to the exact needs of the enterprise using the system.
SUMMARY OF THE INVENTIONIt is a general object of the present invention to provide a novel and useful system for on-line risk transfer that overcomes the limitations and drawbacks of the existing art that were described previously.
A preferable object to which the present invention is applied is fully quantifying and then satisfying the risk reduction needs for a commercial business. Comprehensive quantification of enterprise requirements is enabled by:
- 1) Systematically analyzing and valuing contingent liabilities using real option algorithms as required to ensure that the most current information regarding the magnitude of potential liabilities is included in all analyses;
- 2) Developing an improved understanding of the variability and risk associated with all elements of enterprise value—tangible and intangible;
- 3) Incorporating insights from the analyses of performance by asset management systems (i.e. Customer Relationship Management, Supply Chain Management, Brand Management, etc.) and the analyses of risk by asset risk management systems (credit risk, currency risk, etc.) for individual assets;
- 4) Integrating or fusing the information from the first three items as required to develop a complete, three hundred sixty degree (360°) view of the risk and opportunities faced by the company;
- 5) Clearly identifying the liquidity and foreign exchange position of the enterprise; and
- 6) Developing the optimal risk reduction program for the company within the constraints specified by the user.
The system of the present invention also calculates and displays an optimal value enhancement program for the commercial enterprise using the system. Because information on liquidity and foreign exchange needs is developed and transmitted along with the risk information, the system of the present invention is also capable of functioning as an automated, on-line liquidity transfer system, alone or in combination with the risk transfer system.
The information for each enterprise using the system is continuously communicated in summary format to the central exchange (such as an insurance company or bank) that analyzes the information for all enterprises to:
-
- 1) Arrange swaps of risk, between enterprises with complementary, offsetting needs for a fee; and/or
- 2) Arrange for insurance for a larger fee as required to meet the needs of each enterprise using the system and the profit goals (and reserve requirements) of the firm operating the central exchange.
To provide the most secure system for transferring risk, the system of the present invention goes on to analyze the information provided by each enterprise and the firm operating the central exchange (hereinafter, the central exchange operator) to determine if standby credit lines and/or re-insurance are required. If either of these “back-up” facilities for capital is required, then the appropriate amount of standby credit and/or reinsurance is determined by the system of the present invention.
In addition to enabling the just in time provision of financial services, the present invention has the added benefit of eliminating a great deal of time-consuming and expensive effort by automating the extraction of data from the databases, tables, and files of existing computer-based corporate finance, operations, human resource, supply chain, web-site and “soft” asset management system databases as required to operate the system. In accordance with the invention, the automated extraction, aggregation and analysis of data from a variety of existing computer-based systems significantly increases the scale and scope of the analysis that can be completed. The system of the present invention further enhances the efficiency and effectiveness of the business valuation by automating the retrieval, storage and analysis of information useful for valuing elements of value from external databases, external publications and the internet. Uncertainty over which method is being used for completing the valuation and the resulting inability to compare different valuations is eliminated by the present invention by consistently utilizing the same set of valuation methodologies for valuing the different elements of enterprise value as shown in Table 2.
The market value of the enterprise is calculated by combining the market value of all debt and equity as shown in Table 3.
Consultants from McKinsey & Company recently completed a three year study of companies in 10 industry segments in 12 countries that confirmed the importance of intangible elements of value as enablers of new business expansion and profitable growth. The results of the study, published in the book The Alchemy of Growth, revealed three common characteristics of the most successful businesses in the current economy:
- 1. They consistently utilize “soft” or intangible assets like brands, customers and employees to support business expansion;
- 2. They systematically generate and harvest real options for growth; and
- 3. Their management focuses on three distinct “horizons”—short term (1-3 years), growth (3-5 years out) and options (beyond 5 years).
The experience of several of the most important companies in the U.S. economy, e.g. IBM, General Motors and DEC, in the late 1980s and early 1990s illustrate the problems that can arise when intangible asset information is omitted from corporate financial statements and companies focus only on the short term horizon. All three companies were showing large profits using current accounting systems while their businesses were deteriorating. If they had been forced to take write-offs when the declines in intangible assets were occurring, the problems would have been visible to the market and management would have been forced to act to correct the problems much more quickly than they actually did. These deficiencies of traditional accounting systems are particularly noticeable in high technology companies that are highly valued for their intangible assets and their options to enter growing markets rather than their tangible assets.
The utility of the valuations produced by the system of the present invention are further enhanced by explicitly calculating the expected purchase longevity of the different customers and different elements of value as required to improve the accuracy and usefulness of the valuations.
As shown in Table 2, real options and contingent liabilities are valued using real option algorithms. Because real option algorithms explicitly recognize whether or not an investment is reversible and/or if it can be delayed, the values calculated using these algorithms are more realistic than valuations created using more traditional approaches like Net Present Value. The use of real option analysis for valuing growth opportunities and contingent liabilities (hereinafter, real options) gives the present invention a distinct advantage over traditional approaches to risk management.
The innovative system has the added benefit of providing a large amount of detailed information to the enterprise and central exchange users concerning both tangible and intangible elements of value. Because intangible elements are by definition not tangible, they can not be measured directly. They must instead be measured by the impact they have on their surrounding environment. There are analogies in the physical world. For example, electricity is an “intangible” that is measured by the impact it has on the surrounding environment. Specifically, the strength of the magnetic field generated by the flow of electricity through a conductor is used to determine the amount of electricity that is being consumed. The system of the present invention measures intangible elements of value by identifying the attributes that, like the magnetic field, reflect the strength of the element in driving components of value (revenue, expense and change in capital) and market prices for company equity and are easy to measure. Once the attributes related to the strength of each element are identified, they can be summarized into a single expression (a composite variable or vector). The vectors for all elements are then evaluated to determine their relative contribution to driving each of the components of value. The system of the present invention calculates the product of the relative contribution and the forecast longevity of each element to determine the relative contribution to each of the components of value. The contributions to each component of value are then added together to determine the value of each element (see Table 5).
The method for tracking all the elements of value for a business enterprise provided by the present invention eliminates many of the limitations associated with current systems for risk management that were described previously. To facilitate its use as a tool for managing risk for a commercial enterprise, the system of the present invention produces reports in formats that are similar to the reports provided by traditional accounting systems. Incorporating information regarding all the elements of value is just one of the ways the system of the present invention overcomes the limitations of existing systems. Other advances include:
- 1. The integrated analysis of all risks,
- 2. The automated analysis of both “normal” risks and extreme risks, and
- 3. The preparation of an xml summary of enterprise risk that enable the automated delivery of risk management products and services.
By eliminating many of the gaps in information available to personnel in the enterprise and the central exchange, the system of the present invention enables the just-in-time provision of financial services that are tailored to the exact needs of the enterprise. The electronic linkage also eliminates the time lag that prevents many from companies from obtaining the risk reduction products they need
These and other objects, features and advantages of the present invention will be more readily apparent from the following description of the preferred embodiment of the invention in which:
All extracted information is stored in a file or table (hereinafter, table) within an application database (50) as shown in
The exchange database (51) contains tables for storing user input, extracted information and system calculations including an xml profile table (180), an exchange bot date table (181), a customer table (182), a risk products table (183), a swaps table (184), a customer profile table (185), an exchange payout history table (186), an exchange generic risk table (187), a liability scenario table (188), an asset position table (189), an external exchange database table (190), an asset forecasts table (191), an asset correlation table (192), an asset scenario table (193), an exchange simulations table (194), a contingent capital table (195), an optimal exchange mix table (196) and an exchange premium history table (157). The exchange database (51) can optionally exist as a datamart, data warehouse or departmental warehouse.
As shown in
The exchange-server personal computer (140) has a read/write random access memory (141), a hard drive (142) for storage of the exchange database (51), a keyboard (143), a communications bus (144), a display (145), a mouse (146), a CPU (147) and a printer (148).
The database-server personal computer (130) has a read/write random access memory (131), a hard drive (132) for storage of the application database (50), a keyboard (133), a communications bus (134), a display (135), a mouse (136), a CPU (137) and a printer (138).
While only one database server personal computer is shown in
The application-server personal computer (120) has a read/write random access memory (121), a hard drive (122) for storage of the non-user-interface portion of the enterprise portion of the application software (200, 300, 400 and 500) of the present invention, a keyboard (123), a communications bus (124), a display (125), a mouse (126), a CPU (127) and a printer (128). While only one client personal computer is shown in
The user-interface personal computer (110) has a read/write random access memory (111), a hard drive (112) for storage of a client data-base (49) and the user-interface portion of the application software (700), a keyboard (113), a communications bus (114), a display (115), a mouse (116), a CPU (117) and a printer (118).
The application software (200, 300, 400, 500 and 700) controls the performance of the central processing unit (127) as it completes the calculations required to support the enterprise portion of the risk transfer system. The application software (600) in the exchange server personal computer (140) controls the performance of the central processing unit (147) for the exchange portion of the risk transfer system. In the embodiment illustrated herein, the application software program (200, 300, 400, 500, 600 and 700) is written in a combination of C++ and Visual Basic®. The application software (200, 300, 400, 500, 600 and 700) can use Structured Query Language (SQL) for extracting data from the databases and the internet (5, 10, 12, 15, 17, 25, 30, 35, 37 and 40). The user (20) can optionally interact with the user-interface portion of the application software (700) using the browser software (800) in the browser appliance (90) to provide information to the application software (200, 300, 400, 500 and 700) for use in determining which data will be extracted and transferred to the application database (50) by the data bots.
User input is initially saved to the client database (49) before being transmitted to the communication bus (124) and on to the hard drive (122) of the application-server computer via the network (45). Following the program instructions of the application software, the central processing unit (127) accesses the extracted data and user input by retrieving it from the hard drive (122) using the random access memory (121) as computation workspace in a manner that is well known.
The computers (110, 120, 130 and 140) shown in
Using the system described above, enterprise activity is analyzed, a comprehensive risk management program is developed and implemented for each enterprise after element of value within the enterprise is analyzed using the formulas and data listed in Table 2. As shown in Table 2, the value of the current-operation will be calculated using an income valuation. An integral part of most income valuation models is the calculation of the present value of the expected cash flows, income or profits associated with the current-operation. The present value of a stream of cash flows is calculated by discounting the cash flows at a rate that reflects the risk associated with realizing the cash flow. For example, the present value (PV) of a cash flow of ten dollars ($10) per year for five (5) years would vary depending on the rate used for discounting future cash flows as shown below.
One of the first steps in evaluating the elements of current-operation value is extracting the data required to complete calculations in accordance with the formula that defines the value of the current-operation as shown in Table 4.
The three components of current-operation value will be referred to as the revenue value (R), the expense value (E) and the capital value (C). Examination of the equation in Table 4 shows that there are three ways to increase the value of the current-operation—increase the revenue, decrease the expense or decrease the capital requirements (note: this statement ignores a fourth way to increase value—decrease the interest rate used for discounting future cash flows).
In the preferred embodiment, the revenue, expense and capital requirement forecasts for the current operation, the real options and the contingent liabilities are obtained from an advanced financial planning system database (30) derived from an advanced financial planning system similar to the one disclosed in U.S. Pat. No. 5,615,109. The extracted revenue, expense and capital requirement forecasts are used to calculate a cash flow for each period covered by the forecast for the enterprise by subtracting the expense and change in capital for each period from the revenue for each period. A steady state forecast for future periods is calculated after determining the steady state growth rate that best fits the calculated cash flow for the forecast time period. The steady state growth rate is used to calculate an extended cash flow forecast. The extended cash flow forecast is used to determine the Competitive Advantage Period (CAP) implicit in the enterprise market value.
While it is possible to use analysis bots to sub-divide each of the components of current operation value into a number of sub-components for analysis, the preferred embodiment has a pre-determined number of sub-components for each component of value for the enterprise. The revenue value is not subdivided. In the preferred embodiment, the expense value is subdivided into five sub-components: the cost of raw materials, the cost of manufacture or delivery of service, the cost of selling, the cost of support and the cost of administration. The capital value is subdivided into six sub-components: cash, non-cash financial assets, production equipment, other assets (non financial, non production assets), financial liabilities and equity. The production equipment and equity sub-components are not used directly in evaluating the elements of value.
The components and sub-components of current-operation value will be used in valuing the elements and sub-elements of value. An element of value will be defined as “an identifiable entity or group of items that as a result of past transactions and other data has provided and/or is expected to provide economic benefit to an enterprise”. An item will be defined as a single member of the group that defines an element of value. For example, an individual salesman would be an “item” in the “element of value” sales staff. The data associated with performance of an individual item will be referred to as “item variables”.
Analysis bots are used to determine element of value lives and the percentage of: the revenue value, the expense value, and the capital value that are attributable to each element of value. The resulting values are then added together to determine the valuation for different elements as shown by the example in Table 5.
The risk reduction program development using the approach outlined above is completed in five distinct stages. As shown in
- 1. Identify the item variables, item performance indicators and composite variables for each element of value and sub-element of value that drive the components of value (revenue, expense and changes in capital) and the market price of company equity,
- 2. Create vectors that summarize the performance of the item variables and item performance indicators for each element of value and sub-element of value,
- 3. Determine the appropriate discount rate on the basis of relative causal element strength and value the enterprise real options and contingent liabilities;
- 4. Determine the appropriate discount rate, value and allocate the industry real options to the enterprise on the basis of relative causal element strength;
- 5. Determine the expected life of each element of value and sub-element of value;
- 6. Calculate the enterprise current operation value and value the revenue, expense and capital components of said current operations using the information prepared in the previous stage of processing;
- 7. Specify and optimize predictive models to determine the relationship between the vectors determined in step 2 and the revenue, expense and capital component values determined in step 6,
- 8. Combine the results of the fifth, sixth and seventh stages of processing to determine the value of each element and sub-element (as shown in Table 5); and
- 9. Determine the causal factors for company stock price movement, calculate market sentiment and analyze the causes of market sentiment.
The third stage of processing (block 400 fromFIG. 1 ) analyzes the risks faced by the enterprise in normal and extreme conditions as required to develop a comprehensive risk management program for the enterprise. The fourth stage of processing (block 500 fromFIG. 1 ) implements the risk reduction program by communicating with the exchange, purchasing the required risk reduction and/or by updating soft asset, finance and operation management systems to implement risk reduction programs. The fifth and final stage of processing (block 600 fromFIG. 1 ) analyzes the risks from all the enterprises using the exchange, sets prices and communicates with each enterprise as required to complete risk reduction program transactions.
The flow diagrams in
Corporate financial software systems are generally divided into two categories, basic and advanced. Advanced financial systems utilize information from the basic financial systems to perform financial analysis, financial planning and financial reporting functions. Virtually every commercial enterprise uses some type of basic financial system as they are required to use these systems to maintain books and records for income tax purposes. An increasingly large percentage of these basic financial systems are resident in microcomputer and workstation systems. Basic financial systems include general-ledger accounting systems with associated accounts receivable, accounts payable, capital asset, inventory, invoicing, payroll and purchasing subsystems. These systems incorporate worksheets, files, tables and databases. These databases, tables and files contain information about the company operations and its related accounting transactions. As will be detailed below, these databases, tables and files are accessed by the application software of the present invention as required to extract the information required for completing a business valuation. The system is also capable of extracting the required information from a data warehouse (or datamart) when the required information has been pre-loaded into the warehouse.
General ledger accounting systems generally store only valid accounting transactions. As is well known, valid accounting transactions consist of a debit component and a credit component where the absolute value of the debit component is equal to the absolute value of the credit component. The debits and the credits are posted to the separate accounts maintained within the accounting system. Every basic accounting system has several different types of accounts. The effect that the posted debits and credits have on the different accounts depends on the account type as shown in Table 6.
General ledger accounting systems also require that the asset account balances equal the sum of the liability account balances and equity account balances at all times.
The general ledger system generally maintains summary, dollar only transaction histories and balances for all accounts while the associated subsystems, accounts payable, accounts receivable, inventory, invoicing, payroll and purchasing, maintain more detailed historical transaction data and balances for their respective accounts. It is common practice for each subsystem to maintain the detailed information shown in Table 7 for each transaction.
As is well known, the output from a general ledger system includes income statements, balance sheets and cash flow statements in well defined formats which assist management in measuring the financial performance of the firm during the prior periods when data input and system processing have been completed.
While basic financial systems are similar between firms, operation management systems vary widely depending on the type of company they are supporting. These systems typically have the ability to not only track historical transactions but to forecast future performance. For manufacturing firms, operation management systems such as Enterprise Resource Planning Systems (ERP), Material Requirement Planning Systems (MRP), Purchasing Systems, Scheduling Systems and Quality Control Systems are used to monitor, coordinate, track and plan the transformation of materials and labor into products. Systems similar to the one described above may also be useful for distributors to use in monitoring the flow of products from a manufacturer.
Operation Management Systems in manufacturing firms may also monitor information relating to the production rates and the performance of individual production workers, production lines, work centers, production teams and pieces of production equipment including the information shown in Table 8.
Operation management systems are also useful for tracking requests for service to repair equipment in the field or in a centralized repair facility. Such systems generally store information similar to that shown below in Table 9.
Web site transaction log databases keep a detailed record of every visit to a web site, they can be used to trace the path of each visitor to the web site and upon further analysis can be used to identify patterns that are most likely to result in purchases and those that are most likely to result in abandonment. This information can also be used to identify which promotion would generate the most value for the company using the system. Web site transaction logs generally contain the information shown in Table 10.
Computer based human resource systems may some times be packaged or bundled within enterprise resource planning systems such as those available from SAP, Oracle and Peoplesoft. Human resource systems are increasingly used for storing and maintaining corporate records concerning active employees in sales, operations and the other functional specialties that exist within a modern corporation. Storing records in a centralized system facilitates timely, accurate reporting of overall manpower statistics to the corporate management groups and the various government agencies that require periodic updates. In some cases human resource systems include the company payroll system as a subsystem. In the preferred embodiment of the present invention, the payroll system is part of the basic financial system. These systems can also be used for detailed planning regarding future manpower requirements. Human resource systems typically incorporate worksheets, files, tables and databases that contain information about the current and future employees. As will be detailed below, these databases, tables and files are accessed by the application software of the present invention as required to extract the information required for completing a business valuation. It is common practice for human resource systems to store the information shown in Table 11 for each employee.
Risk management systems databases (17) contain statistical data about the past behavior and forecasts of likely future behavior of interest rates, currency exchange rates and commodity prices. They also contain information about the current mix of risk reduction products (derivatives, insurance, etc.) the enterprise has purchased. Some companies also use risk management systems to evaluate the desirability of extending or increasing credit lines to customers. The information from these systems can be used to supplement the risk information developed by the system of the present invention.
External databases can be used for obtaining information that enables the definition and evaluation of a variety of things including elements of value, market value factors, industry real options and composite variables. In some cases information from these databases can be used to supplement information obtained from the other databases and the internet (5, 10, 12, 15, 17, 30, 35, 37 and 40). In the system of the present invention, the information extracted from external databases (25) can be in the forms listed in Table 12.
The system of the present invention uses different “bot” types to process each distinct data type from external databases (25). The same “bot types” are also used for extracting each of the different types of data from the Internet (40). The system of the present invention must have access to at least one external database (25) that provides information regarding the equity prices for the enterprise and the equity prices and financial performance of competitors.
Advanced financial systems may also use information from external databases (25) and the internet (40) in completing their processing. Advanced financial systems include financial planning systems and activity based costing systems. Activity based costing systems may be used to supplement or displace the operation of the expense component analysis segment of the present invention as disclosed previously. Financial planning systems generally use the same format used by basic financial systems in forecasting income statements, balance sheets and cash flow statements for future periods. Management uses the output from financial planning systems to highlight future financial difficulties with a lead time sufficient to permit effective corrective action and to identify problems in company operations that may be reducing the profitability of the business below desired levels. These systems are most often developed by individuals within companies using two and three dimensional spreadsheets such as Lotus 1-2-3®, Microsoft Excel® and Quattro Pro C. In some cases, financial planning systems are built within an executive information system (EIS) or decision support system (DSS). For the preferred embodiment of the present invention, the advanced finance system database is similar to the financial planning system database detailed in U.S. Pat. No. 5,165,109 for “Method of and System for Generating Feasible, Profit Maximizing Requisition Sets”, by Jeff S. Eder, the disclosure of which is incorporated herein by reference.
While advanced financial planning systems have been around for some time, soft asset management systems are a relatively recent development. Their appearance is further proof of the increasing importance of “soft” assets. Soft asset management systems include: alliance management systems, brand management systems, customer relationship management systems, channel management systems, intellectual property management systems, process management systems and vendor management systems. Soft asset management systems are similar to operation management systems in that they generally have the ability to forecast future events as well as track historical occurrences. Customer relationship management systems are the most well established soft asset management systems at this point and will be the focus of the discussion regarding soft asset management system data. In firms that sell customized products, the customer relationship management system is generally integrated with an estimating system that tracks the flow of estimates into quotations, orders and eventually bills of lading and invoices. In other firms that sell more standardized products, customer relationship management systems generally are used to track the sales process from lead generation to lead qualification to sales call to proposal to acceptance (or rejection) and delivery. All customer relationship management systems would be expected to track all of the customers interactions with the enterprise after the first sale and store information similar to that shown below in Table 13.
Supply chain management system databases (37) contain information that may have been in operation management system databases (10) in the past. These systems provide enhanced visibility into the availability of goods and promote improved coordination between customers and their suppliers. All supply chain management systems would be expected to track all of the items ordered by the enterprise after the first purchase and store information similar to that shown below in Table 14.
System processing of the information from the different databases (5, 10, 12, 15, 17, 25, 30, 35 and 37) and the internet (40) described above starts in a block 201,
The enterprise checklists are used by a “rules” engine (such as the one available from Neuron Data) in block 202 to influence the number and type of items with pre-defined metadata mapping for each category of value. For example, if the checklists indicate that the enterprise is focused on branded, consumer markets, then additional brand related factors will be pre-defined for mapping. The application of these system settings will be further explained as part of the detailed explanation of the system operation.
The software in block 202 uses the current system date to determine the time periods (months) that require data to complete the current operation and the real option valuations. After the date range is calculated it is stored in the system settings table (140). In the preferred embodiment the valuation of the current operation by the system utilizes basic financial, advanced financial, soft asset management, supply chain, web-site transaction, external database and human resource data for the three year period before and the three year forecast period after the current date. The user (20) also has the option of specifying the data periods that will be used for completing system calculations.
After the storage of system setting data is complete, processing advances to a software block 203. The software in block 203 prompts the user (20) via the metadata and conversion rules window (702) to map metadata using the standard specified by the user (20) (XML, Microsoft Open Information Model or the Metadata Coalitions specification) from the basic financial system database (5), the operation management system database (10), the web site transaction log database (12), the human resource information system database (15), the risk management system database (17), the external database (25), the advanced financial system database (30), the soft asset management system database (35) and the supply chain system database (37) to the enterprise hierarchy stored in the system settings table (140) and to the pre-specified fields in the metadata mapping table (141). Pre-specified fields in the metadata mapping table include, the revenue, expense and capital components and sub-components for the enterprise and pre-specified fields for expected value drivers. Because the bulk of the information being extracted is financial information, the metadata mapping often takes the form of specifying the account number ranges that correspond to the different fields in the metadata mapping table (141). Table 16 shows the base account number structure that the account numbers in the other systems must align with. For example, using the structure shown below, the revenue component for the enterprise could be specified as enterprise 01, any department number, accounts 400 to 499 (the revenue account range) with any sub-account.
As part of the metadata mapping process, any database fields that are not mapped to pre-specified fields are defined by the user (20) as component of value. elements of value or non-relevant attributes and “mapped” in the metadata mapping table (141) to the corresponding fields in each database in a manner identical to that described above for the pre-specified fields. After all fields have been mapped to the metadata mapping table (141), the software in block 203 prompts the user (20) via the metadata and conversion rules window (702) to provide conversion rules for each metadata field for each data source. Conversion rules will include information regarding currency conversions and conversion for units of measure that may be required to accurately and consistently analyze the data. The inputs from the user (20) regarding conversion rules are stored in the conversion rules table (142) in the application database (50). When conversion rules have been stored for all fields from every data source, then processing advances to a software block 204.
The software in block 204 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 212. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 207.
The software in block 207 checks the bot date table (149) and deactivates any basic financial system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142).
The software in block 207 then initializes data bots for each field in the metadata mapping table (141) that mapped to the basic financial system database (5) in accordance with the frequency specified by user (20) in the system settings table (140). Bots are independent components of the application that have specific tasks to perform. In the case of data acquisition bots, their tasks are to extract and convert data from a specified source and then store it in a specified location. Each data bot initialized by software block 207 will store its data in the basic financial system table (143). Every data acquisition bot for every data source contains the information shown in Table 17.
After the software in block 207 initializes all the bots for the basic financial system database, processing advances to a block 208. In block 208, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the basic financial system database (5), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the basic financial system metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the basic financial system table (143). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the basic financial system table (143). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing passes on to software block 212.
The software in block 212 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 228. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 221.
The software in block 221 checks the bot date table (149) and deactivates any operation management system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 221 then initializes data bots for each field in the metadata mapping table (141) that mapped to the operation management system database (10) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 221 will store its data in the operation system table (144).
After the software in block 221 initializes all the bots for the operation management system database, processing advances to a block 222. In block 222, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the operation management system database (10), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the operation management system metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the operation system table (144). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the operation system table (144). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to a software block 225.
The software in block 225 checks the bot date table (149) and deactivates any web site transaction log data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 225 then initializes data bots for each field in the metadata mapping table (141) that mapped to the web site transaction log database (12) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 225 will store its data in the web log data table (172).
After the software in block 225 initializes all the bots for the web site transaction log database, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the web site transaction log database (12), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the web site transaction log metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the web log data table (172). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the web log data table (172). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to a software block 226.
The software in block 226 checks the bot date table (149) and deactivates any human resource information system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 226 then initializes data bots for each field in the metadata mapping table (141) that mapped to the human resource information system database (15) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 226 will store its data in the human resource system table (145).
After the software in block 226 initializes all the bots for the human resource information system database, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the human resource information system database (15), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the human resource information system metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the human resource system table (145). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the human resource system table (145). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 228.
The software in block 228 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 248. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 241.
The software in block 241 checks the bot date table (149) and deactivates any external database data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 241 then initializes data bots for each field in the metadata mapping table (141) that mapped to the external database (25) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 241 will store its data in the external database table (146).
After the software in block 241 initializes all the bots for the external database, processing advances to a block 242. In block 242, the bots extract and convert data in accordance with their preprogrammed instructions. As each bot extracts and converts data from the external database (25), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the external database metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the external database table (146). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the external database table (146). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to a software block 245.
The software in block 245 checks the bot date table (149) and deactivates any advanced financial system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 245 then initializes data bots for each field in the metadata mapping table (141) that mapped to the advanced financial system database (30) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 245 will store its data in the advanced finance system database table (147).
After the software in block 245 initializes all the bots for the advanced finance system database, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the advanced financial system database (30), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the advanced finance system database metadata to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the advanced finance system database table (147). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the advanced finance system database table (147). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 246.
The software in block 246 checks the bot date table (149) and deactivates any soft asset management system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 246 then initializes data bots for each field in the metadata mapping table (141) that mapped to a soft asset management system database (35) in accordance with the frequency specified by user (20) in the system settings table (140). Extracting data from each soft asset management system ensures that the management of each soft asset is considered and prioritized within the overall financial models for the each enterprise. Each data bot initialized by software block 246 will store its data in the soft asset system table (148).
After the software in block 246 initializes bots for all soft asset management system databases, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the soft asset management system databases (35), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the metadata for the soft asset management system databases to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the soft asset system table (148). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the soft asset system table (148). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 248.
The software in block 248 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 264. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 261.
The software in block 261 checks the bot date table (149) and deactivates any risk management system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 261 then initializes data bots for each field in the metadata mapping table (141) that mapped to a risk management system database (17) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 261 will store its data in the risk system table (176).
After the software in block 261 initializes bots for all risk management system databases, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the risk management system databases (17), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the metadata for the risk management system database (17) to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the risk management system table (174). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the risk management system table (174). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 262.
The software in block 262 checks the bot date table (149) and deactivates any supply chain system data bots with creation dates before the current system date and retrieves information from the system settings table (140), metadata mapping table (141) and conversion rules table (142). The software in block 262 then initializes data bots for each field in the metadata mapping table (141) that mapped to a supply chain system database (37) in accordance with the frequency specified by user (20) in the system settings table (140). Each data bot initialized by software block 262 will store its data in the supply chain system table (174).
After the software in block 262 initializes bots for all supply chain system databases, the bots extract and convert data in accordance with their preprogrammed instructions in accordance with the frequency specified by user (20) in the system settings table (140). As each bot extracts and converts data from the supply chain system databases (37), processing advances to a software block 209 before the bot completes data storage. The software in block 209 checks the metadata for the supply chain system database (37) to see if all fields have been extracted. If the software in block 209 finds no unmapped data fields, then the extracted, converted data are stored in the supply chain system table (174). Alternatively, if there are fields that haven't been extracted, then processing advances to a block 211. The software in block 211 prompts the user (20) via the metadata and conversion rules window (702) to provide metadata and conversion rules for each new field. The information regarding the new metadata and conversion rules is stored in the metadata mapping table (141) and conversion rules table (142) while the extracted, converted data are stored in the supply chain system table (174). It is worth noting at this point that the activation and operation of bots where all the fields have been mapped to the application database (50) continues. Only bots with unmapped fields “wait” for user input before completing data storage. The new metadata and conversion rule information will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 264.
The software in block 264 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 276. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 265.
The software in block 265 prompts the user (20) via the identification and classification rules window (703) to identify keywords such as company names, brands, trademarks and competitors for pre-specified fields in the metadata mapping table (141). The user (20) also has the option of mapping keywords to other fields in the metadata mapping table (141). After specifying the keywords, the user (20) is prompted to select and classify descriptive terms for each keyword. The input from the user (20) is stored in the keyword table (150) in the application database before processing advances to a software block 267.
The software in block 267 checks the bot date table (149) and deactivates any internet text and linkage bots with creation dates before the current system date and retrieves information from the system settings table (140), the metadata mapping table (141) and the keyword table (150). The software in block 267 then initializes internet text and linkage bots for each field in the metadata mapping table (141) that mapped to a keyword in accordance with the frequency specified by user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of text and linkage bots, their tasks are to locate, count and classify keyword matches and linkages from a specified source and then store their findings in a specified location. Each text and linkage bot initialized by software block 267 will store the location, count and classification data it discovers in the classified text table (151). Multimedia data can be processed using bots with essentially the same specifications if software to translate and parse the multimedia content is included in each bot. Every internet text and linkage bot contains the information shown in Table 18.
After being initialized, the text and linkage bots locate and classify data from the internet (40) in accordance with their programmed instructions with the frequency specified by user (20) in the system settings table (140). As each text bot locates and classifies data from the internet (40) processing advances to a software block 268 before the bot completes data storage. The software in block 268 checks to see if all linkages are identified and all keyword hits are associated with descriptive terms that have been classified. If the software in block 268 doesn't find any unclassified “hits” or “links”, then the address, counts and classified text are stored in the classified text table (151). Alternatively, if there are terms that haven't been classified or links that haven't been identified, then processing advances to a block 269. The software in block 269 prompts the user (20) via the identification and classification rules window (703) to provide classification rules for each new term. The information regarding the new classification rules is stored in the keyword table (150) while the newly classified text and linkages are stored in the classified text table (151). It is worth noting at this point that the activation and operation of bots where all fields map to the application database (50) continues. Only bots with unclassified fields will “wait” for user input before completing data storage. The new classification rules will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to a software block 270.
The software in block 270 checks the bot date table (149) and deactivates any external database bots with creation dates before the current system date and retrieves information from the system settings table (140), the metadata mapping table (141) and the keyword table (150). The software in block 270 then initializes external database bots for each field in the metadata mapping table (141) that mapped to a keyword in accordance with the frequency specified by user (20) in the system settings table (140). Every bot initialized by software block 270 will store the location, count and classification of data it discovers in the classified text table (151). Every external database bot contains the information shown in Table 19.
After being initialized the bots locate data from the external database (25) in accordance with its programmed instructions with the frequency specified by user (20) in the system settings table (140). As each bot locates and classifies data from the external database (25) processing advances to a software block 268 before the bot completes data storage. The software in block 268 checks to see if all keyword hits are associated with descriptive terms that have been classified. If the software in block 268 doesn't find any unclassified “hits”, then the address, count and classified text are stored in the classified text table (151) or the external database table (146) as appropriate. Alternatively, if there are terms that haven't been classified, then processing advances to a block 269. The software in block 269 prompts the user (20) via the identification and classification rules window (703) to provide classification rules for each new term. The information regarding the new classification rules is stored in the keyword table (150) while the newly classified text is stored in the classified text table (151). It is worth noting at this point that the activation and operation of bots where all fields map to the application database (50) continues. Only bots with unclassified fields “wait” for user input before completing data storage. The new classification rules will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to software block 276.
The software in block 276 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 291. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 277.
The software in block 277 checks the system settings table (140) to see if there is geocoded data in the application database (50) and to determine which on-line geocoding service (Centrus™ from QM Soft or MapMarker™ from Mapinfo) is being used. If geospatial data are not being used, then processing advances to a block 291. Alternatively, if the software in block 277 determines that geospatial data are being used, processing advances to a software block 278.
The software in block 278 prompts the user (20) via the geospatial measure definitions window (709) to define the measures that will be used in evaluating the elements of value. After specifying the measures, the user (20) is prompted to select the geospatial locus for each measure from the data already stored in the application database (50). The input from the user (20) is stored in the geospatial measures table (152) in the application database before processing advances to a software block 279.
The software in block 279 checks the bot date table (149) and deactivates any geospatial bots with creation dates before the current system date and retrieves information from the system settings table (140), the metadata mapping table (141) and the geospatial measures table (152). The software in block 279 then initializes geospatial bots for each field in the metadata mapping table (141) that mapped to geospatial data in the application database (50) in accordance with the frequency specified by user (20) in the system settings table (140) before advancing processing to a software block 280.
Bots are independent components of the application that have specific tasks to perform. In the case of geospatial bots, their tasks are to calculate user specified measures using a specified geocoding service and then store the measures in a specified location. Each geospatial bot initialized by software block 279 will store the measures it calculates in the application database table where the geospatial data was found. Tables that could include geospatial data include: the basic financial system table (143), the operation system table (144), the human resource system table (145), the external database table (146), the advanced finance system table (147) and the soft asset system table (148). Every geospatial bot contains the information shown in Table 20.
In block 280 the geospatial bots locate data and complete measurements in accordance with their programmed instructions with the frequency specified by the user (20) in the system settings table (140). As each geospatial bot retrieves data and calculates the geospatial measures that have been specified, processing advances to a block 281 before the bot completes data storage. The software in block 281 checks to see if all geospatial data located by the bot has been measured. If the software in block 281 doesn't find any unmeasured data, then the measurement is stored in the application database (50). Alternatively, if there are data elements that haven't been measured, then processing advances to a block 282. The software in block 282 prompts the user (20) via the geospatial measure definition window (709) to provide measurement rules for each new term. The information regarding the new measurement rules is stored in the geospatial measures table (152) while the newly calculated measurement is stored in the appropriate table in the application database (50). It is worth noting at this point that the activation and operation of bots that don't have unmeasured fields continues. Only the bots with unmeasured fields “wait” for user input before completing data storage. The new measurement rules will be used the next time bots are initialized in accordance with the frequency established by the user (20). In either event, system processing then passes on to a software block 291.
The software in block 291 checks: the basic financial system table (143), the operation system table (144), the human resource system table (145), the external database table (146), the advanced finance system table (147), the soft asset system table (148), the classified text table (151) and the geospatial measures table (152) to see if data are missing from any of the periods required for system calculation. The range of required dates was previously calculated by the software in block 202. If there are no data missing from any period, then processing advances to a software block 293. Alternatively, if there are missing data for any field for any period, then processing advances to a block 292.
The software in block 292, prompts the user (20) via the missing data window (704) to specify the method to be used for filling the blanks for each item that is missing data. Options the user (20) can choose from for filling the blanks include: the average value for the item over the entire time period, the average value for the item over a specified period, zero, the average of the preceding item and the following item values and direct user input for each missing item. If the user (20) doesn't provide input within a specified interval, then the default missing data procedure specified in the system settings table (140) is used. When all the blanks have been filled and stored for all of the missing data, system processing advances to a block 293.
The software in block 293 calculates attributes by item for each numeric data field in the basic financial system table (143), the operation system table (144), the human resource system table (145), the external database table (146), the advanced finance system table (147) and the soft asset system table (148). The attributes calculated in this step include: cumulative total value, the period-to-period rate of change in value, the rolling average value and a series of time lagged values. In a similar fashion the software in block 293 calculates attributes for each date field in the specified tables including time since last occurrence, cumulative time since first occurrence, average frequency of occurrence and the rolling average frequency of occurrence. The numbers derived from numeric and date fields are collectively referred to as “item performance indicators”. The software in block 293 also calculates pre-specified combinations of variables called composite variables for measuring the strength of the different elements of value. The item performance indicators are stored in the table where the item source data was obtained and the composite variables are stored in the composite variables table (153) before processing advances to a block 294.
The software in block 294 uses attribute derivation algorithms such as the AQ program to create combinations of the variables that weren't pre-specified for combination. While the AQ program is used in the preferred embodiment of the present invention, other attribute derivation algorithms, such as the LINUS algorithms, may be used to the same effect. The software creates these attributes using both item variables that were specified as “element” variables and item variables that were not. The resulting composite variables are stored in the composite variables table (153) before processing advances to a block 295.
The software in block 295 derives market value factors by enterprise for each numeric data field with data in the sentiment factors table (169). Market value factors include: the ratio of enterprise earnings to expected earnings, commodity prices not captured in process valuations, inflation rate, growth in g.d.p., volatility, volatility vs. industry average volatility, interest rates, increases in interest rates, insider trading direction and levels, consumer confidence and the unemployment rate that have an impact on the market price of the equity for an enterprise and/or an industry. The market value factors derived in this step include: cumulative totals, the period to period rate of change, the rolling average value and a series of time lagged values. In a similar fashion the software in block 295 calculates market value factors for each date field in the specified table including time since last occurrence, cumulative time since first occurrence, average frequency of occurrence and the rolling average frequency of occurrence. The numbers derived from numeric and date fields are collectively referred to as “market performance indicators”. The software in block 295 also calculates pre-specified combinations of variables called composite factors for measuring the strength of the different market value factors. The market performance indicators and the composite factors are stored in the sentiment factors table (169) before processing advances to a block 296.
The software in block 296 uses attribute derivation algorithms, such as the Linus algorithm, to create combinations of the factors that were not pre-specified for combination. While the Linus algorithm is used in the preferred embodiment of the present invention, other attribute derivation algorithms, such as the AQ program, may be used to the same effect. The software creates these attributes using both market value factors that were included in “composite factors” and market value factors that were not. The resulting composite variables are stored in the sentiment factors table (169) before processing advances to a block 297.
The software in block 297 uses pattern-matching algorithms to assign pre-designated data fields for different elements of value to pre-defined groups with numerical values. This type of analysis is useful in classifying purchasing patterns and/or communications patterns as “heavy”, “light”, “moderate” or “sporadic”. The classification and the numeric value associated with the classification are stored in the application database (50) table where the data field is located before processing advances to a block 298.
The software in block 298 retrieves data from the metadata mapping table (141), creates and then stores the definitions for the pre-defined components of value in the components of value definition table (155). As discussed previously, the revenue component of value is not divided into sub-components, the expense value is divided into five sub-components: the cost of raw materials, the cost of manufacture or delivery of service, the cost of selling, the cost of support and the cost of administration and the capital value is divided into six sub-components: cash, non-cash financial assets, production equipment, other assets, financial liabilities and equity in the preferred embodiment. Different subdivisions of the components of value can be used to the same effect. When data storage is complete, processing advances to a software block 302 to begin the analysis of the extracted data using analysis bots.
Analysis BotsThe flow diagrams in
- 1. Identify the item variables, item performance indicators and composite variables for each enterprise, element of value and sub-element of value that drive the components of value (revenue, expense and changes in capital),
- 2. Create vectors that use item variables, item performance indicators and composite variables to summarize the performance of each enterprise, element of value and sub-element of value,
- 3. Determine the causal factors for industry value, determine the appropriate interest rate, value and allocate the industry real options to each enterprise on the basis of relative element strength;
- 4. Determine the appropriate interest rate on the basis of relative causal element strength and value the enterprise real options;
- 5. Determine the expected life of each element of value and sub-element of value;
- 6. Calculate the enterprise current operation value and value the revenue, expense and capital components using the information prepared in the previous stage of processing;
- 7. Specify and optimize predictive causal models to determine the relationship between the vectors determined in step 2 and the revenue, expense and capital values determined in step 6,
- 8. Combine the results of the fifth, sixth and seventh stages of processing to determine the value of each, enterprise contribution, element and sub-element (as shown in Table 5);
- 9. Calculate the market sentiment by subtracting the current operation value, the total value of real options and the allocated industry options from market value for the enterprise (if it has a public stock market price); and
- 10. Analyze the sources of market sentiment.
Each analysis bot generally normalizes the data being analyzed before processing begins.
Processing in this portion of the application begins in software block 302. The software in block 302 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change then processing advances to a software block 314. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 303.
The software in block 303 retrieves data from the meta data mapping table (141) and the soft asset system table (148) and then assigns item variables, item performance indicators and composite variables to each element of value using a two-step process. First, item variables and item performance indicators are assigned to elements of value based on the soft asset management system they correspond to (for example, all item variables from a brand management system and all item performance indicators derived from brand management system variables are assigned to the brand element of value). Second, pre-defined composite variables are assigned to the element of value they were assigned to measure in the metadata mapping table (141). After the assignment of variables and indicators to elements is complete, the resulting assignments are saved to the element of value definition table (155) and processing advances to a block 304.
The software in block 304 checks the bot date table (149) and deactivates any temporal clustering bots with creation dates before the current system date. The software in block 304 then initializes bots as required for each component of value. The bots: activate in accordance with the frequency specified by the user (20) in the system settings table (140), retrieve the information from the system settings table (140), the metadata mapping table (141) and the component of value definition table (156) as required and define segments for the component of value data before saving the resulting cluster information in the application database (50).
Bots are independent components of the application that have specific tasks to perform. In the case of temporal clustering bots, their primary task is to segment the component and sub-component of value variables into distinct time regimes that share similar characteristics. The temporal clustering bot assigns a unique identification (id) number to each “regime” it identifies and stores the unique id numbers in the cluster id table (157). Every time period with data are assigned to one of the regimes. The cluster id for each regime is saved in the data record for each item variable in the table where it resides. The item variables are segmented into a number of regimes less than or equal to the maximum specified by the user (20) in the system settings. The data are segmented using a competitive regression algorithm that identifies an overall, global model before splitting the data and creating new models for the data in each partition. If the error from the two models is greater than the error from the global model, then there is only one regime in the data. Alternatively, if the two models produce lower error than the global model, then a third model is created. If the error from three models is lower than from two models then a fourth model is added. The process continues until adding a new model does not improve accuracy. Other temporal clustering algorithms may be used to the same effect. Every temporal clustering bot contains the information shown in Table 21.
When bots in block 304 have identified and stored regime assignments for all time periods with data, processing advances to a software block 305.
The software in block 305 checks the bot date table (149) and deactivates any variable clustering bots with creation dates before the current system date. The software in block 305 then initializes bots as required for each element of value. The bots: activate in accordance with the frequency specified by the user (20) in the system settings table (140), retrieve the information from the system settings table (140), the metadata mapping table (141) and the element of value definition table (155) as required and define segments for the element of value data before saving the resulting cluster information in the application database (50).
Bots are independent components of the application that have specific tasks to perform. In the case of variable clustering bots, their primary task is to segment the element of value variables into distinct clusters that share similar characteristics. The clustering bot assigns a unique id number to each “cluster” it identifies and stores the unique id numbers in the cluster id table (157). Every item variable for every element of value is assigned to one of the unique clusters. The cluster id for each variable is saved in the data record for each item variable in the table where it resides. The item variables are segmented into a number of clusters less than or equal to the maximum specified by the user (20) in the system settings table (140). The data are segmented using the “default” clustering algorithm the user (20) specified in the system settings. The system of the present invention provides the user (20) with the choice of several clustering algorithms including: an unsupervised “Kohonen” neural network, neural network, decision tree, support vector method, K-nearest neighbor, expectation maximization (EM) and the segmental K-means algorithm. For algorithms that normally require the number of clusters to be specified, the bot will iterate the number of clusters until it finds the cleanest segmentation for the data. Every variable clustering bot contains the information shown in Table 22.
When bots in block 305 have identified and stored cluster assignments for the item variables associated with each component and subcomponent of value, processing advances to a software block 306.
The software in block 306 checks the bot date table (149) and deactivates any predictive model bots with creation dates before the current system date. The software in block 306 then retrieves the information from the system settings table (140), the metadata mapping table (141), the element of value definition table (155) and the component of value definition table (156) required to initialize predictive model bots for each component of value.
Bots are independent components of the application that have specific tasks to perform. In the case of predictive model bots, their primary task is to determine the relationship between the item variables, item performance indicators and composite variables (collectively hereinafter, “the variables”) and the components of value (and sub-components of value). Predictive model bots are initialized for each component and sub-component of value. They are also initialized for each cluster and regime of data in accordance with the cluster and regime assignments specified by the bots in blocks 304 and 305. A series of predictive model bots is initialized at this stage because it is impossible to know in advance which predictive model type will produce the “best” predictive model for the data from each commercial enterprise. The series for each model includes 12 predictive model bot types: neural network; CART; GARCH, projection pursuit regression; generalized additive model (GAM), redundant regression network; rough-set analysis, boosted Naïve Bayes Regression; MARS; linear regression; support vector method and stepwise regression. Additional predictive model types can be used to the same effect. The software in block 306 generates this series of predictive model bots for the levels of the enterprise shown in Table 23.
Every predictive model bot contains the information shown in Table 24.
After predictive model bots are initialized, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, the bots retrieve the required data from the appropriate table in the application database (50) and randomly partition the item variables, item performance indicators and composite variables into a training set and a test set. The software in block 306 uses “bootstrapping” where the different training data sets are created by re-sampling with replacement from the original training set so data records may occur more than once. The same sets of data will be used to train and then test each predictive model bot. When the predictive model bots complete their training and testing, processing advances to a block 307.
The software in block 307 determines if clustering improved the accuracy of the predictive models generated by the bots in software block 306. The software in block 307 uses a variable selection algorithm such as stepwise regression (other types of variable selection algorithms can be used) to combine the results from the predictive model bot analyses for each type of analysis—with and without clustering—to determine the best set of variables for each type of analysis. The type of analysis having the smallest amount of error as measured by applying the mean squared error algorithm to the test data is given preference in determining the best set of variables for use in later analysis. There are four possible outcomes from this analysis as shown in Table 25.
If the software in block 307 determines that clustering improves the accuracy of the predictive models, then processing advances to a software block 310. Alternatively, if clustering doesn't improve the overall accuracy of the predictive models, then processing advances to a software block 308.
The software in block 308 uses a variable selection algorithm such as stepwise regression (other types of variable selection algorithms can be used) to combine the results from the predictive model bot analyses for each model to determine the best set of variables for each model. The models having the smallest amount of error as measured by applying the mean squared error algorithm to the test data is given preference in determining the best set of variables. As a result of this processing, the best set of variables contain: the item variables, item performance indicators and composite variables that correlate most strongly with changes in the components of value. The best set of variables will hereinafter be referred to as the “value drivers”. Eliminating low correlation factors from the initial configuration of the vector creation algorithms increases the efficiency of the next stage of system processing. Other error algorithms alone or in combination may be substituted for the mean squared error algorithm. After the best set of variables have been selected and stored in the element variables table (158) for all models at all levels, the software in block 308 tests the independence of the value drivers at the enterprise, element and sub-element level before processing advances to a block 309.
The software in block 309 checks the bot date table (149) and deactivates any causal model bots with creation dates before the current system date. The software in block 309 then retrieves the information from the system settings table (140), the metadata mapping table (141), the component of value definition table (156) and the element variables table (158) as required to initialize causal model bots for each enterprise, element of value and sub-element of value in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of causal model bots, their primary task is to refine the item variable, item performance indicator and composite variable selection to reflect only causal variables. (Note: these variables are grouped together to represent an element vector when they are dependent). A series of causal model bots are initialized at this stage because it is impossible to know in advance which causal model will produce the “best” vector for the best fit variables from each model. The series for each model includes five causal model bot types: Tetrad, MML, LaGrange, Bayesian and path analysis. The software in block 309 generates this series of causal model bots for each set of variables stored in the element variables table (158) in the previous stage in processing. Every causal model bot activated in this block contains the information shown in Table 26.
After the causal model bots are initialized by the software in block 309, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the element variable information for each model from the element variables table (158) and sub-divides the variables into two sets, one for training and one for testing. The same set of training data is used by each of the different types of bots for each model. After the causal model bots complete their processing for each model, the software in block 309 uses a model selection algorithm to identify the model that best fits the data for each enterprise, element or sub-element being analyzed. For the system of the present invention, a cross validation algorithm is used for model selection. The software in block 309 saves the best fit causal factors in the vector table (159) in the application database (50) and processing advances to a block 312. The software in block 312 tests the value drivers or vectors to see if there are “missing” value drivers that are influencing the results. If the software in block 312 does not detect any missing value drivers, then system processing advances to a block 323. Alternatively, if missing value drivers are detected by the software in block 312, then processing advances to a software block 321.
If software in block 307 determines that clustering improves predictive model accuracy, then processing advances to block 310 as described previously. The software in block 310 uses a variable selection algorithm such as stepwise regression (other types of variable selection algorithms can be used) to combine the results from the predictive model bot analyses for each model and cluster to determine the best set of variables for each model. The models having the smallest amount of error as measured by applying the mean squared error algorithm to the test data is given preference in determining the best set of variables. As a result of this processing, the best set of variables contain: the item variables, item performance indicators and composite variables that correlate most strongly with changes in the components of value. The best set of variables will hereinafter be referred to as the “value drivers”. Eliminating low correlation factors from the initial configuration of the vector creation algorithms increases the efficiency of the next stage of system processing. Other error algorithms alone or in combination may be substituted for the mean squared error algorithm. After the best set of variables have been selected and stored in the element variables table (158) for all models at all levels, the software in block 310 tests the independence of the value drivers at the enterprise, element and sub-element level before processing advances to a block 311.
The software in block 311 checks the bot date table (149) and deactivates any causal model bots with creation dates before the current system date. The software in block 311 then retrieves the information from the system settings table (140), the metadata mapping table (141), the component of value definition table (156) and the element variables table (158) as required to initialize causal model bots for each enterprise, element of value and sub-element of value at every level in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of causal model bots, their primary task is to refine the item variable, item performance indicator and composite variable selection to reflect only causal variables. (Note: these variables are grouped together to represent a single element vector when they are dependent). In some cases it may be possible to skip the correlation step before selecting causal the item variable, item performance indicator and composite variables. A series of causal model bots are initialized at this stage because it is impossible to know in advance which causal model will produce the “best” vector for the best fit variables from each model. The series for each model includes four causal model bot types: Tetrad, LaGrange, Bayesian and path analysis. The software in block 311 generates this series of causal model bots for each set of variables stored in the element variables table (158) in the previous stage in processing. Every causal model bot activated in this block contains the information shown in Table 27.
After the causal model bots are initialized by the software in block 311, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the element variable information for each model from the element variable table (158) and sub-divides the variables into two sets, one for training and one for testing. The same set of training data is used by each of the different types of bots for each model. After the causal model bots complete their processing for each model, the software in block 311 uses a model selection algorithm to identify the model that best fits the data for each enterprise, element or sub-element being analyzed. For the system of the present invention, a cross validation algorithm is used for model selection. The software in block 311 saves the best fit causal factors in the vector table (159) in the application database (50) and processing advances to block 312. The software in block 312 tests the value drivers or vectors to see if there are “missing” value drivers that are influencing the results. If the software in block 312 doesn't detect any missing value drivers, then system processing advances to a block 323. Alternatively, if missing value drivers are detected by the software in block 312, then processing advances to a software block 321.
The software in block 321 prompts the user (20) via the variable identification window (710) to adjust the specification(s) for the affected enterprise, element of value or subelement of value. After the input from the user (20) is saved in the system settings table (140) and/or the element of value definition table (155), system processing advances to a software block 323. The software in block 323 checks the in the system settings table (140) and/or the element of value definition table (155) to see if there any changes in structure. If there have been changes in the structure, then processing advances to a block 205 and the system processing described previously is repeated. Alternatively, if there are no changes in structure, then processing advances to a block 325.
The software in block 325 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new one. If the calculation is new, then processing advances to a software block 326. Alternatively, if the calculation is not a new calculation, then processing advances to a software block 333.
The software in block 326 checks the bot date table (149) and deactivates any vector generation bots with creation dates before the current system date. The software in block 326 then initializes bots for each element and sub-element of value for the enterprise. The bots activate in accordance with the frequency specified by the user (20) in the system settings table (140), retrieve the information from the system settings table (140), the metadata mapping table (141), the component of value definition table (156) and the element variables table (158) as required to initialize vector generation bots for each enterprise, element of value and sub-element of value in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of vector generation bots, their primary task is to produce formulas, (hereinafter, vectors) that summarize the relationship between the item variables, item performance indicators and composite variables for the element or sub-element and changes in the component or sub-component of value being examined. (Note: these variables are simply grouped together to represent an element vector when they are dependent). A series of vector generation bots are initialized at this stage because it is impossible to know in advance which vector generation algorithm will produce the “best” vector for the best fit variables from each model. The series for each model includes four vector generation bot types: data fusion, polynomial, induction and LaGrange. Other vector generation algorithms can be used to the same effect. The software in block 326 generates this series of vector generation bots for each set of variables stored in the element variables table (158). Every vector generation bot contains the information shown in Table 28.
When bots in block 326 have identified and stored vectors for all time periods with data, processing advances to a software block 327.
The software in block 327 checks the bot date table (149) and deactivates any temporal clustering bots with creation dates before the current system date. The software in block 327 then initializes bots for market value factors for each enterprise with a market price and for the industry. The bots activate in accordance with the frequency specified by the user (20) in the system settings table (140), retrieve the information from the system settings table (140), the metadata mapping table (141) and the sentiment factors table (169) as required and define regimes for the market value factor data before saving the resulting regime information in the application database (50).
Bots are independent components of the application that have specific tasks to perform. In the case of temporal clustering bots for market value factors, their primary tasks are to identify the best market value indicator (price, relative price, yield or first derivative of price change) to use for market factor analysis and then to segment the market value factors into distinct time regimes that share similar characteristics. The temporal clustering bots select the best value indicator by grouping the universe of stocks using each of the four value indicators and then comparing the clusters to the known groupings of the S&P 500. The temporal clustering bots then use the identified value indicator in the analysis of temporal clustering. The bots assign a unique id number to each “regime” it identifies and stores the unique id numbers in the cluster id table (157). Every time period with data is assigned to one of the regimes. The cluster id for each regime is also saved in the data record for each market value factor in the table where it resides. The market value factors are segmented into a number of regimes less than or equal to the maximum specified by the user (20) in the system settings table (140). The factors are segmented using a competitive regression algorithm that identifies an overall, global model before splitting the data and creating new models for the data in each partition. If the error from the two models is greater than the error from the global model, then there is only one regime in the data. Alternatively, if the two models produce lower error than the global model, then a third model is created. If the error from three models is lower than from two models then a fourth model is added. The process continues until adding a new model does not improve accuracy. Other temporal clustering algorithms may be used to the same effect. Every temporal clustering bot contains the information shown in Table 29.
When bots in block 327 have identified and stored regime assignments for all time periods with data, processing advances to a software block 328.
The software in block 328 checks the bot date table (149) and deactivates any causal factor bots with creation dates before the current system date. The software in block 328 then retrieves the information from the system settings table (140), the metadata mapping table (141), the element of value definition table (155) and the sentiment factors table (169) as required to initialize causal market value factor bots for the enterprise and for the industry in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of causal factor bots, their primary task is to identify the item variables, item performance indicators, composite variables and market value factors that are causal factors for stock price movement. (Note: these variables are grouped together when they are dependent). For each enterprise and industry the causal factors are those that drive changes in the value indicator identified by the temporal clustering bots. A series of causal factor bots are initialized at this stage because it is impossible to know in advance which causal factors will produce the “best” model for each enterprise and industry. The series for each model includes five causal model bot types: Tetrad, LaGrange, MML, Bayesian and path analysis. Other causal models can be used to the same effect. The software in block 328 generates this series of causal model bots for each set of variables stored in the element variables table (158) in the previous stage in processing. Every causal factor bot activated in this block contains the information shown in Table 30.
After the causal factor bots are initialized by the software in block 328, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the required information from the element of value definition table (155) and the sentiment factors table (169) and sub-divide the data into two sets, one for training and one for testing. The same set of training data is used by each of the different types of bots for each model. After the causal factor bots complete their processing for the enterprise and/or industry, the software in block 328 uses a model selection algorithm to identify the model that best fits the data for each enterprise or industry. For the system of the present invention, a cross validation algorithm is used for model selection. The software in block 328 saves the best fit causal factors in the sentiment factors table (169) in the application database (50) and processing advances to a block 329. The software in block 329 tests to see if there are “missing” causal market value factors that are influencing the results. If the software in block 329 does not detect any missing market value factors, then system processing advances to a block 330. Alternatively, if missing market value factors are detected by the software in block 329, then processing returns to software block 321 and the processing described in the preceding section is repeated.
The software in block 330 checks the bot date table (149) and deactivates any industry rank bots with creation dates before the current system date. The software in block 330 then retrieves the information from the system settings table (140), the metadata mapping table (141), the vector table (159) and the sentiment factors table (169) as required to initialize industry rank bots for the enterprise if it has a public stock market price and for the industry in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of industry rank bots, their primary task is to determine the relative position of the enterprise being evaluated on the causal attributes identified in the previous processing step. (Note: these variables are grouped together when they are dependent). The industry rank bots use Data Envelopement Analysis (hereinafter, DEA) to determine the relative industry ranking of the enterprise being examined. The software in block 330 generates industry rank bots for the enterprise being evaluated. Every industry rank bot activated in this block contains the information shown in Table 31.
After the industry rank bots are initialized by the software in block 330, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the item variables, item performance indicators, composite variables and market value factors for the enterprise from the application database (50) and sub-divides the factors into two sets, one for training and one for testing. After the industry rank bots complete their processing for the enterprise the software in block 330 saves the industry ranks in the vector table (159) in the application database (50) and processing advances to a block 331.
The software in block 331 checks the bot date table (149) and deactivates any option bots with creation dates before the current system date. The software in block 331 then retrieves the information from the system settings table (140), the metadata mapping table (141), the basic financial system database (143), the external database table (146) and the advanced finance system table (147) as required to initialize option bots for the industry and the enterprise.
Bots are independent components of the application that have specific tasks to perform. In the case of option bots, their primary tasks are to calculate the discount rate to be used for valuing the real options and to value the real options for the industry and the enterprise. The discount rate for enterprise real options is calculated by adding risk factors for each causal soft asset to a base discount rate. The risk factor for each causal soft asset is determined by a two step process. The first step in the process divides the maximum real option discount rate (specified by the user in system settings) by the number of causal soft assets. The second step in the process determines if the enterprise is highly rated on the causal soft assets and determines an appropriate risk factor. If the enterprise is highly ranked on the soft asset, then the discount rate is increased by a relatively small amount for that causal soft asset. Alternatively, if the enterprise has a low ranking on a causal soft asset, then the discount rate is increased by a relatively large amount for that causal soft asset as shown below in Table 32.
The discount rate for industry options is calculated using a weighted average total cost of capital approach in a manner that is well known. The base discount rate for enterprise options is calculated using a total average cost of capital (TACO) approach shown below.
TACC=cost of debt X(debt value/total value)+cost of equity X(equity value/total value)+cost of insurance X(insurance value/total value)
After the appropriate discount rates are determined, the value of each real option is calculated using Black Scholes algorithms in a manner that is well known. The real option can be valued using other algorithms including binomial, neural network or dynamic programming algorithms. The software in block 331 values option bots for the industry and the enterprise. Industry option bots utilize the industry cost of capital for all calculations.
Option bots contain the information shown in Table 33.
After the option bots are initialized, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information for the industry and the enterprise from the basic financial system database (143), the external database table (146) and the advanced finance system table (147) as required to complete the option valuation. After the discount has been determined the value of the real option is calculated using Black Schole's algorithms in a manner that is well known. The resulting values are then saved in the real option value table (162) in the application database (50) before processing advances to a block 332.
The software in block 332 uses the results of the DEA analysis in the prior processing block and the percentage of industry real options controlled by the enterprise to determine the allocation percentage for industry options. The more dominant the enterprise, as indicated by the industry rank for the intangible element indicators, the greater the allocation of industry real options. When the allocation of options has been determined and the resulting values stored in the real option value table (162) in the application database (50), processing advances to a block 333.
The software in block 333 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation, a value analysis or a structure change, then processing advances to a software block 341. Alternatively, if the calculation is new a value analysis or a structure change, then processing advances to a software block 343.
The software in block 341 checks the bot date table (149) and deactivates any cash flow bots with creation dates before the current system date. The software in the block then retrieves the information from the system settings table (140), the metadata mapping table (141) and the component of value definition table (156) as required to initialize cash flow bots for the enterprise in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of cash flow bots, their primary tasks are to calculate the cash flow for the enterprise for every time period where data are available and to forecast a steady state cash flow for the enterprise. Cash flow is calculated using a well known formula where cash flow equals period revenue minus period expense plus the period change in capital plus non-cash depreciation/amortization for the period. The steady state cash flow is calculated for the enterprise using forecasting methods identical to those disclosed previously in U.S. Pat. No. 5,615,109 to forecast revenue, expenses, capital changes and depreciation separately before calculating the cash flow. The software in block 334 initializes cash flow bots for the enterprise.
Every cash flow bot contains the information shown in Table 34.
After the cash flow bots are initialized, the bots activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated the bots retrieve the component of value information for the enterprise from the component of value definition table (156). The cash flow bots then complete the calculation and forecast of cash flow for the enterprise before saving the resulting values by period in the cash flow table (161) in the application database (50) before processing advances to a block 342.
The software in block 342 checks the bot date table (149) and deactivates any element life bots with creation dates before the current system date. The software in block 341 then retrieves the information from the system settings table (140), the metadata mapping table (141) and the element of value definition table (155) as required to initialize element life bots for each element and sub-element of value in the enterprise being examined.
Bots are independent components of the application that have specific tasks to perform. In the case of element life bots, their primary task is to determine the expected life of each element and sub-element of value. There are three methods for evaluating the expected life of the elements and sub-elements of value. Elements of value that are defined by a population of members or items (such as: channel partners, customers, employees and vendors) will have their lives estimated by analyzing and forecasting the lives of the members of the population. The forecasting of member lives will be determined by the “best” fit solution from competing life estimation methods including the Iowa type survivor curves, Weibull distribution survivor curves, Gompertz-Makeham survivor curves, polynomial equations and the forecasting methodology disclosed in U.S. Pat. No. 5,615,109. Elements of value (such as some parts of Intellectual Property i.e. patents) that have legally defined lives will have their lives calculated using the time period between the current date and the expiration date of the element or sub-element. Finally, elements of value and sub-element of value (such as brand names, information technology and processes) that may not have defined lives and that may not consist of a collection of members will have their lives estimated by comparing the relative strength and stability of the element vectors with the relative stability of the enterprise Competitive Advantage Period (CAP) estimate. The resulting values are stored in the element of value definition table (155) for each element and sub-element of value.
Every element life bot contains the information shown in Table 35.
After the element life bots are initialized, they are activated in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information for each element and sub-element of value from the element of value definition table (155) as required to complete the estimate of element life. The resulting values are then saved in the element of value definition table (155) in the application database (50) before processing advances to a block 343.
The software in block 343 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation, a value analysis or a structure change. If the calculation is not a new calculation or a structure change, then processing advances to a software block 402. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 345.
The software in block 345 checks the bot date table (149) and deactivates any component capitalization bots with creation dates before the current system date. The software in block 341 then retrieves the information from the system settings table (140), the metadata mapping table (141) and the component of value definition table (156) as required to initialize component capitalization bots for the enterprise.
Bots are independent components of the application that have specific tasks to perform. In the case of component capitalization bots, their task is to determine the capitalized value of the components and subcomponents of value, forecast revenue, expense or capital requirements for the enterprise in accordance with the formula shown in Table 36.
After the capitalized value of every component and sub-component of value is complete, the results are stored in the component of value definition table (156) in the application database (50).
Every component capitalization bot contains the information shown in Table 37.
After the component capitalization bots are initialized they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information for each component and sub-component of value from the advanced finance system table (147) and the component of value definition table (156) as required to calculate the capitalized value of each component. The resulting values are then saved in the component of value definition table (156) in the application database (50) before processing advances to a block 347.
The software in block 347 checks the bot date table (149) and deactivates any element valuation bots with creation dates before the current system date. The software in block 347 then retrieves the information from the system settings table (140), the metadata mapping table (141), the element of value definition table (155), the component of value definition table (156) as required to initialize valuation bots for each element and sub-element of value.
Bots are independent components of the application that have specific tasks to perform. In the case of element valuation bots, their task is to calculate the contribution of every element of value and sub-element of value in the enterprise using the overall procedure outlined in Table 5. The first step in completing the calculation in accordance with the procedure outlined in Table 5, is determining the relative contribution of element and sub-element of value by using a series of predictive models to find the best fit relationship between:
1. The element of value vectors and the enterprise components of value; and
2. The sub-element of value vectors and the element of value they correspond to.
The system of the present invention uses 12 different types of predictive models to determine relative contribution: neural network; CART; projection pursuit regression; generalized additive model (GAM); GARCH; MMDR; redundant regression network; boosted Naïve Bayes Regression; the support vector method; MARS; linear regression; and stepwise regression to determine relative contribution. The model having the smallest amount of error as measured by applying the mean squared error algorithm to the test data is the best fit model. The “relative contribution algorithm” used for completing the analysis varies with the model that was selected as the “best-fit”. For example, if the “best-fit” model is a neural net model, then the portion of revenue attributable to each input vector is determined by the formula shown in Table 38.
After the relative contribution of each enterprise, element of value and sub-element of value is determined, the results of this analysis are combined with the previously calculated information regarding element life and capitalized component value to complete the valuation of each: enterprise contribution, element of value and sub-element using the approach shown in Table 39.
The resulting values are stored in the element of value definition table (155) for each element and sub-element of value of the enterprise.
Every valuation bot contains the information shown in Table 40.
After the valuation bots are initialized by the software in block 347 they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information from the element of value definition table (155) and the component of value definition table (156) as required to complete the valuation. The resulting values are then saved in the element of value definition table (155) in the application database (50) before processing advances to a block 351.
The software in block 351 checks the bot date table (149) and deactivates any residual bots with creation dates before the current system date. The software in block 351 then retrieves the information from the system settings table (140), the metadata mapping table (141) and the element of value definition table (155) as required to initialize residual bots for the enterprise.
Bots are independent components of the application that have specific tasks to perform. In the case of residual bots, their task is to retrieve data as required from the element of value definition table (155) and the component of value definition table (156) and then calculate the residual going concern value for the enterprise in accordance with the formula shown in Table 41.
Every residual bot contains the information shown in Table 42.
After the residual bots are initialized they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information from the element of value definition table (155) and the component of value definition table (156) as required to complete the residual calculation for the enterprise. After the calculation is complete, the resulting values are then saved in the element of value definition table (155) in the application database (50) before processing advances to a block 352.
The software in block 352 checks the bot date table (149) and deactivates any sentiment calculation bots with creation dates before the current system date. The software in block 352 then retrieves the information from the system settings table (140), the metadata mapping table (141), the external database table (146), the element of value definition table (155), the component of value definition table (156) and the real option value table (162) as required to initialize sentiment calculation bots for the enterprise.
Bots are independent components of the application that have specific tasks to perform. In the case of sentiment calculation bots, their task is to retrieve data as required from: the external database table (146), the element of value definition table (155), the component of value definition table (156) and the real option value table (162) and then calculate the sentiment for the enterprise in accordance with the formula shown in Table 43.
Every sentiment calculation bot contains the information shown in Table 44.
After the sentiment calculation bots are initialized they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information from the external database table (146), the element of value definition table (155), the component of value definition table (156) and the real option value table (162) as required to complete the sentiment calculation for each enterprise. After the calculation is complete, the resulting values are then saved in the enterprise sentiment table (166) in the application database (50) before processing advances to a block 353.
The software in block 353 checks the bot date table (149) and deactivates any sentiment analysis bots with creation dates before the current system date. The software in block 353 then retrieves the information from the system settings table (140), the metadata mapping table (141), the external database table (146), the element of value definition table (155), the component of value definition table (156), the real option value table (162), the enterprise sentiment table (166) and the sentiment factors table (169) as required to initialize sentiment analysis bots for the enterprise.
Bots are independent components of the application that have specific tasks to perform. In the case of sentiment analysis bots, their primary task is to determine the composition of the calculated sentiment by comparing the portion of overall market return that related to the different elements of value and the calculated valuation for each element of value as shown below in Table 45.
Every sentiment analysis bot contains the information shown in Table 46.
After the sentiment analysis bots are initialized, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information from the system settings table (140), the metadata mapping table (141), the enterprise sentiment table (166) and the sentiment factors table (169) as required to analyze sentiment. The resulting breakdown of sentiment is then saved in the enterprise sentiment table (169) in the application database (50) before processing advances to a block 402.
Risk Reduction BotsThe flow diagram in
System processing in this portion of the application software (400) begins in a block 402. The software in block 402 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change, then processing advances to a software block 412. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 403.
The software in block 403 checks the bot date table (149) and deactivates any statistical bots with creation dates before the current system date. The software in block 403 then retrieves the information from the system settings table (140), the external database table (146), the element of value definition table (155), the element variables table (158) and the sentiment factor table (169) as required to initialize statistical bots for each causal value driver and market value factor.
Bots are independent components of the application that have specific tasks to perform. In the case of statistical bots, their primary tasks are to calculate and store statistics such as mean, median, standard deviation, slope, average period change, maximum period change, variance and covariance for each causal value driver and market value factor for every regime. Covariance with the market as a whole is also calculated for each value driver and market value factor. Every statistical bot contains the information shown in Table 47.
When bots in block 403 have identified and stored statistics for each causal value driver and market value factor in the statistics table (170), processing advances to a software block 404.
The software in block 404 checks the bot date table (149) and deactivates any risk reduction activity bots with creation dates before the current system date. The software in block 404 then retrieves the information from the system settings table (140), the external database table (146), the element of value definition table (155), the element variables table (158), the sentiment factor table (169) and the statistics table (170) as required to initialize risk reduction activity bots for each causal value driver and market value factor.
Bots are independent components of the application that have specific tasks to perform. In the case of risk reduction activity bots, their primary tasks are to identify actions that can be taken by the enterprise to reduce risk. For example, if one customer presents a significant risk to the enterprise, then the risk reduction bot might identify a reduction in the credit line for that customer to reduce the risk. Every risk reduction activity bot contains the information shown in Table 48.
When bots in block 404 have identified and stored risk reduction activities in the risk reduction activity table (179), processing advances to a software block 405.
The software in block 405 checks the bot date table (149) and deactivates any extreme value bots with creation dates before the current system date. The software in block 405 then retrieves the information from the system settings table (140), the external database table (146), the element of value definition table (155), the element variables table (158) and the sentiment factor table (169) as required to initialize extreme value bots in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of extreme value bots, their primary task is to identify the extreme values for each causal value driver and market value factor. The extreme value bots use the Blocks method and the peak over threshold method to identify extreme values. Other extreme value algorithms can be used to the same effect. Every extreme value bot activated in this block contains the information shown in Table 49.
After the extreme value bots are initialized, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the required information from the system settings table (140), the external database table (146), the element of value definition table (155), the element variables table (158) and the sentiment factor table (169) and determine the extreme value range for each value driver or market value factor. The bot saves the extreme values for each causal value driver and market value factor in the statistics table (170) in the application database (50) and processing advances to a block 409.
The software in block 409 checks the bot date table (149) and deactivates any scenario bots with creation dates before the current system date. The software in block 409 then retrieves the information from the system settings table (140), the operation system table (144), the external database table (146), the advanced finance system table (147), the element of value definition table (155), the sentiment factors table (169) and the statistics table (170) as required to initialize scenario bots in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of scenario bots, their primary task is to identify likely scenarios for the evolution of the causal value drivers and market value factors. The scenario bots use information from the advanced finance system and external databases to obtain forecasts for individual causal factors before using the covariance information stored in the statistics table (170) to develop forecasts for the other causal value drivers and factors under normal conditions. They also use the extreme value information calculated by the previous bots and stored in the statistics table (170) to calculate extreme scenarios. Every scenario bot activated in this block contains the information shown in Table 50.
After the scenario bots are initialized, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the required information and develop a variety of scenarios as described previously. After the scenario bots complete their calculations they save the resulting scenarios in the scenarios table (171) in the application database (50) and processing advances to a block 410.
The software in block 410 checks the bot date table (149) and deactivates any simulation bots with creation dates before the current system date. The software in block 410 then retrieves the information from the system settings table (140), the operation system table (144), the advanced finance system table (147), the element of value definition table (155), the external database table (156), the sentiment factors table (169), the statistics table (170), the scenarios table (171) and the generic risk table (178) as required to initialize simulation bots in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of simulation bots, their primary task is to run three different types of simulations for the enterprise. The simulation bots run simulations of organizational financial performance and valuation using: the two types of scenarios generated by the scenario bots—normal and extreme, they also run an unconstrained genetic algorithm simulation that evolves to the most negative scenario. In addition to examining the economic factors that were identified in the previous analysis, the bots simulate the impact of generic risks like fire, earthquakes, floods and other weather-related pheonomenal that are un-correlated with the economic scenarios. Every simulation bot activated in this block contains the information shown in Table 51.
After the simulation bots are initialized, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). Once activated, they retrieve the required information and simulate the financial performance and value impact of the different scenarios. After the simulation bots complete their calculations, the resulting forecasts are saved in the simulations table (168) and the summary xml table (177) in the application database (50) and processing advances to a block 411.
The software in block 411 continually runs an analysis to define the optimal risk reduction strategy for each of the identified normal and extreme scenarios. It does this by first retrieving from the system settings table (140), the operation system table (144), the external database table (146), the advanced finance system table (147), the element of value definition table (155), the sentiment factors table (169), the statistics table (170), the scenario table (171), the risk reduction products table (173) and the risk reduction activity table (179) which is the information required to initialize the optimization algorithm. The software in the block determines the optimal mix of risk reduction products (derivative purchase, insurance purchase, etc.) and risk reduction activities (reducing credit limits for certain customers, shifting production from high risk to lower risk countries, etc.) for the company under each scenario given the confidence interval established by the user (20) in the system settings using a linear programming optimization algorithm. A multi criteria optimization determines the best mix for reducing risk under both normal and extreme scenarios. Other optimization algorithms can be used at this point and all optimizations consider the effect of changes in the cost of capital on the optimal solution. In any event, the resulting product and activity mix for each set of scenarios and the combined analysis is saved in the optimal mix table (175) and the xml summary table (177) in the application database (50) and the revised simulations are saved in the simulations table (168) before processing passes to a software block 412. The shadow prices from these optimizations are also stored in the risk reduction products table (173) and the xml summary table (177) for use in identifying new risk reduction products that the company may wish to purchase and/or new risk reduction activities the company may wish to develop.
The software in block 412 checks the system settings table (140) in the application database (50) to determine if the current calculation is a new calculation or a structure change. If the calculation is not a new calculation or a structure change, then processing advances to a software block 502. Alternatively, if the calculation is new or a structure change, then processing advances to a software block 413.
The software in block 413 checks the bot date table (149) and deactivates any impact bots with creation dates before the current system date. The software in block 413 then retrieves the information from the system settings table (140), the operation system table (144), the external database table (146), the advanced finance system table (147), the element of value definition table (155), the simulations table (168), the sentiment factors table (169), the statistics table (170), the scenario table (171) and the optimal mix table (175) as required to initialize value impact bots in accordance with the frequency specified by the user (20) in the system settings table (140).
Bots are independent components of the application that have specific tasks to perform. In the case of impact bots, their primary task is to determine the value impact of each risk reduction product and activity—those included in the optimal mix and those that aren't—on the different scenarios. Every impact bot contains the information shown in Table 52.
After the value impact bots are initialized by the software in block 413, they activate in accordance with the frequency specified by the user (20) in the system settings table (140). After being activated, the bots retrieve information as required to revise the simulations of enterprise performance and determine the risk reduction impact of each product on each simulation. The resulting forecast of value impacts are then saved in the risk reduction products table (173) or the risk reduction activity table (179) as appropriate in the application database (50) before processing advances to a block 414.
The software in block 414 prepares and displays a listing from highest impact to lowest impact for each risk reduction product under the normal scenarios, the extreme scenarios and the combined (multi-criteria) analysis using the prioritized listing display window (706). The optimal mix for the normal and extreme scenarios are determined by calculating the weighted average sum of the different scenarios where the weighting is determined by the relative likelihood of the scenario. The display identifies the optimal mix from the combined analysis as the recommended solution for enterprise risk reduction. At this point, the user (20) is given the option of:
1. Editing (adding or deleting products and activities) from the recommended solution;
2. Selecting the optimal mix from the normal scenario;
3. Selecting and then editing the optimal mix from the normal scenarios;
4. Selecting the optimal mix from the extreme scenario;
5. Selecting and then editing the optimal mix from the extreme scenarios; or
6. Leaving the default choice in place.
After the user (20) has finished the review and the optional edit of the selected mix, any changes are saved in the optimal mix table (175) in the application database (50) and processing advances to a software block 502. It should be noted that the processing of the risk reduction bot segment can, with very minor changes, also be used to analyze the impact of value enhancing changes on the enterprise. This could include a value maximization analysis and/or a multi-criteria maximum value, minimum risk optimization.
OutputThe flow diagram in
The software in block 502 checks the optimal mix table (175) in the application database (50) to determine which risk reduction activities have been included in the optimal mix. If risk reduction activities have been included in the optimal mix, then the software in this block prepares summaries of the changes and transmits them to the affected financial, operational and/or soft asset management system(s). For example, if the option to reduce the credit line for a certain customer has been accepted, then the customer relationship management system and the accounts receivable system will be updated with the new credit limit information by a transmission from the software in this block. Alternatively, if there are no risk reduction activities in the optimal mix, then processing advances directly to a software block 503.
The software in block 503 retrieves information from the system settings table (140) and the advanced finance system table (147) that is required to calculate the minimum amount of cash that will be available for investment in risk reduction during the next 36 month period. The system settings table (140) contains the minimum amount of cash and available securities that the user (20) indicated was required for enterprise operation while the advanced finance system table (147) contains a forecast of the cash balance for the enterprise for each period during the next 36 months. A summary of the available cash and cash deficits by currency, by month, by enterprise for the next 36 months is stored in a summary xml format in the xml summary table (177) during this stage of processing. After the amount of available cash for each enterprise is calculated and stored in the risk reduction purchase table (165), processing advances to a software block 504.
The software in block 504 assembles the previously developed summaries of cash position, foreign exchange requirements, risks, scenarios and statistics into a xml summary profile of the enterprise. This summary profile is transferred via the network (45) to a software block 604 to start the processing in block 600. The software in block 600 reviews the enterprise profile and develops a recommended list of products and/or swaps that the enterprise should purchase to reduce risk. The recommended list of products and/or swaps is then transmitted by a software block 616 via a network (45) to a software block 514.
After the software in block 504 transmits the summary profile, processing advances to a software block 507. The software in block 507 checks the summary profile to see if there are any new losses in the profile. If there are new losses, then the information regarding the losses is transmitted via a network (45) to a software block 618. After the software in block 618 analyzes the
The software in block 514 analyzes the risk reduction products and swaps transmitted by the exchange to determine the percentage reduction in financial performance volatility that their purchase will produce for the enterprise. If the previously completed sentiment analysis indicated that financial performance volatility was a driver of market value, then the software in block 514 will retrieve the required information from the sentiment factors table (169) and estimate the value increase that will be produced by the decreased volatility. The software in block 514 also confirms that the products and/or swaps recommended by the exchange can be purchased using available cash for a total expenditure, counting both prior purchases and planned purchases, that is less than or equal to the maximum investment amount established by the user (20) in system settings table (140). If the planned purchases are within the guidelines established by the user (20), then the software generates a purchase order for the additional risk reduction products and/or swaps. Alternatively, if there isn't available cash or if the planned purchase exceeds the expenditure guideline established by the user (20), then a message indicating the problem(s) is prepared. In any event, the software in block 514 displays the resulting message or purchase order to the user (20) via the purchase review data window (711). The purchase review data window (711) also displays the estimate of value increase, if any, that the implementation of the risk reduction program will provide. The user (20) can optionally edit or confirm the purchase order, increase the amount that can be spent on risk reduction or chose to purchase a mix that is not the optimal mix. After the user (20) completes his or her review and optional edit, the software in block 514 transmits any orders to purchase the risk reduction products that were approved via the network (45) to a software block 617 which accepts the order transmits a confirmation. The software at this point could, of course, initialize one or more bots to search the various web sites and exchanges to get the best price for the company using the system of the present invention. In any event, the details of the purchase transaction and confirmation are then saved in the risk reduction purchase table (165) before processing advances to block 515.
The software in block 515 displays the report selection window (705) to the user (20). The user (20) optionally selects reports for printing. If the user (20) selects any reports for printing, then the information regarding the reports selected is saved in the reports table (164). After the user (20) has finished selecting reports, processing advances to a software block 516.
The software in block 516 checks the reports tables (164) to determine if any reports have been designated for printing. If reports have been designated for printing, then processing advances to a block 525. The software in block 525 sends the designated reports to the printer (118). After the reports have been sent to the printer (118), processing advances to a software block 527. Alternatively, if no reports were designated for printing, then processing advances directly from block 516 to block 527.
The software in block 527 checks the system settings table (140) to determine if the system is operating in a continuous run mode. If the system is operating in a continuous run mode, then processing returns to block 205 and the processing described previously is repeated. Alternatively, if the system is not running in continuous mode, then the processing advances to a block 528 where the system stops.
ExchangeThe flow diagram in
System processing in this portion of the application software (400) begins in a block 602. The software in block 602 checks the exchange bot date table (181) in the exchange database (51) and deactivates any data bots with creation dates before the current system date. The software in block 602 then retrieves the information from the xml profile table (180), the customer table (182), the risk products table (183), the swaps table (184), the customer profiles table (185) the generic risk table (187), the external exchange database table (190) and the contingent capital table (195) as required to initialize exchange data bots.
Bots are independent components of the application that have specific tasks to perform. In the case of exchange data bots, their primary tasks are to:
-
- 1. Store the latest version of the customer profile in the customer profile table (182);
- 2. Update the external exchange database table (190) with information required to analyze asset returns on existing and potential investments;
- 3. Update the exchange generic risk table (187); and
- 4. Update the contingent capital table (195).
Every exchange data bot contains the information shown in Table 53.
When the bots in block 604 have stored the profile for the customer transmitting data to the exchange in the customer profiles table (185), the generic risk information in the generic risk table (187), the contingent capital information in the contingent capital table (195) and the external data required for asset return analysis in the external exchange database table (190) in the exchange database (51), processing advances to a software block 605.
The software in block 605 checks the exchange bot date table (181) and deactivates any transfer bots with creation dates before the current system date for the customer transmitting data to the exchange. The software in block 605 then retrieves the information from the xml profile table (180), the customer table (182), the risk products table (183), the swaps table (184) and the customer profile table (185) as required to initialize transfer bots for the enterprise transmitting a summary profile to the exchange.
Bots are independent components of the application that have specific tasks to perform. In the case of transfer bots, their primary tasks are to identify swaps, existing product and new products that can be made to satisfy the risk transfer needs of the enterprise transmitting data to the exchange. For example, if one enterprise has a significant risk from oil prices dropping (a heating oil company, for example) and another enterprise faces a significant risk when oil prices rise (a trucking company, for example), then the transfer bot will identify the offsetting risk factors and record a swap. If the risk transfer can be completed by both an existing risk transfer product and a swap, then preference is given to the swap. Every transfer bot contains the information shown in Table 54.
After the transfer bot identifies the swaps, existing products and new products that will satisfy the needs of the enterprise for risk transfer the results are saved to the exchange database (51). Information on swaps is saved on the swaps table (184) and the customer profile table (185) and information on new products is saved in the risk products table (183) without a price. The price for new products will be established later in the processing. After data storage is complete, processing advances to a software block 609.
The software in block 609 checks the exchange bot date table (181) and deactivates any liability scenario bots with creation dates before the current system date. The software in block 605 then retrieves the information from the xml profile table (180), the customer table (182), the risk products table (183), the swaps table (184), the customer profile table (185), the exchange payout history table (186), the generic risk table (187) and the exchange premium history table (196) as required to initialize new liability scenario bots.
Bots are independent components of the application that have specific tasks to perform. In the case of liability scenario bots, their primary tasks are to create a series of scenarios estimating the net payout (premiums minus payout=net payout) associated the risks transferred via swaps or insurance from all customers. As with the prior analysis at the enterprise level, there are two types of scenarios developed at this stage of processing, normal scenarios and extreme scenarios. The scenarios are developed by combining the information and statistics from summary profiles transmitted by the customers of the exchange with the exchange payout history, the exchange premium history and generic risk information. Every liability scenario bot activated in this block contains the information shown in Table 55.
After the liability scenario bots are initialized, they retrieve the required information from the xml profile table (180), the customer table (182), the risk products table (183), the swaps table (184), the customer profile table (185), the exchange payout history table (186), the generic risk table (187), the external exchange database table (190) and the exchange premium history (196) before generating a series of net payout scenarios that are appropriate for the type of analysis being completed—extreme or normal. The bot saves the scenarios in the liability scenario table (188) in the exchange database (51) and processing advances to a block 610.
The software in block 610 continually completes analyses similar to those completed by the analysis bots in the enterprise portion of the system of the present invention. The software in this block uses the publicly available information stored in the external exchange database table (190) to complete the analyses shown in Table 56 for each equity investment listed in the asset position table (189) and described in data obtained from the external database (25).
The results of the first three forecasts (items 2, 3 and 4 from Table 56) are saved in the asset forecasts table (191) in the exchange database (51) and the market value factors (item 1 from Table 56) are saved with the appropriate equity in the asset position table (189). The software in this block uses the publicly available information stored in the external exchange database table (190) to complete the analyses shown in Table 56 for each income generating investments (i.e. bonds or real estate) listed in the asset position table (189) and described in data obtained from the external database (25).
The results of the forecast (items 2 from Table 57) are saved in the asset forecasts table (191) in the exchange database (51) and the market value factors (item 1 from Table 57) are saved with the appropriate investment in the asset position table (189). The software in block 610 then analyzes the covariance between the causal factors for each of the assets to determine the covariance between these assets under both normal and extreme conditions. The results of these analyses are then stored in the asset correlation table (192) before processing advances to a block 611.
The software in block 611 checks the exchange bot date table (181) and deactivates any asset scenario bots with creation dates before the current system date. The software in block 610 then retrieves the information from the asset position table (189), the external exchange database table (190) and the asset correlation table (192) as required to initialize the asset scenario bots.
Bots are independent components of the application that have specific tasks to perform. In the case of asset scenario bots, their primary task is to identify likely scenarios for the evolution of the causal market value factors. The asset scenario bots use information from the external databases to obtain forecasts for individual causal factors before using the covariance information stored in the asset correlation table (192) to develop scenarios for the other causal factors under normal and extreme conditions. Every scenario bot activated in this block contains the information shown in Table 58.
After the asset scenario bots are initialized, they retrieve the required information and develop a variety of normal and extreme scenarios as described previously. After the scenario bots complete their calculations they save the resulting scenarios in the asset scenario table (193) in the exchange database (51) and processing advances to a block 612.
The software in block 612 checks the exchange bot date table (181) and deactivates any net capital scenario bots with creation dates before the current system date. The software in block 612 then retrieves the information from the liability scenario table (183), and the asset scenario table (193) as required to initialize net capital scenarios bots.
Bots are independent components of the application that have specific tasks to perform. In the case of net capital scenario bots, their primary task is to run four different types of simulations for the exchange. The net capital scenario bots run simulations of the exchange financial performance using the two types of scenarios generated by the asset and liability scenario bots—normal and extreme. The net capital scenario bots also run an unconstrained genetic algorithm simulation that evolves to the most negative scenario and simulations specified by regulatory agencies. Every net capital scenario bot activated in this block contains the information shown in Table 59.
After the net capital scenario bots are initialized, they retrieve the required information and simulate the financial performance of the exchange under the different scenarios. After the net capital scenarios complete their calculations, the resulting forecasts are saved in the exchange simulations table (194) in the exchange database (51) and processing advances to a block 613.
The software in block 613 checks the exchange bot date table (181) and deactivates any asset optimization bots with creation dates before the current system date. The software in block 613 then retrieves the information from the asset position table (189), the external exchange database table (190), the asset forecasts table (191), the asset correlation table (192), the asset scenario table (193), the exchange simulations table (194) and the as required to initialize asset optimization bots.
Bots are independent components of the application that have specific tasks to perform. In the case of asset optimization bots, their primary task is to determine the optimal mix of assets and risk reduction activities (purchase reinsurance and/or other contingent capital purchases, etc.) for the exchange under each scenario using a linear programming optimization algorithm that is constrained by any limitations imposed by regulatory requirements. A multi criteria optimization is also run at this stage to determine the best mix for maximizing value under both normal and extreme scenarios. A penalty function for asset liability mismatch can be added as required to minimize the difference between asset and liability lives. Other optimization algorithms can be used at this point to achieve the same result. Every asset optimization bot activated in this block contains the information shown in Table 60.
After the asset optimization bots complete their analyses, the resulting asset and contingent capital mix for each set of scenarios and the combined analysis is saved in the optimal exchange mix table (196) in the exchange database (51) and the revised simulations are saved in the exchange simulations table (194) before processing passes to a software block 614.
The software in block 614 prepares and displays the optimal mix of asset purchases, asset sales and contingent capital purchases for the normal, extreme and combined scenario analysis using the optimal mix review display window (712). The optimal mix for the normal and extreme scenarios are determined by calculating the weighted average sum of the different scenarios where the weighting is determined by the relative likelihood of the scenario. The display identifies the optimal mix from the combined analysis as the recommended solution for exchange value maximization. At this point, the exchange operator (21) is given the option of:
1) Editing (adding or deleting products and activities) from the recommended solution;
2) Selecting the optimal mix from the normal scenarios;
3) Selecting and then editing the optimal mix from the normal scenarios;
4) Selecting the optimal mix from the extreme scenarios;
5) Selecting and then editing the optimal mix from the extreme scenarios; or
6) Leaving the default choice in place.
After the exchange operator (21) has finished the review and the optional edit of the selected mix, any changes are saved in the optimal exchange mix table (196) in the exchange database (51). The new optimal mix is compared to the existing asset position stored in the asset position table (189) and orders are generated to purchase assets, sell assets and/or purchase contingent capital as required to bring the current asset position in line with the new optimal mix. These orders are then transmitted via a network (45) to other exchanges on the internet. When the order confirmations are received, the asset position table (189) is updated with the new information and processing advances to a block 615. It is worth noting at this point that the processing described in blocks 611, 612 and 614 could also be used to manage an investment portfolio on a stand alone basis.
The software in block 615 prepares and displays the proposed prices for the risk transfer products and the swaps that are being offered to the customer using the price review display window (715). The list prices from the risk products table (183) are used for the existing risk products. Pricing for swaps are calculated by marking up the cost of the swap by a standard amount. The software in block 615 marks up the calculated breakeven price for any new risk transfer products that were introduced by the bots in block 605. At this point, the exchange operator (21) is given the option of:
-
- 1) Editing the recommended prices for any and all of the risk transfers—swaps, existing products and new products;
- 2) Accepting the recommended prices; or
- 3) Removing some of swaps and/or risk transfer products from the list.
After the exchange operator (21) completes the review, all price changes and the prices for any new risk transfer products are saved in the risk products table (183) before processing advances to a block 616.
The software in block 616 transmits the information regarding the products, swaps and pricing that will be used to transfer the risks identified in the initial xml risk transfer summary from the customer to block 514. The transmission to the enterprise is in a summary xml format that is similar to the one initially transmitted to the exchange by the enterprise.
As described previously, the user (20) can reject, edit and/or accept the proposed mix of products and swaps contained in the xml risk transfer summary via the purchase review window (711). The information regarding the decisions made regarding the accepted risk transfers (swaps or purchases) is communicated via a network (45) by the software in block 514 to a software block 617. The software in block 617 accepts the confirmed orders, updates the information in the risk products table (183), the swaps table (184), the customer profiles table (185) and the exchange premium history table (197) before advancing to a software block 618.
The software in block 618 accepts input from block 507 regarding any new losses that are contained in the profiles being transmitted to the exchange. The software in block 618 verifies the loss is for an insured risk, updates the customer profiles table (185), updates the exchange payout history table (186) and arranges for payment of the claim in a manner that is well known. After the processing of claims is completed, exchange processing returns to block 604 and the process described above is repeated.
Thus, the reader will see that the system and method described above transforms extracted transaction data, corporate information, information from external databases and information from the internet into detailed valuations and risk analyses for specific elements of value within the enterprise and for the enterprise as a whole. The system and method described above goes on to use the detailed valuation and risk analysis information to develop and implement a comprehensive program of risk reduction activities and risk transfers specifically tailored to the enterprise using the system. The level of detail, breadth and speed of the risk analysis allows users of the system to manage their risks in an fashion that is superior to the method currently available to users of existing risk analysis systems and traditional insurance products.
Because the xml profiles used in the system (100) provide a comprehensive picture of the financial status of the companies transferring risk through the exchange, the system and method of the present invention can be used with essentially no modifications to provide an on-line transfer system for:
1. Foreign exchange;
2. Liquidity (aka credit);
3. Any combination of foreign exchange, liquidity and risk.
With relatively minor modifications the system of the present invention could be used to manage transfers of ownership rights alone or in combination with foreign exchange, liquidity and risk.
While the above description contains many specificity's, these should not be construed as limitations on the scope of the invention, but rather as an exemplification of one preferred embodiment thereof. Accordingly, the scope of the invention should be determined not by the embodiment illustrated, but by the appended claims and their legal equivalents.
Claims
1. A computer-implemented method for performing an analysis of financial data, comprising the steps of:
- storing, in a computer readable memory, financial data related to a population of financial data records and segmented into a number of categories, wherein the categories are mutually exclusive and collectively exhaustive of the financial data, and scenario data for a set of scenarios, wherein each of the scenarios is defined at least in part by a set of variables, and wherein the scenario data for each of the scenarios comprise at least some parameter values for the set of variables;
- providing a computer processor associated with the computer readable memory with a model of a system defined at least in part by the set of variables;
- processing, with the computer processor, the financial data and the scenario data using the model to obtain an estimated model outcome distribution comprising a distribution of estimated model outcomes relating to the system and based on the set of scenarios; and
- outputting the estimated model outcome distribution.
2. The computer-implemented method of claim 1, wherein the processing further comprises:
- selecting a first subset of the financial data as a first sample, the first subset drawn without replacement from each of the categories;
- performing, with the model and the first subset, a first test of the set of scenarios to obtain a first set of sample outcomes for each of the scenarios;
- repeating the selecting and performing steps using additional subsets of the financial data to perform additional tests of the set of scenarios and to obtain additional sets of sample outcomes for each of the scenarios;
- wherein the additional subsets are drawn without replacement from each of the categories;
- wherein the first sample outcomes and the additional sample outcomes are combined to create a cumulative estimated model outcome distribution; wherein the selecting and performing steps are repeated until the cumulative model outcome distribution is within a pre-determined acceptable tolerance limit from a distribution of fully assessed model outcomes for the set of scenarios obtainable by performing, with the model, a single test of the set of scenarios using all of the data.
3. The computer-implemented method of claim 1, wherein the system comprises an organization that physically exists.
4. The computer-implemented method of claim 1, wherein the cumulative model outcome distribution is identified as the estimated model outcome distribution.
5. The computer-implemented method of claim 1, further comprising segmenting the financial data into the selected number categories before storing the financial data in the computer readable memory where the categories comprise current operation revenue, current operation expense, current operation capital change, real options and market sentiment.
6. The computer-implemented method of claim 1, wherein the financial data comprises insurance policyholder data; wherein the model comprises a model of one or more insurance liabilities; and wherein the model outcomes comprise measures of a risk comprising a likelihood of an occurrence of the insurance liability for a scenario in the set of scenarios.
7. The computer implemented method of claim 1, wherein the model of the system is developed by learning from the financial data where learning from the financial data comprises:
- using a plurality of predictive models and a plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact of each of one or more elements of value;
- using the plurality of predictive models and the plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact each of one or more external factors;
- learning which algorithm from a plurality of linear and nonlinear predictive model algorithms to include in the model in order to model a net contribution or impact of each of the one or more elements of value and each of the one or more external factors to a model output value;
- learning which model from a plurality of causal models comprises a best fit for modeling the contribution of the elements of value and the external factors to the model output value when using the selected data;
- learning if a clustering of the input data improves an accuracy of the component of value models;
- learning a relative contribution of each of the elements of value to the model output value, and
- learning a relative contribution of each of the external factors to the model output value,
- where the plurality of causal models are selected from the group consisting of Tetrad, LaGrange, Bayesian and path analysis, where the elements of value physically exist and are selected from the group consisting of customers, equipment, partners and suppliers and where the plurality of predictive models are selected from the group consisting of classification and regression tree;
- projection pursuit regression; generalized additive model (GAM), redundant regression network;
- neural network, multivariate adaptive regression splines; linear regression; and stepwise regression.
8. A non-transitory computer program product tangibly embodied on a computer readable medium and comprising a program code for directing at least one computer to perform an automated risk management method, comprising:
- store, in a computer readable memory, financial data related to a population of financial data records and segmented into a number of categories, wherein the categories are mutually exclusive and collectively exhaustive of the financial data, and scenario data for a set of scenarios, wherein each of the scenarios is defined at least in part by a set of variables, and wherein the scenario data for each of the scenarios comprise at least some parameter values for the set of variables;
- provide a computer processor associated with the computer readable memory with a model of a system defined at least in part by the set of variables;
- process the financial data and the scenario data using the model to obtain an estimated model outcome distribution comprising a distribution of estimated model outcomes relating to the system and based on the set of scenarios where the model is developed by learning from the financial data; and
- output the estimated model outcome distribution.
9. The non-transitory computer program product of claim 8, wherein the processing further comprises:
- selecting a first subset of the financial data as a first sample, the first subset drawn without replacement from each of the categories;
- performing, with the model and the first subset, a first test of the set of scenarios to obtain a first set of sample outcomes for each of the scenarios;
- repeating the selecting and performing steps using additional subsets of the financial data to perform additional tests of the set of scenarios and to obtain additional sets of sample outcomes for each of the scenarios;
- wherein the additional subsets are drawn without replacement from each of the categories;
- wherein the first sample outcomes and the additional sample outcomes are combined to create a cumulative estimated model outcome distribution; wherein the selecting and performing steps are repeated until the cumulative model outcome distribution is within a pre-determined acceptable tolerance limit from a distribution of fully assessed model outcomes for the set of scenarios obtainable by performing, with the model, a single test of the set of scenarios using all of the data.
10. The non-transitory computer program product of claim 8, wherein the system comprises an organization that physically exists.
11. The non-transitory computer program product of claim 8, wherein the cumulative model outcome distribution is identified as the estimated model outcome distribution.
12. The non-transitory computer program product of claim 8, further comprising segmenting the financial data into the selected number categories before storing the financial data in the computer readable memory where the categories comprise current operation revenue, current operation expense, current operation capital change, real options and market sentiment.
13. The non-transitory computer program product of claim 8, wherein the financial data comprises insurance policyholder data; wherein the model comprises a model of one or more insurance liabilities; and wherein the model outcomes comprise measures of a risk comprising a likelihood of an occurrence of the insurance liability for a scenario in the set of scenarios.
14. The non-transitory computer program product of claim 8, wherein developing the model of the system by learning from the financial data comprises:
- using a plurality of predictive models and a plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact of each of one or more elements of value;
- using the plurality of predictive models and the plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact each of one or more external factors;
- learning which algorithm from a plurality of linear and nonlinear predictive model algorithms to include in the model in order to model a net contribution or impact of each of the one or more elements of value and each of the one or more external factors to a model output value;
- learning which model from a plurality of causal models comprises a best fit for modeling the contribution of the elements of value and the external factors to the model output value when using the selected data;
- learning if a clustering of the input data improves an accuracy of the component of value models;
- learning a relative contribution of each of the elements of value to the model output value, and
- learning a relative contribution of each of the external factors to the model output value,
- where the plurality of causal models are selected from the group consisting of Tetrad, LaGrange, Bayesian and path analysis and where the plurality of predictive models are selected from the group consisting of classification and regression tree; projection pursuit regression; generalized additive model (GAM), redundant regression network; neural network, multivariate adaptive regression splines; linear regression; and stepwise regression.
15. An automated risk management system, comprising:
- a computer with at least one processor having circuitry to execute instructions; a storage device available to each of said processors with sequences of instructions stored therein, which when executed cause at least one of the processors to: store, in a computer readable memory, financial data related to a population of financial data records and segmented into a number of categories, wherein the categories are mutually exclusive and collectively exhaustive of the financial data, and scenario data for a set of scenarios, wherein each of the scenarios is defined at least in part by a set of variables, and wherein the scenario data for each of the scenarios comprise at least some parameter values for the set of variables; provide a computer processor associated with the computer readable memory with a model of a tangible system defined at least in part by the set of variables; process the financial data and the scenario data using the model to obtain an estimated model outcome distribution comprising a distribution of estimated model outcomes relating to the tangible system and based on the set of scenarios where the model is developed by learning from the financial data; and output the estimated model outcome distribution.
16. The system of claim 15, wherein the processing further comprises:
- selecting a first subset of the financial data as a first sample, the first subset drawn without replacement from each of the categories;
- performing, with the model and the first subset, a first test of the set of scenarios to obtain a first set of sample outcomes for each of the scenarios;
- repeating the selecting and performing steps using additional subsets of the financial data to perform additional tests of the set of scenarios and to obtain additional sets of sample outcomes for each of the scenarios;
- wherein the additional subsets are drawn without replacement from each of the categories;
- wherein the first sample outcomes and the additional sample outcomes are combined to create a cumulative estimated model outcome distribution; wherein the selecting and performing steps are repeated until the cumulative model outcome distribution is within a pre-determined acceptable tolerance limit from a distribution of fully assessed model outcomes for the set of scenarios obtainable by performing, with the model, a single test of the set of scenarios using all of the data.
17. The system of claim 15, wherein the tangible system comprises an organization that physically exists.
18. The system of claim 15, wherein the cumulative model outcome distribution is identified as the estimated model outcome distribution.
19. The system of claim 15, further comprising segmenting the financial data into the selected number categories before storing the financial data in the computer readable memory where the categories comprise current operation revenue, current operation expense, current operation capital change, real options and market sentiment.
20. The system of claim 15, wherein developing the model of the system by learning from the financial data comprises:
- using a plurality of predictive models and a plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact of each of one or more elements of value;
- using the plurality of predictive models and the plurality of causal models to analyze and select a portion of the financial data to use as an input when modeling an impact each of one or more external factors;
- learning which algorithm from a plurality of linear and nonlinear predictive model algorithms to include in the model in order to model a net contribution or impact of each of the one or more elements of value and each of the one or more external factors to a model output value;
- learning which model from a plurality of causal models comprises a best fit for modeling the contribution of the elements of value and the external factors to the model output value when using the selected data;
- learning if a clustering of the input data improves an accuracy of the component of value models;
- learning a relative contribution of each of the elements of value to the model output value, and
- learning a relative contribution of each of the external factors to the model output value,
- where the plurality of causal models are selected from the group consisting of Tetrad, LaGrange, Bayesian and path analysis and where the plurality of predictive models are selected from the group consisting of classification and regression tree; projection pursuit regression; generalized additive model (GAM), redundant regression network; neural network, multivariate adaptive regression splines; linear regression; and stepwise regression.
Type: Application
Filed: Jan 13, 2013
Publication Date: May 23, 2013
Inventor: Jeff Scott Eder (Mill Creek, WA)
Application Number: 13/740,223
International Classification: G06Q 10/06 (20120101);