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

Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started

Reply
ChPetru
Helper I
Helper I

Poor performance IF measure

Hello,

 

I have created a measure that has horrible performance:

_Active License = 
VAR ExpiresInFuture =
    LASTDATE ( LineItem[Opportunity Line End Date] )
        >= LASTDATE ( ReferenceDate[Reference Date] )
VAR ExpiresInPast =
    LASTDATE ( LineItem[Opportunity Line End Date] )
        <= LASTDATE ( ReferenceDate[Reference Date] )
VAR StartsInFuture =
    FIRSTDATE ( LineItem[Opportunity Line Start Date] )
        >= LASTDATE ( ReferenceDate[Reference Date] )
VAR StartsInPast =
    FIRSTDATE ( LineItem[Opportunity Line Start Date] )
        <= LASTDATE ( ReferenceDate[Reference Date] )
RETURN
    IF (
        ExpiresInPast,
        "Expired",
        IF (
            StartsInPast && ExpiresInFuture,
            "Active",
            IF ( StartsInFuture && ExpiresInFuture, "Future", "Error" )
        )
    )

 

This is not even running for low granularity.. not sure how I can optimize it to run under 3ms. 

The output should tell me if a license if expired, active or future based on the row level start and end date.

 

Thank you

 

2 REPLIES 2
PabloDeheza
Solution Sage
Solution Sage

Hi there!

One thing you can try is splitting the variables so you dont make the engine compute the same thing multiple times. The engine is sometimes smart enough to realise that something was already computed but not always.

Try one variable for 

LASTDATE ( LineItem[Opportunity Line End Date] )

One for

LASTDATE ( ReferenceDate[Reference Date] )

And one for

FIRSTDATE ( LineItem[Opportunity Line Start Date] )

Variables are only computed once, since you are using one of those expression 4 times, that should help at least something on your performance.

Let me know if that helps! 

Sorry, it did not help at all. I actually broke down the measure to:

 

_License Active =
IF (
    FIRSTDATE ( LineItem[Opportunity Line Start Date] )
        <= LASTDATE ( ReferenceDate[Reference Date] )
        && LASTDATE ( LineItem[Opportunity Line End Date] )
            >= LASTDATE ( ReferenceDate[Reference Date] ),
    TRUE (),
    FALSE ()
)

 

and it still has huge performance issues. 

How can I optimize this?

Helpful resources

Announcements
Sept PBI Carousel

Power BI Monthly Update - September 2024

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

September Hackathon Carousel

Microsoft Fabric & AI Learning Hackathon

Learn from experts, get hands-on experience, and win awesome prizes.

Sept NL Carousel

Fabric Community Update - September 2024

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