# QlikView App Dev

Discussion Board for collaboration related to QlikView App Development.

Announcements
Join this live chat April 6, 10AM EST - QlikView to Qlik Sense REGISTER
cancel
Showing results for
Did you mean:
Not applicable

## Rolling calculation

Hey,

I would like to calculate a twelve month rolling chart which is independend from it's time dimension.

Dimensions:

• period_year contains the combination of the month and the year formated as date ("MM.YYYY").

Variables:

• v_mr_top_limit = 07.2015
• v_mr_bottom_limit = 06.2014

Expression:

=SUM(

{<

period_year={'<\$(v_mr_top_limit)>\$(v_mr_bottom_limit)'}

>} AGGR(

RANGESUM(

ABOVE(

TOTAL SUM(

{<

period_year

>} values

)

,

0

,

12

)

)

,

period_year

)

)

I have expected to see the same value as if I have used the internal chart accumulation function.

I have no idea what causes the problem.

Any suggestions?

Best

Simon

1 Solution

Accepted Solutions
Not applicable
Author

I think I have solved the problem on my own

The reason for incorrect calculation is the sort order AGGR() uses because it does not use the current sort order from the chart but the original load order.

In my example this sort order is 2015.1, 2015.10, 2015.11, 2015.12, 2015.2,... etc.

To solve this problem I have done a pre-calculation of the dates and insert my data with a left join.

LET v_month_difference = 18;

LET v_period_year_min = (MAKEDATE(2014,1,1);

FOR i=0 TO (\$(v_month_difference)-1)

FACTDATA:

\$(i)+1 AS sort

AUTOGENERATE(1)

;

NEXT i;

Not applicable
Author

I think I have solved the problem on my own

The reason for incorrect calculation is the sort order AGGR() uses because it does not use the current sort order from the chart but the original load order.

In my example this sort order is 2015.1, 2015.10, 2015.11, 2015.12, 2015.2,... etc.

To solve this problem I have done a pre-calculation of the dates and insert my data with a left join.

LET v_month_difference = 18;

LET v_period_year_min = (MAKEDATE(2014,1,1);

FOR i=0 TO (\$(v_month_difference)-1)

FACTDATA: