Do not input private or sensitive data. View Qlik Privacy & Cookie Policy.
Skip to main content

Announcements
Qlik Connect 2026! Turn data into bold moves, April 13 -15: Learn More!
cancel
Showing results for 
Search instead for 
Did you mean: 
paulinhok14
Creator
Creator

Histogram with a Calculated Dimension

Hello dears!

Hope everything is well.

I have an application in which I present a key-performance indicator that tells me a calculated "Accuracy" for each element in my database called "Pair".

This accuracy is calculated as follows:

 

Avg (

Aggr (

If ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) = Alt ( Sum (distinct [Forecast Qty] ), 0 ), 100,
If ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) = 0 and Alt ( Sum (distinct [Forecast Qty] ), 0 ) <> 0, 0,
If ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) <> 0 and Alt ( Sum (distinct [Forecast Qty] ), 0 ) = 0, 0,

100 -
If ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) > Alt ( Sum (distinct [Forecast Qty] ), 0 ), ( Fabs ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) - Alt ( Sum (distinct [Forecast Qty] ), 0 ) ) ) / Alt ( Sum (distinct [Demanded Qty] ), 0 ) * 100,

If ( Alt ( Sum (distinct [Forecast Qty] ), 0 ) > Alt ( Sum (distinct [Demanded Qty] ), 0 ), ( Fabs ( Alt ( Sum (distinct [Demanded Qty] ), 0 ) - Alt ( Sum (distinct [Forecast Qty] ), 0 ) ) ) / Alt ( Sum (distinct [Forecast Qty] ), 0 ) * 100
)
)

)
)
)
, [%Pair] )

)

 

This expression returns me a number between 0 and 100 for each Pair, and I aggregate them as Average for overall value: 

valeling_1-1688740460861.png

I would like to create an Histogram counting how many Pairs are with a determined Accuracy, whether with a Class() or not.
I created a bar chart with the following settings:

Dimension: The same as highlighted above.
Expression: count (%Pair)

The chart fails with an error in calculated Dimension:

valeling_2-1688740839811.png

 

I can't calculate this expression previously in script because this Accuracy should recalculate respecting time frame filters.

Any ideas on how can I make this Histogram as I described?

Thank you in advance!

Labels (1)
1 Solution

Accepted Solutions
Oleg_Troyansky
Partner Ambassador/MVP
Partner Ambassador/MVP

Hi there!

I wish you could attend my lecture on Set Analysis and AGGR at the Masters Summit for Qlik - in one of my examples, I'm teaching just that - how to build a Histogram with an aggregated expression. Check out our schedule this fall, maybe you can join...

In a nutshell - a calculated dimension requires an array of values. The AGGR() function generates an array, but then the Avg() turns it into a single number. For your needs, you should drop the Avg() and leave the AGGR().

In order to get a bar chart with a reasonable number of bars, perhaps you want to round the results of AGGR() to the desired level. For example, rounding to 10 will give you 10 bars in your chart.

Cheers,

 

Ask me about Qlik Sense Expert Class!

View solution in original post

2 Replies
Oleg_Troyansky
Partner Ambassador/MVP
Partner Ambassador/MVP

Hi there!

I wish you could attend my lecture on Set Analysis and AGGR at the Masters Summit for Qlik - in one of my examples, I'm teaching just that - how to build a Histogram with an aggregated expression. Check out our schedule this fall, maybe you can join...

In a nutshell - a calculated dimension requires an array of values. The AGGR() function generates an array, but then the Avg() turns it into a single number. For your needs, you should drop the Avg() and leave the AGGR().

In order to get a bar chart with a reasonable number of bars, perhaps you want to round the results of AGGR() to the desired level. For example, rounding to 10 will give you 10 bars in your chart.

Cheers,

 

Ask me about Qlik Sense Expert Class!
paulinhok14
Creator
Creator
Author

Hey Oleg, thanks for your answer!

Not even knowing what you kindly said: "a calculated dimension requires an array of values. The AGGR() function generates an array, but then the Avg() turns it into a single number", I've just managed to reach the solution removing Avg() from dimension.

And now reading your comment, everything makes sense. I appreciate, thank you for making it clear!