Skip to main content
Version: I2024.2.x

Use cases for Time Dimensions

The following use cases are examples from AtScale's Sales Insights demo data, in which time dimensions are used for time-based sales analysis. The calculated measures shown in each MDX example use the following time intelligence MDX functions to navigate through time dimensions: LEAD, LAG, PREVMEMBER, NEXTMEMBER, CURRENTMEMBER, PERIODSTODATE, and PARALLELPERIOD.

Period-over-period growth for sales amounts

In this use case, the calculated measures below can be used to compare sales growth of the current period to the previous period. These calculated measures use CURRENTMEMBER, LAG, and PREVMEMBER to calculate the sales amount for the previous period and the sales amount growth over the previous period.

Case 1

Calculated measure for sales amount for the previous period: [Measures].[Sales Amount-Order Retail445-Prev]

([Order Date Dimension].[Order Retail445].CurrentMember.PrevMember, [Measures].[salesamount1])

Case 2

Calculated measure for sales amount growth over the previous period: [Measures].[Sales Amount-Order Retail445-PrevPeriodGrowth]

([Order Date Dimension].[Order Retail445].CurrentMember, [Measures].[salesamount1])
-
[Measures].[Sales Amount-Order Retail445-PrevYear]

Workbooks

Figure 1. Tableau workbook use cases 1 and 2

image

Figure 2. Excel workbook for use cases 1 and 2

image

Sales growth year-over-year

In this use case, the calculated measures below can be used to find the internet sales growth over one year (between now and the same time last year). The MDX expressions below use CURRENTMEMBER and PARALLELPERIOD.

Case 3

Calculated measure for internet sales from last year: [Measures].[Sales Amount-Order Retail445-PrevYear]

(ParallelPeriod(
[Order Date Dimension].[Order Retail445].[Order Reporting_Year],
1,
[Order Date Dimension].[Order Retail445].CurrentMember),
[Measures].[salesamount1]
)

Case 4

Calculated measure for growth of internet sales between last year and the current year: [Measures].[Sales Amount-Order Retail445-PrevYearGrowth]

([Order Date Dimension].[Order Retail445].CurrentMember, [Measures].[salesamount1])
-
[Measures].[Sales Amount-Order Retail445-PrevYear]

Workbooks

Figure 3. Tableau workbook for use cases 3 and 4

image

Figure 4. Excel workbook for use cases 3 and 4

image

Sales year-to-date

In this use case, the calculated measure below can be used to find the internet sales for the year, ending with the current date.

Case 5

Calculated measure for the aggregate of sales for the year: [Measures].[Sales Amount-Order Retail445-YTD]

MDX expression:

Aggregate(
PeriodsToDate(
[Order Date Dimension].[Order Retail445].[Order Reporting_Year],
[Order Date Dimension].[Order Retail445].CurrentMember
),
[Measures].[salesamount1]
)

Sales year-to-date by day, compared to previous year

In this use case, the calculated measure below can be used to compare the daily sales amount for the year-to-date, and the year-to-date sales of the year previous.

Case 6

Calculated measure for all internet sales of the year previous to the current year: [Measures].[Sales Amount-Order Retail445-YTDPrevYear]

MDX expression:

Aggregate(
PeriodsToDate(
[Order Date Dimension].[Order Retail445].[Order Reporting_Year],
ParallelPeriod(
[Order Date Dimension].[Order Retail445].[Order Reporting_Year],
1,
[Order Date Dimension].[Order Retail445].CurrentMember
)
),
[Measures].[salesamount1]
)

Workbooks

Figure 5. Tableau workbook for use cases 5 and 6

image

Figure 6. Excel workbook for use cases 5 and 6

image

Daily sales compared to 30-period moving average and standard deviation

In this use case, the calculated measures can be used to compare each day's sales for the past 30 days, as well as each day's moving average of the previous 30 days. We can also find the upper and lower bounds of the daily moving average's standard deviation.

Case 7

Calculated measure for the 30-period moving average: [Measures].[Sales Amount-Order Retail445-30PrdMvAvg] (Not that the Range operator ":" is inclusive at both ends of the range, so use a lag value of 29 to get a 30 period range.)

Avg(
[Order Date Dimension].[Order Retail445].CurrentMember.Lag(29)
:
[Order Date Dimension].[Order Retail445].CurrentMember,
[Measures].[salesamount1]
)

Case 8

Calculated measure for the 30-period moving average's standard deviation: [Measures].[Sales Amount-Order Retail445-30PrdMvStdev]

Stdev(
[Order Date Dimension].[Order Retail445].CurrentMember.Lag(29)
:
[Order Date Dimension].[Order Retail445].CurrentMember,
[Measures].[salesamount1]
)

Case 9

Calculated measure for the standard deviation's upper bound: [Measures].[Sales Amount-Order Retail445-30PrdMvUpperBand]

[Measures].[Sales Amount-Order Retail445-30PrdMvAvg]
+
[Measures].[Sales Amount-Order Retail445-30PrdMvStdev]

Case 10

Calculated measure for the standard deviation's lower bound: [Measures].[Sales Amount-Order Retail445-30PrdMvLowerBand]

[Measures].[Sales Amount-Order Retail445-30PrdMvAvg]
-
[Measures].[Sales Amount-Order Retail445-30PrdMvStdev]

Workbooks

Figure 7. Tableau workbook for use cases 7, 8, 9 and 10

image

Figure 8. Excel visual representation for use cases 7, 8, 9 and 10

image

30-period moving average compared to the previous year's

This use case compares the moving average of sales for last 30 days, compared to the same period in the previous year.

Case 11

Calculated measure for the 30-period moving average in the previous year: [Measures].[Sales Amount-Order Retail445-30PrdMvAvgPrevYear]

Avg(
ParallelPeriod(
[Order Date Dimension].[Order Retail445].[Order ReportIng_Year],
1,
[Order Date Dimension].[Order Retail445].CurrentMember
).Lag(29):
ParallelPeriod(
[Order Date Dimension].[Order Retail445].[Order ReportIng_Year],
1,
[Order Date Dimension].[Order Retail445].CurrentMember
),
[Measures].[salesamount1]
)

Workbooks

Figure 9. Tableau workbook for use case 11 against 30PrdMvAvg

image

Figure 10. Excel workbook for use case 11 against 30PrdMvAvg

image

30-period moving average percent change compared to the previous year's

This use case compares the growth in percentage of the 30-period moving average, compared to that of the same period in the previous year.

Case 12

Calculated measure for 30-period moving average growth between years : [Measures].[Sales Amount-Order Retail445-30PrdMvAvgPrevYearGrowthPct]

(
[Measures].[Sales Amount-Order Retail445-30PrdMvAvg]
-
[Measures].[Sales Amount-Order Retail445-30PrdMvAvgPrevYear]
)
/
[Measures].[Sales Amount-Order Retail445-30PrdMvAvgPrevYear]

Workbooks

Figure 11. Tableau workbook for use case 12

image

Figure 12. Excel workbook for use case 12

image

365-day moving window at levels higher than Day

In this use case, the calculated measure calculates a 365-day moving window at a level higher than Day.

The value of using this method to compute a moving window is that it decouples the computation from the period boundaries at higher levels. If the report user evaluates the expression at a level higher than Day (e.g. Month), the system shows the last non-empty 365-day moving window value.

This differs from other methods, such as ParallelPeriod, in that it avoids the problem of expanding the time range to the period start boundary, thereby maintaining the exact window size of 365 days up the hierarchy, even when reporting on mid-month (or higher) levels.

note

This scripting capability is not to be confused with the implicit "Last Non Empty" Semi-Additive aggregation measure type.

The MDX expressions used are Tail, Head, ExtractMember, and NonEmpty.

Case 13

The following expression calculates a 365-day moving average based on the last non-empty Day record for the measure [Measures].[Internet Sales Amount Local], which is a standard SUM measure.

Avg(
ExtractMember(
Tail(
NonEmpty(
Descendants(
[DateCustom].[StandardMonth].CurrentMember,
[DateCustom].[StandardMonth].[Date], SELF
),
[Measures].[Internet Sales Amount Local]
)
),
0
).Lag(364) :

ExtractMember(
Tail(
NonEmpty(
Descendants(
[DateCustom].[StandardMonth].CurrentMember,
[DateCustom].[StandardMonth].[Date], SELF
),
[Measures].[Internet Sales Amount Local]
)
),
0
),
[Measures].[Internet Sales Amount Local]
)