Displaying the first date of my historical years
Hi All,
I was wondering if there is a syntax that gives me the first date of my historical years, based on the timescale settings. My Fiscal Year (currently) goes from 01-06-2018 to 31-05-2019 and I have 2 past years within my model, i.e. the date I'm looking for right now is 01-06-2016. I would like to have a syntax that gives me this date based on the timescale, because it has to 'move' to the next year once we go into the new Fiscal Year.
Currently this date is a manual input (see attachment).Additionally, almost al other dates are a function of this 'First Actual Date', so I do not want to have the 'First Actual Date' to be a function of the other dates.
hope this is clear enough and looking forward to answers!
Best,
Thomas
Best Answer
-
Yep - This is possible (as easy!!)
1. Create a check of the first period
2. Return the date if 1. above
In the example below, I have weeks
the formulas are:
1st Week? - OFFSET(1, -1, 0) = 0 (formatted as Boolean)
Date = IF NOT '1st Week?' THEN BLANK ELSE START() (formatted as Date)
3. Bring the value into your target module (formatted as date)
The formula is
Date - TIMESUM(Future Time by Week.Date) (formatted as Date)
You can also use that the trick in 1. for the end of the timescale by changing the -1 parameter
OFFSET(1, 1, 0) = 0
Hope that helps
David
4
Answers
-
Great, this helps indeed!
Thought there would be an easy solution, but just could not come up with it yet.
Thanks!
0 -
I use the 1st period flag to get around having an additional line item for opening balances too
So
IF 1st Period THEN Opening Balance Data ELSE PREVIOUS(Closing)
Where the Opening Balance Data is not dimensioned by time
David
0 -
Nice work-around too. I'm using flags a lot as well in the financial models. Like the flexibility of working with it.0
-
Booleans are great and the most efficient method of modelling.
Just don't do IF xxx = yyy THEN TRUE ELSE FALSE
My pet hate!!!
xxx = yyy is sufficient!
David
0 -
Would you explain how that OFFSET is accomplishing the task? I have only used OFFSET with a specific Line Item. What does giving it a '1' do?0
-
The offset 1 is pulling '1' in from the previous period. It could be any value, I just chose 1 but by embedding the absolute value within the formula, it saves having another line item
Because you use the 0 as the "fill" parameter to display a value if Offset doesn't return a value, you can check for that. In the first period, there is no previous period, the formula returns the fill value, so you check for that
I could have written OFFSET(99,-1,66) = 66. The result would be the same
I hope that helps
David
0 -
Ah! So your OFFSET is asking "is there something in the period before this period?" And this will always give you some sort of value EXCEPT when you are in the first period of the timescale. In that one case it will not find anything so it will return whatever you put as the third term. You can then ask "did I get the third term value?" You will only get that return when you are in the first period of the timescale. Nice!0
-
Exactly
And, of course, the reverse is true for the last period as there is nothing in the "next" period.
Simple!
David
0