Value dimension is a system-defined dimension, it represents the types of value stored in your application. You can find the following image for your quick understanding if this dimension.
Actually, you will find the dimension shows in HFM system as below, depending on how many currencies you have set up for the application. (5 currencies in this example.)
Technically, <EC>, <ECA>, <ECT>, <PC>, <PCA> and <PCT> are the pointers to the currency members. For example, if the entity and its parent's local currencies are HKD, the data will be stored in "HKD" member when input data in <EA> or translate data to <PA>.
For the sub group rollup logic in Entity dimension, you can find the picture below. Sub Group's <EC> = Sum of the children Subsidiaries/Associates/Joint Ventures' [Contribution Total]
After the understanding the value dimension, we can move to the HFM rule's calculation logic. Actually, the HFM admin guide describes very clearly about the rules so I just copy some of the contents here.
You use Financial Management rules to automate the calculations of data within an application. You can use rules for these purposes:
- Calculate data entry level amounts for a specific entity, scenario, and period.
- Prevent data entry for a specific cell in a specific entity, scenario, and period.
- Allow input at the Parent entity level.
- Calculate data that cannot be calculated through a hierarchical aggregation, such as ratios or variance analysis.
- Perform allocations from a parent entity to a list of base entities.
- Perform complex currency conversions, calculate exchange rate differences, or perform other calculations necessary for your consolidation.
- Define formulas to dynamically calculate accounts.
- Specify the accounts in the application that support intercompany transactions.
HFM provides the following rule types
- Calculation
- Translation
- Consolidation
- Allocation
- Input
- NoInput
- Dynamic Calculation
- Transactions
- Equity Pickup
- OnDemand (From version 11.1.2.3)
During the consolidation process, rules are executed in a pre-defined sequence. For each base child of a specific parent, the calculation sequence for the various elements in the Value dimension takes place in this order:
- Accounts defined as IsCalculated in the metadata are cleared in EntityCurrency.
- Accounts defined as IsCalculated in the metadata are cleared in EntityCurrAdjs.
- The Sub Calculate() routine is executed on EntityCurrency.
- The Sub Calculate() routine is executed on EntityCurrAdjs.
- The ParentCurrency data is cleared.
- Default translation is applied to all accounts defined as Revenue, Expense, Asset, Liability for the total amount of EntityCurrency and EntityCurrAdjs. For accounts with the Flow or Balance attribute, translation is not applied by default, the total amount of EntityCurrency and EntityCurrAdjs is rolled up into Parent Currency.
- The Sub Translate() routine is executed.
- The Sub Calculate() routine is executed on ParentCurrency.
- Accounts defined as “IsCalculated” in the metadata are cleared in ParentCurrAdjs.
- The Sub Calculate() routine is executed on ParentCurrAdjs.
- Accounts defined as “IsCalculated” in the metadata are cleared in ParentAdjs
- The Sub Calculate() routine is executed on ParentAdjs.
- Proportion and Elimination data are cleared.
- Default consolidation and eliminations are performed for the total amount of Parent and ParentAdjs.
- The Sub Calculate() routine is executed on Proportion and Elimination.
- Accounts defined as “IsCalculated” in the metadata are cleared in ContributionAdjs.
- The Sub Calculate() routine is executed on ContributionAdjs.
After the previous steps have been repeated for each base child, this sequence takes place for the parent entity:
- The EntityCurrency data is cleared.
- The sum of the total of Proportion, Elimination, and ContributionAdjs for every child is written into EntityCurrency of the parent entity.
- The Sub Calculate() routine is executed on EntityCurrency.
- Accounts defined as “IsCalculated” in the metadata are cleared in EntityCurrAdjs.
- The Sub Calculate() routine is executed on EntityCurrAdjs.
Note: If a parent is further consolidated into another parent, this sequence continues with step 5 from the child consolidation sequence.
No comments:
Post a Comment