Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.
Hi All
I have created the following measure which provides what i need but performs poorly.
The measure iterates through each "point" and each row in the calendar to determine if there is "Actual Data". If there is no data, ie. it is blank then it returns the corresponding forecast for the point in question for the day.
Is nesting these sumx the right thing to do? Thanks in advance:
calculate(
sumx(Calendar_,
SUMX(Points,
IF(ISBLANK([Actual Unit, Cost and Carbon]),
calculate(
max(Target[Daily Target]),
CROSSFILTER(Points[DBName-Point_Id],Target[DBName-Point_Id],OneWay_LeftFiltersRight))))),FILTER(Target,Target[TargetType] = 0))
Solved! Go to Solution.
Hi @debenaire ,
Nesting SUMX functions can indeed lead to performance issues because it requires iterating over rows multiple times, which can be resource-intensive.
Instead of nesting SUMX functions, consider restructuring your calculations to minimize the number of row context iterations. You can do this by trying to move calculations outside of the SUMX function if possible.
So I think you can change the DAX code like this:
VAR ActualDataCheck =
SUMX(
Points,
IF(
ISBLANK([Actual Unit, Cost and Carbon]),
BLANK(),
[Actual Unit, Cost and Carbon]
)
)
VAR Result =
IF(
ISBLANK(ActualDataCheck),
CALCULATE(
MAX(Target[Daily Target]),
FILTER(
Target,
Target[TargetType] = 0
)
),
ActualDataCheck
)
RETURN
SUMX(
Calendar_,
Result
)
Best Regards
Yilong Zhou
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Hi @debenaire ,
Nesting SUMX functions can indeed lead to performance issues because it requires iterating over rows multiple times, which can be resource-intensive.
Instead of nesting SUMX functions, consider restructuring your calculations to minimize the number of row context iterations. You can do this by trying to move calculations outside of the SUMX function if possible.
So I think you can change the DAX code like this:
VAR ActualDataCheck =
SUMX(
Points,
IF(
ISBLANK([Actual Unit, Cost and Carbon]),
BLANK(),
[Actual Unit, Cost and Carbon]
)
)
VAR Result =
IF(
ISBLANK(ActualDataCheck),
CALCULATE(
MAX(Target[Daily Target]),
FILTER(
Target,
Target[TargetType] = 0
)
),
ActualDataCheck
)
RETURN
SUMX(
Calendar_,
Result
)
Best Regards
Yilong Zhou
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.
Thanks so much!
Hi @debenaire
In general does not look good. But how does your model look like? how does your report look like? and confirm [Actual Unit, Cost and Carbon] is a measure.
User | Count |
---|---|
51 | |
27 | |
19 | |
18 | |
14 |
User | Count |
---|---|
91 | |
86 | |
39 | |
23 | |
22 |