Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
Rotergnom2
Regular Visitor

Moving Average

Hey,

 

I tried to go for the Moving Average building with PowerBI. 

 

The problem is that the moving average is calculated for the future, which does not make any sense. 

I wanted to do a six-month-rolling average with the quick measure (problem of above appeared), then with the formula = calculate(average([Sales]), DatesInPeriod([date];Lastdate([date]), -6, MONTH). Same Problem, again. So I do not know what is the problem. Perhaps somebody could offer me a simple sample PBIX data with a 6 month moving average over 2 years data..

 

Unbenannt.PNG

1 ACCEPTED SOLUTION
v-jiascu-msft
Employee
Employee

Hi @Rotergnom2,

 

I would suggest you create a date table in your scenario. Please check out the attached demo and the measure below.

Measure =
VAR maxFactDate =
    CALCULATE ( MAX ( FactTable[Date] ), ALL ( 'Calendar' ) )
RETURN
    IF (
        MAX ( 'Calendar'[Date] ) > maxFactDate,
        BLANK (),
        CALCULATE (
            AVERAGEX (
                SUMMARIZE (
                    'FactTable',
                    'Calendar'[Date].[Year],
                    'Calendar'[Date].[Month],
                    "MonthTotal", SUM ( FactTable[Sales] )
                ),
                [MonthTotal]
            ),
            DATESINPERIOD ( 'Calendar'[date], LASTDATE ( 'Calendar'[date] ), -6, MONTH )
        )
    )

Best Regards,

Dale

Community Support Team _ Dale
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

View solution in original post

3 REPLIES 3
v-jiascu-msft
Employee
Employee

Hi @Rotergnom2,

 

Could you please mark the proper answer as a solution?

 

Best Regards,

Dale

Community Support Team _ Dale
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
v-jiascu-msft
Employee
Employee

Hi @Rotergnom2,

 

I would suggest you create a date table in your scenario. Please check out the attached demo and the measure below.

Measure =
VAR maxFactDate =
    CALCULATE ( MAX ( FactTable[Date] ), ALL ( 'Calendar' ) )
RETURN
    IF (
        MAX ( 'Calendar'[Date] ) > maxFactDate,
        BLANK (),
        CALCULATE (
            AVERAGEX (
                SUMMARIZE (
                    'FactTable',
                    'Calendar'[Date].[Year],
                    'Calendar'[Date].[Month],
                    "MonthTotal", SUM ( FactTable[Sales] )
                ),
                [MonthTotal]
            ),
            DATESINPERIOD ( 'Calendar'[date], LASTDATE ( 'Calendar'[date] ), -6, MONTH )
        )
    )

Best Regards,

Dale

Community Support Team _ Dale
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Greg_Deckler
Super User
Super User

So, is your calculation correct other than the fact that it includes future estimations?


@ me in replies or I'll lose your thread!!!
Instead of a Kudo, please vote for this idea
Become an expert!: Enterprise DNA
External Tools: MSHGQM
YouTube Channel!: Microsoft Hates Greg
Latest book!:
The Definitive Guide to Power Query (M)

DAX is easy, CALCULATE makes DAX hard...

Helpful resources

Announcements
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.