Monday, September 5, 2016

Hyperion Planning Model Learnings: Fast Food Restaurant Business

This is going to be the first of many blog posts where I will be posting my experiences with various projects that I've been involved for the last seven years ! I do regret that I should have done this much earlier, since now I am having a hard time remembering things I did few years back !

The basic philosophy of any Hyperion Planning implementation is always the same: Shifting client's Planning and Budgeting processes from tiring Excel based spreadsheets to quick and easy Essbase cubes. Actual data is brought in from another system, mostly some ERP system like Oracle ERP, SAP etc. This data needs to be pushed to Hyperion systems. Various implementations use variety of techniques to achieve this.

Lets talk about fast food restaurant business. I will be dividing this posts in various sections:

Fast Food business Budgeting and Forecasting philosophy:
Restaurant business is very tricky, especially when it comes to fast food restaurants like McDonald's or Domino's Pizza. Margins per food item sold are not very high, so you want to sell more at any given time while keeping the costs at a minimum. What are the costs involved ? Well, it can be as small as tissue papers or sauce sachets to as big as automated cooking machines (French Fries' making machine, ovens etc). Then there is the cost of human resources, electricity, water. Not to mention, food wastage adds a lot to costs of running a FF restaurant.
To make matters even complicated, FF restaurants plan on a daily basis unlike monthly or weekly in most manufacturing business. So, planners will meticulously plan for each day at the start of each month (or the end of previous month). Why ? Simply because human eating patterns vary. Next week there is some football match, so people are going to be glued to their TVs, ordering Pizzas. Some Marvel Comic movie is going to get released in the theatre next to your outlet, more people will have some junk food for the next two weeks. Some holiday is coming, people will prefer to stay indoors, so no business.

Planning and Budgeting in Hyperion Planning:
Hyperion Planning deals with overall business and the motive of that is to have P&L and Balance Sheet reports, along with some Sales or Expenses reports.
Point to be noted here is that inventory planning, that is, how many buns you will order for next week or how many burgers you need to sell tomorrow, are not covered in Hyperion Planning model. We must, for the sake of simplicity, concentrate on 'Revenue' of an outlet.
Keeping that in mind, we try to keep the Sales account hierarchy as simple as possible. Instead of listing revenue from each food item sold, we only have Food sales.

Keeping this in mind, we arrive at what can be our possible dimensions:
----------------------------------------------------------------------------------------------------------------------
Account: Hierarchy must be derived from their existing P&L and other reports. ERP structure can also be used as a reference although ERP can be too detailed. So we might have to prune it to fit in our system.

Period: One of the important dimensions which needs careful thought as it cannot be changed later. Food Budgeting and Planning can be done either at a daily, weekly or monthly level. Daily and Weekly Planning requires custom period hierarchy which can complicate things further especially when leap years and week adjustments are considered. One advantage of having daily or weekly calendar is you can do more with your Hyperion applications. e.g. weekly sales plan, daily sales report, trend analysis etc.

When using on-premise Hyperion system, this can be achieved easily as you can have multiple applications with varying Period dimensions. Same cannot be the case with PBCS as there is a limitation of one application and Period dimension is shared across the cubes. We need to keep this in mind when proposing a solution to the client.

When your start month is different than January, months of a FY can spill over to the next year in Planning application, this is a point worth noting. It can be handled using correct aliases along with period specific calculations.

Entity: Usually Entity dimension is simpler in case of FF restaurant chains. Outlets usually roll up in an uncomplicated manner, say, one outlet rolls up to a city, which rolls up to a district, which rolls up to a state and then a country.
What complicates matters here is the classification of outlets: Some can be classified based on the number of tables (size), business hours (24x7), newly opened (this decides whether it can be considered for next year's budget) just to name a few. Discuss this with the client in order to come to an agreement as to which one is going to be the primary roll up and whether other attributes can be accommodated in it.

Custom Dimensions : Product: Consider this only if  client is planning and budgeting by food items (in my case, they did not). In some cases, Food Sales by products can be accommodated within Account dimension itself.

Assets : Assets can be accommodated within account hierarchy if the calculations are simple else we might need to have a separate dimension created.

Manpower/ HR: Ideally, this should be taken up in a separate application altogether. Depending on whether it is a PBCS implementation or on-premise, we must decide what best solution can be offered.
-------------------------------------------------------------------------------------------------------------------------

Business Logic: 
Sales and Cost of Sales calculations are simple, based on year on year percentage growth. Since seasonality is crucial in food business, we usually consider figures of the month (or lowest level member) of previous year for calculating Budget figures of same month of next year.


Weekly/Daily sales analysis, Manpower planning (on a daily basis) can be complicated. This can severely impact delivery timelines as it increases testing and validation time. We must keep this in mind while committing to the client.

Depreciation logic is same as the one in manufacturing business, Hyperion Calc manager has in-built depreciation calculation functions which are pretty straight forward.

Data Integration:  FDMEE and ODI remain the best choices for catering to data integration solutions. Before we begin with the implementation, we must at all cost, finalize this part of the system as it is the foundation of Hyperion solution. On a PBCS environment, this can be very simple as we cannot use any other tool than FDMEE.

Data forms and Reports: Reports are easier said than done. It is better to present a few sample reports to the client while the design and implementation is in progress. Their demands can be catered to by doing minor changes before the application is finalized. Since data forms are the first things which users interact with the system, letting them get a hang of the system right from the start is a good practice.

Tuesday, March 29, 2016

Beginners guide for Hyperion Planning Backup

Ok, so this is one of the most common and widely available documentation that you can find on Hyperion. 

What is the backup mechanism for Hyperion Planning and related applications ?

I am just going to make things easier for beginners to get started with backup strategies:
In case of server recovery, you need to have the following things ready 

1. LCM export of Planning and Essbase
2. LCM export of Shared Services 
3. Folder contents of Financial Reports 
4. ODI Master and Work repository 
5. Essbase data

Essbase.sec file can be backed up as well, but that wont be necessary if you already have LCM exports of Essbase and Shared services.

I will not cover FDMEE and other applications here.

As a good backup startegy, it is advisable to have at least seven days (week) of backup. So the easiest way is to have a backup folder location having seven folders with name of each day and then automate the LCM and data copy commands.

Here is a quick reference guide for each automation script

1. LCM export of Planning, Essbase and Shared Services (EPM 11.1.2.2 uses the EXPORT and IMPORT.xml files in LCM folders, newer versions can use a profile file directly)

cd D:\Oracle\Middleware\user_projects\epmsystem1\bin

D:\Oracle\Middleware\user_projects\epmsystem1\bin\utility.bat D:\Oracle\Middleware\user_projects\epmsystem1\bin\Export_BUD.xml -b D:\Prod_Process\Backups\HYPPROD

exit

2. Data Export Maxl (Call this through a Shell/cmd )

login admin password on essbase_server;
alter application HypApp disable connects;
export database HypApp.FCST all data in columns to data_file 'D:\\Backups\\HYPAPP\\HYPFCST_ALL.txt';
alter application HypFcst enable connects;

exit;


3. Finally copy the contents to a secure location, see a simple code below

@echo off
cd D:
SETLOCAL
REM /* parse Date value to get day of the week (System calendar should be English REM US ex. Tue 03/20/2016) if no, change the system date settings or below code REM */

for /f "tokens=1" %%i IN ("%Date%") DO ( echo %%i & set dow=%%i )
echo day of the week is %dow%

REM Delete folder with the name of day of week
rmdir D:\Prod_Process\BACKUPS\FILES\FROM_PROD\%dow% /s /q

REM Recreate folder once again 
mkdir D:\Prod_Process\BACKUPS\FILES\FROM_PROD\%dow%
echo Directory recreated : D:\Prod_Process\BACKUPS\FILES\FROM_PROD\%dow%

REM Copy contents from remote server to backup folders
REM You can alter the paths here 
xcopy \\server-39\d$\Prod_Process\Backups D:\Prod_Process\BACKUPS\FILES\FROM_PROD\%dow% /E /Y && xcopy \\server-38\d$\Oracle\Middleware\user_projects\epmsystem2\ReportingAnalysis\data D:\Prod_Process\BACKUPS\FILES\FROM_PROD\%dow% /E /Y

echo Folders copied
ENDLOCAL


exit

Once the above script is automated through task scheduler, it will create folders with names Sun, Mon, Tue and so on and copy the contents from source to target.

4. ODI Master and Work Repository Export 
Create a package which exports these two repositories and convert it into a scenario. 
Refer to this wonderful blog for exporting repositories
http://odiexperts.com/automize-the-backup-using-odi-exports/

Automate the scenario execution (Refer to my older post for ODI automation). Copy the zip files to a secure location using the script mentioned above.


5. Financial Reports Backup
Once you ensure that Planning and Essbase applications are restored, you have to copy the contents of RM1 folder from here 


Oracle\Middleware\user_projects\epmsystem2\ReportingAnalysis\data\RM1

and paste it to the recovered server, then restart the Financial Reporting services. It is therefore necessary that you backup the above mentioned folder

This much is enough to get started with backup automation. You can try many other things as you progress. 

Cheers !





Monday, January 4, 2016

Server Recovery and lessons learnt

Last month of 2015 was exciting, well at least at the beginning. Everything in the project was going as expected when suddenly a mail comes. One of the production server is inaccessible. IT guys find out that the server has some registries corrupted and they will have to restore the back up (tape backup of the entire C drive)

Then comes the bad news, the backup is not working either, IT guys restore the backup as old as one year but it is of no help   The only option is to rebuild a new server and replicate/reinstall Hyperion components in it. And so it begins.

Components on this server were
1. EAS
2. FR and Reporting Framework services.
3. ODI Studio and Data loading batch scripts

Good news was that Oracle Middleware home was on D drive which was intact so

Lesson #1: ALWAYS INSTALL EPM ON A DRIVE OTHER THAN C or NOT ON THE ONE HAVING OS FILES AND FOLDERS

This ensured that the some essential folders that are required can still be used.
Next task was to reinstall HFR and Framework services. The new server given had the D drive of the older one so Oracle folder is present, but that is of no use as registry entries are absent and it does not detect anything.
I decided to use the option of  'Reinstall this release' and reconfigure the database, but it did not work

Lesson #2: Re-installing a component on a recovered server does not work. You have to install afresh i.e. Select 'New installation' option
But make sure you use the same directory name and path. So the old Oracle folder has to be renamed (DO NOT DELETE it as it is needed at the time of restore)

At the time of configuration, use the 'Re-use schema' option. Selecting drop and recreate tables will say good bye to existing reports that are created.

By god's grace the configuration succeeded this time without any issue. One important point at the time of Configuration to be noted is

Lesson #3: When configuring web server for FR, make sure that Admin server is up and running on the shared services server. Else domain setup will fail. 

Recover RM1 folder.

Lesson #4: Once you have successfully started the FR services, close it once and replace the contents of RM1 folder with the older one.
it is located here
D:\Oracle\Middleware\user_projects\epmsystem1\ReportingAnalysis\Data\RM1

Hush ! the FR server was finally up and running. It was time to move to ODI

ODI does not require reinstall, it will work as expected, but with the credential details gone. Now comes the twist. For some reason the ODI work repository schema tables got deleted !
Nobody is able to figure out why that would have happened. The database is on a different server.
We confirmed the schema details from the Master repository tables and some entries had changed. This was re-assured when we compared it with Repositories of Development. Restoring it with older schemas did not work. This is still a mystery.

Lesson #5: Never trust disk backups or schema backups taken by other teams. 
The one thing that I've learnt the hard way is to have repository exports of ODI and keeping it in a safe remote location. Also, it is a good habit to have EPM LCM exports of every component that we can think of.

Then we came to know that Development and Production systems were not in sync.

Lesson #6: Always keep all environments in sync. We can copy contents directly from one environment to another.