Reverse-mapping using Smartlist
This is essentially relying on dimension-based smartlists to resolve to the intended member. This option gives the users the ability to maintain the mappings via a webform without having the underlying business rules hard-coding to any target members. Use case for this method can be applied to any allocation-type business rules. Details of this techniques can be found in this post and this one.User Variables & Planning Expressions
The User Variables feature in Planning can be a useful tool to give users more control over what they wish to view in a webform. Forms configured to use these variables will give users the ability to dynamically select a member at runtime (e.g. a parent member of a hierarchy) which could then be used to display the descendants of the selected parent. To take it one step further, we can use the user variables in business rules as well. This helps us to limit the calculation to only the selected member(s), thus, making the rule run faster.Let's see how this can be achieved in the business rule. The trick here is to use a Planning Expression to resolve to the selected member of the User Variable. The Planing Expression in question here is the [[PlanningFunctions.getUserVarValue("User_Variable")]].
Consider this. I have defined the following User Variables:
And I wish to limit my calculation scope to level 0 members of the selected Entity and Cost Centre parents. Here's how I would code my rule:
The "PlanningFunction.getUserVarValue" Planning Expression will resolve to the base members of entity and cost centre that the user has selected at runtime. You could also use other Planning Expressions to further your quest in avoiding any hard-coding in your rules. Here are some other examples of Planning Expressions that you could possible use:
Periods
The following is a list of Period-related Planning Expressions:I have personally not used any of the above Planning Expressions except for [[Period("FIRST_PERIOD")]] & [[Period("LAST_PERIOD")]]. Here's an example of how I've used them in my rule to control how I get the prior period value for an account.
Scenarios
Here's a list of Planning Expressions linked to Scenarios:The last I used the above expressions, they require the Scenario Name to be a string (i.e. hard-coded) but the latest reference guide from Oracle shows that the expressions now accepts variables such as Runtime Prompts (RTP). Try it out and let me know we can now use variables. Would be awesome if this is true.
Here's an example code I've lifted from the Oracle's guide. Looks like it accepts RTPs.
That's all folks for this blogpost. Let me know if you find this post useful and any other feedback is also welcomed. Thank you and see you in my next post.