As usually when trying to develop a certain new functionality or model, in QlikView™ or other software, I enjoy starting with a prototype that has a pretty simple set of data behind.
Some times I load this set of data using some short LOAD * INLINE , while in other occasions, when a data set with more cases is required, especially one that I am aware I will need to extend, I choose to have some Excel files/sheets as data sources.
LOAD * INLINE [
Dimension
1
2
30
40
50
600
700
800
900
];
We’ve started with the regular approach: a calculated dimension CLASS (Dimension,BoundaryDistance) and a pretty simple function in the expression: count(Dimension) over a bar chart.
And this gave me a pretty easy to predict answer:
data:image/s3,"s3://crabby-images/fe823/fe8239803ae36a01801903c34a4c6e348dab7ff7" alt=""
data:image/s3,"s3://crabby-images/a2805/a2805f8a798b44f576be8a37d4d9d51b1c8c026b" alt=""
data:image/s3,"s3://crabby-images/10a02/10a02e63a4f675c27dcc2b95ac158a93f495ca49" alt=""
=dual(
pow(10,floor(log10(Dimension),1))
& ‘<=x<‘
& pow(10,ceil(log10(Dimension),1))
,class(log10(Dimension),1, ‘Dimension’)
)
data:image/s3,"s3://crabby-images/e7668/e7668496d81ea5c58590ab89516f4c47e5489a73" alt=""
All nice there with a small exception: the first interval seems pretty strange ! (1<=x)
data:image/s3,"s3://crabby-images/84068/840685e593640de9c2ec57e99ca503b477b04fbc" alt=""
Now, looking at the last 2 figures, it’s clear where the problem of the first bucket is coming from: we are attempting to use log(o) within the calculation steps of the first value within the calculated dimension.
But log(o) is minus infinite and therefore the calculation is going wild !
=dual(
if( pow(10,ceil(log10(Dimension),1))=1
, 0&'<=x<‘&10
,pow(10,floor(log10(Dimension),1))
&'<=x<‘
& pow(10,ceil(log10(Dimension),1))
)
,class(log10(Dimension),1)
)
data:image/s3,"s3://crabby-images/1fd38/1fd381085da0010149342acb2739baa58c309892" alt=""
=dual(
if( pow(10,ceil(log10(Dimension),Variable1))=1
, 0&'<=x<‘&10
,pow(10,floor(log10(Dimension),Variable1))
&'<=x<‘
& pow(10,ceil(log10(Dimension),Variable1))
)
,class(log10(Dimension),Variable1 ))
data:image/s3,"s3://crabby-images/85c26/85c266e5a54276f28be762043345abd70d1120f6" alt=""
and like this for Variable=2:
data:image/s3,"s3://crabby-images/7da16/7da16bf8b4237c0ca12f037814fa8b006f82ee15" alt=""
if( pow(10,ceil(log10(Dimension),Variable1))=1
, 0&'<=x<‘& pow(10,Variable1) ,pow(10,floor(log10(Dimension),Variable1)) &'<=x<‘ &pow(10,ceil(log10(Dimension),Variable1))
) ,class(log10(Dimension),Variable1
))
data:image/s3,"s3://crabby-images/0650e/0650efca1b5249d3030833b688ab61f73cb5774c" alt=""
data:image/s3,"s3://crabby-images/786dd/786ddff67caf417c61b75e20b37440ecbc4f668a" alt=""
data:image/s3,"s3://crabby-images/64299/64299198016f51a828c780bf10120cf29241c1d2" alt=""
- the calculated dimension option within QlikView™ is a pretty wild and powerful option, no doubt about it !
- using small data prototypes to start from is always a wise idea !
- try to “beautify” as much as possible your formulas and scripts ! (aka structure your code)
- CEIL and FLOOR are so valuable !
- saluting the LOG10() function. I kind of missed a LOG2() variation of this in some smart Gauge boundary limitations… (if anyone interested on this matter, let me know within a comment