This is what we would want.A trendline in Business Objects.
data:image/s3,"s3://crabby-images/1b966/1b96627dc07b728686d7dcdaee11248691fc3b65" alt="image image"
It is not possible to let Business Objects insert a trendline in a chart automatically. It’s a feature that is simply missing. This is what I have been living with until now, it simply isn’t possible, end of story. And that makes me rebel. I want to make it possible.
Two problems : I’m not a real good mathematician. The math to achieve trendlines isn’t easy math either.
But, good news, I figured it out – and it works. Over the next few articles, I will hand you the math to add trendlines to your charts.
Our first type of trendline : A LINEAR TRENDLINE
The functions Excel uses to calculate that trendline looks like this :
data:image/s3,"s3://crabby-images/526ca/526ca088c43a6ca60b6c45f627d24d44b3bafeae" alt=""
and this
data:image/s3,"s3://crabby-images/170f7/170f76582a695c78d6252dc1b9a32925584c6ec0" alt=""
That’s the sort of math that makes my head spin – but after 5 minutes, I figured out how it works and then it’s easy. In case you don’t know, the x and y with a dash over their heads are averages.
The first function gets you the “direction-coëfficiënt”, the second gives you the interception point. Both are needed to calculate the trend.
Step1:
Calculate the average on both X and Y.
data:image/s3,"s3://crabby-images/fff95/fff9551997d1d12ed3bae327ef20524d948a0f87" alt="image image"
In this case, I used the formula : Average(<Sales revenue) in Report. If you don’t know what the “in Report” stands for, you should have a look at the articles about contexts. It’s not an easy subject.
With that, we have the average of Y and we also need the average of X. This might be a bit strange. Basically, you just need to find the middle of the X-axis of your chart.
So, we need to count how many items there are and find the middle of that. In fact, for our 12 months the middle is not 6 but 6,5 because it’s an even number of lines. So, what I end up doing is using a runningcount function :”=RunningCount(<Month)” Which I then take an average on.
data:image/s3,"s3://crabby-images/fee95/fee95e577ae0375e6b0b81598508d2649f5a441d" alt="image image"
the function at the end is : =Average((RunningCount(<Month>) )) In Report. which I define as variable <AverageX>
This means, that at this point, we have the two numbers with the dashes over their heads. Next, we need to subtract the X and Y values from it.
For X, this is : =((RunningCount(<Month>) In <Month>) - <AverageX>) In <Month> which I define as a variable X – AverageX
data:image/s3,"s3://crabby-images/20f75/20f75b9a5926d70c58695291c0121cb1de1e60f9" alt="image image"
Next, we need Y – AverageY
=(<Sales revenue> - <AverageY>) In <Month> which I define as Y – AverageY
data:image/s3,"s3://crabby-images/1fc03/1fc0374d248b3f54f2a9dc4c8143c575d6c91012" alt="image image"
Next, we need to multiply those : =<X - average X>*<Y - AverageY> and add them up.
data:image/s3,"s3://crabby-images/51309/51309084618bdb19d61ea2ec5f9e0d949b9a9b3c" alt="image image"
This gives us the first part of our division, specified at the beginning of this document.
For our second part, we need to Square x-divisionX and add them up.
that’s :=Sum(Power(<X - average X> , 2) In Body) In Report
data:image/s3,"s3://crabby-images/213c3/213c3802757131d7dc5633a6480c24bb21b59fcb" alt="image image"
Last but not least, we need to divide them to get the direction Coëfficient.
data:image/s3,"s3://crabby-images/ab9b2/ab9b24b8a439b598bfeb87008fdbe6c7e3c37246" alt="image image"
Now that we calculated b, we can proceed to calculate
data:image/s3,"s3://crabby-images/170f7/170f76582a695c78d6252dc1b9a32925584c6ec0" alt=""
This translates to :
=<AverageY> - (<AverageX>*<coefficient>)
and that’s our “Intercept” which amounts to the Intercept function in Excel.
data:image/s3,"s3://crabby-images/3fc13/3fc13504bd01afa1c35034ae01092b3c2951a275" alt="image image"
Now we can calculate the values for our Trendline. The function in this case (for a linear Trendline is:
y = mx + b
m = direction coëfficient
b = intercept
data:image/s3,"s3://crabby-images/81464/8146422192dbdaa04894513d7f60208bd3f2bf81" alt="image image"
the x-Value is our runningCount on the month (remember
)
So, now we transform this to a chart :
data:image/s3,"s3://crabby-images/ea316/ea3160f68f0b44b0507c31ea4994b0be7b2ce6c2" alt="image image"
I had a great time trying to figure this one out, so I hope it’s useful to anyone. Next up Logarithmic trendlines. It won’t be easy, I can promise you that data:image/s3,"s3://crabby-images/1714c/1714c15fe1edb3a380ba8b158864602012fe350c" alt="Glimlach"
ah.. last but not least, this is what that trendline looks like in Excel data:image/s3,"s3://crabby-images/1714c/1714c15fe1edb3a380ba8b158864602012fe350c" alt="Glimlach"
data:image/s3,"s3://crabby-images/7c3dc/7c3dc0edcc8ed2181419dbf0b41bfd1e0163e566" alt="image image"
Isn’t that – entirely – identical
Lovely.
Cheers
Binabik