PARALLEL AVAILABILITY CONTROL CHECKS IN FINANCIAL MANAGEMENT SYSTEM
A rule set for an AVC system permits AVC operations to be performed at various levels of hierarchy within a governing budget data structure. A rule set contains a plurality of rules, each having an address field which relates an arbitrarily assigned control object to budget nodes in a budget data structure. Control objects typically are assigned to various units and aggregation levels within an organization and also across other dimensions. Rule arrays with several independent rule sets can be activated in parallel for checking an individual input data record against multiple budgetary requirements defined for the organization. This structure provides a comprehensive AVC control feature even for very large budget data structures and complex budgetary control environments.
Latest SAP AG Patents:
- Systems and methods for augmenting physical media from multiple locations
- Compressed representation of a transaction token
- Accessing information content in a database platform using metadata
- Slave side transaction ID buffering for efficient distributed transaction management
- Graph traversal operator and extensible framework inside a column store
This application is a divisional of U.S. patent application Ser. No. 10/739,131, filed Dec. 19, 2003, and claims benefit under 35 U.S.C. §119(e) of U.S. Provisional Application Ser. No. 60/488,815, filed Jul. 22, 2003, which are incorporated herein by reference in their entirety.
BACKGROUNDAvailability Control (“AVC”) refers to an oversight feature in budget control software that monitors ongoing expenditures of a business unit (an organization, department, sub-unit) and determines whether they are consistent with a budgetary plan established for that business unit. If an operator attempts to enter a transaction having an expenditure that is inconsistent with the budgetary plan, an AVC system may either block the transaction or generate online an alert within the system (perhaps an e-mail notification to a predetermined addressee) in response.
Currently available AVC systems are quite limited. SAP AG, the assignee of the present invention, currently employs an AVC oversight feature that can perform at most one defined AVC inquiry directed to a single hierarchical level within an organization. However, the inventors perceive a need in the art to expand such oversight to include implementation of multiple parallel AVC rules.
Embodiments of the present invention provide a rule array for an online AVC system that permits an entirely flexible definition of multiple AVC checks. The rule array contains one or several independent rule sets. Each rule set may include a plurality of control objects that address nodes of a budget data structure. Control objects typically are assigned to various units within an organization and also across other dimensions. The rule sets can address arbitrarily assigned control objects. Thus, it becomes possible to activate different rule sets in parallel to check an individual input data record against multiple budgetary requirements defined for the organization.
Embodiments of the present invention introduce a parallel AVC mechanism to an EMA 100. In
The AVC manager 130 manages execution of rules in response to new expenditure transaction requests that are made of the EMA system 100. When a new expenditure transaction request is received by the EMA system 100, the AVC manager 130 may determine whether the transaction request is related to any rule in the rule array 140. If so, it executes the rule to determine if the new transaction request complies with it. Transactions that comply with all relevant rules may be admitted to the system and may update the assigned ledger database 150, 160.
Operation of the AVC management features might best be understood with reference to an example involving a hypothetical organization. Consider an organization composed of departments A, B and C. Department A may include sub-departments A1 and A2, department B may have no sub-departments and department C may have sub-departments C1, C2, C3, C4 and C5.
The budget data structure 200 of
Within each node of the budget data structure, the system may store values representing allocated budget for the corresponding business unit/dimension and also aggregations of expenditure transactions charged against it. In practice, it is permissible to define two databases, one for budget and the other for expenditure data, if so desired. Such implementation preferences are immaterial for the purposes of the present invention. All that is required is that the AVC manager can access budgetary values and expenditure aggregation values provided within each of the budget nodes.
Following execution of the last identified rule, the method may determine whether the transaction was blocked (box 1070). If no rule generated an error, the system may inform the transaction system that the transaction request may be admitted (box 1080). The method may also update the AVC ledger database with the new expenditure data (box 1090).
A proper understanding of the foregoing embodiments may be facilitated through use of an example. Consider a scenario as shown in Table 1. As shown, a budget node for department A may store a budget value of 10K. Budget nodes for sub-departments A1 and A2 each store budget values of 20K. Budget nodes A1.1 and A1.2 store budget values of 45K and budget nodes A2.1-A2.4 each store budget values of 15K.
Aggregated expenditure for a certain point in time is shown in Table 1 as well. In this example, assume that expenditures are posted only to leaf nodes (e.g., A1.1, A1.2, A2.1, etc.) in the budget data structure but not to branch nodes (e.g., A1, A2). Other implementations may differ.
Returning to
Consider operation of the rules, however, when a new transaction request is presented which proposes an additional expenditure of 10K against budget node A1.1. Execution of the rules would yield the following:
In this example, since budget node A1.1 does not contribute to control object A2, rule 380 need not be executed. Additionally, the proposed expenditure passes the requirements of rules 360 and 370 and, therefore, the expenditure can be admitted to system.
If a new transaction request, instead proposed an expenditure of 20K to budget node A1.1, execution would yield:
Again, rule 380 need not be executed because it does not use data from budget node A1.1 as a source. Execution of rule 360, however, generates an error. In this case, the total expenditure value including the proposed expenditure would be 210K which exceeds the 200K budget defined for control object A. Rule 370, if it were executed alone, would not generate an error.
If a transaction request has proposed an expenditure of 10K to budget node A2.1, execution of the rule set would yield:
In this example, rule 360 is satisfied but rule 380 is not. In this example, the response, however is a warning. Thus, the proposed transaction can be admitted to the system.
The parallel AVC mechanism provided by the foregoing embodiments provides a convenient oversight mechanism through which EMAs can manage new transactions as they are admitted to the system and ensure that the transactions comply with multiple budgetary requirements of the organization. Although relatively simple data structures and rule sets are illustrated here, large corporations may define organizational data structures that include several thousands of budget nodes with complex rules for assigning control objects at different organizational levels. An EMA system may process several million transactions during the course of its fiscal year from a variety of sources. It is not always apparent that an expenditure directed to a low-level budget node (e.g., A1.1) may violate budgetary requirements defined for superior control objects at different higher organizational levels such as Al and A. Because the AVC system of the present invention permits control objects to address arbitrary locations of the budget data structure, however, the AVC system ensures compliance no matter where an expenditure is posted nor at which level it must be checked.
The parallel AVC mechanism of the foregoing embodiments also provides a mechanism through which an organization can monitor the propriety of budget reductions. In some business applications, an organization may find it convenient to adjust budget allocations of a fiscal period at some point during the fiscal period. Rather than raise expenditure levels, the budget adjustments could cause budget levels to drop. Some budget levels may drop to an extent that it would cause violation of an AVC rule even though there has been no change in the aggregated budget. Thus, the parallel AVC mechanism can detect budgetary revisions that might be made in violation of a governing financial control strategy for the organization. To detect possible violations, it would be sufficient to perform the AVC checks of the foregoing embodiments after a budget revision occurs.
The foregoing describes operation of the present invention in the context of a transaction request that is simultaneously checked at two different organizational or aggregation levels. Of course, the principles of the present invention are not limited. In practice, a single transaction entered at a terminal T may generate a document to be processed by the EMA, for example, a purchase order or an invoice, that must simultaneously comply with budgetary requirements at more than two organizational or aggregation levels. In this case, the rule arrays accordingly would consist of more than two rule sets. From this document, the transaction system 110 (
According to an embodiment, ledger databases 150, 160 (
The exemplary rule sets of
As noted, the foregoing embodiments may provide a software implemented EMA system. As such, these embodiments may be represented by program instructions that are to be executed by a server or other common computing platform. One such platform 500 is illustrated in the simplified block diagram of
Several embodiments of the present invention are specifically illustrated and described herein. However, it will be appreciated that modifications and variations of the present invention are covered by the above teachings and within the purview of the appended claims without departing from the spirit and intended scope of the invention.
Claims
1. An AVC method, comprising:
- responsive to a transaction identifying a new expenditure of an organization, determining whether the new expenditure is relevant to any AVC control objects in a rule set,
- if so, executing the relevant AVC control objects until an error is generated, the executing comprising: retrieving budget information and expenditure information for the control object, determining with reference to the retrieved budget information, the retrieved expenditure information and the new expenditure information, whether a rule represented by the control object is violated; and
- if execution the rule is violated and the control object identifies an error as a response thereto, blocking the transaction.
2. The AVC method of claim 1, further comprising storing an aggregation of budget values addressed by a control object in a separate ledger database.
3. The AVC method of claim 1, further comprising storing an aggregation of expenditure values addressed by a control object in a separate ledger database.
4. The AVC method of claim 1, wherein the control objects are organized into rule sets and control objects of a common rule set address budget nodes in a common hierarchical level of a budget data structure.
5. The AVC method of claim 1, wherein the control objects address budget nodes at various hierarchical levels of a budget data structure.
6. The AVC method of claim 1, further comprising admitting the new transaction if no rule generates an error.
7. The AVC method of claim 1, further comprising generating a warning message if the new transaction violates a rule for which a warning notification is defined.
8. A computer readable medium in which are stored program instructions that when executed, cause a financial management system to:
- determine whether a new expenditure is relevant to any AVC control objects in a rule set responsive to a transaction identifying the new expenditure,
- if so, execute rules represented by the relevant control objects by: retrieving budget information and expenditure information for the control object, determining, with reference to the retrieved budget information, the retrieved expenditure information and the new expenditure information, whether a rule represented by the control object is violated; and if execution the rule is violated and the control object identifies an error as a response thereto, blocking the transaction.
9. The medium of claim 8, further comprising a budget data structure storing aggregations of expenditure data.
10. The medium of claim 8, wherein the instructions further cause storage of an aggregation of budget values addressed by a control object in a separate ledger database.
11. The medium of claim 8, wherein the instructions further cause storage of an aggregation of expenditure values addressed by a control object in a separate ledger database.
12. The medium of claim 8, wherein the control objects are organized into rule sets and control objects of a common rule set address budget nodes in a common hierarchical level of a budget data structure.
13. The medium of claim 8, wherein the control objects address budget nodes at various hierarchical levels of a budget data structure.
14. The medium of claim 8, wherein the instructions further cause admission of the new transaction if no rule generates an error.
15. The medium of claim 8, wherein the instructions further cause a warning message to be generated if the new transaction violates a rule for which a warning notification is defined.
16. An AVC method, comprising:
- responsive to an attempted adjustment in budget for an organization, executing a plurality of AVC control objects until an error is generated, the executing comprising: retrieving budget information and expenditure information for the control object, determining, with reference to the retrieved budget information and the retrieved expenditure information, whether a rule represented by the control object is violated; and
- if execution the rule is violated and the control object identifies an error as a response thereto, blocking the attempted budget adjustment.
Type: Application
Filed: Oct 31, 2013
Publication Date: Feb 27, 2014
Applicant: SAP AG (Walldorf)
Inventors: Horst Schnoerer (Angelbachtal), Christian Metz (Paris), Andreas Schaefer (Mougins), Juergen Hollberg (Wiesloch)
Application Number: 14/068,952
International Classification: G06Q 20/40 (20060101);