Skip to main content

Kahan Summation Algorithm implementation with python

In numerical analysis, Kahan's algorithm is used to find the sum of all the items in a given list without compromising on the precision. I will first explain the basics of why this algorithm has importance even if you are using python.


To get a hands-on experience, you can open your python interpreter and type the commands along the way.

>>> alist = [0.1]*10
>>> alist
[0.1, 0.1, 0.1, 0.1, 0.1, 0.1, 0.1, 0.1, 0.1, 0.1]
>>> 
As you can see we have created a list with 10 items. For your proof, I have also printed the list alist. There are only 10 0.1's and nothing else. Now see the magic

>>> sum(alist)
0.9999999999999999
>>> 

I have used the inbuilt sum function to find the sum of all the elements in the given list. The expected value is 1.0, but we get 0.9999999999999999, which is approximately equal to 1.0 but not exactly equal to 1.0. Okay if you are not convinced with the above, I sum each and every element separately. Here it goes:

>>> 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1
0.9999999999999999

But why is this happening? This is because of the round off errors that computers make. To eliminate these kinds of rounding off errors that computers make we can use the Kahan's Algorithm. But remember that if precision is not of utmost importance for you then I suggest you use direct summation because Kahan's algorithm will considerably add some time in your performance.

Kahan's Algorithm implementation can be seen below

Program

The program is very small and I think you should plug in some numbers to understand.
Now let us check how correct this program is. We will use the above function and check if we are getting the correct answer.

>>> KahanSum([0.1]*10)
1.0
>>> sum([0.1]*10) == 1.0
False
>>> KahanSum([0.1]*10) == 1.0
True
>>> 

And of course, we are getting the correct answer. I think you are convinced about the use of Kahan's algorithm in programming.

If you want to have accurate summation for a given lists, then don't worry you don't have to write this function. You can import the inbuilt fsum function and this will calculate the summation accurately.

>>> from math import fsum
>>> fsum([0.1]*10)
1.0
>>> fsum([0.1]*10) == 1.0
True
>>> 

To know about the Kahan's algorithm you can see the Wikipedia Kahan Summation algorithm.

As always you can download the files from Github Gist kahan_algorithm.py

If you have any doubt or haven't understood anything then comment in the comment box below and I will be glad to help you.

If you have found any typo please let me know so that I can correct it as soon as possible,

If you have any suggestions or if you have any feedback then please do comment in the comment box below. I will be very happy to see your message.

You can also contact me.

Thank you. Have a nice day😃.

Popular posts from this blog

Project Euler Problem 67 Solution with Python

Maximum path sum II By starting at the top of the triangle below and moving to adjacent numbers on the row below, the maximum total from top to bottom is 23. 3 7 4 2 4 6 8 5 9 3 That is, 3 + 7 + 4 + 9 = 23. Find the maximum total from top to bottom in triangle.txt (right click and 'Save Link/Target As...'), a 15K text file containing a triangle with one-hundred rows.

Problem 43 Project Euler Solution with python

Sub-string divisibility The number, 1406357289, is a 0 to 9 pandigital number because it is made up of each of the digits 0 to 9 in some order, but it also has a rather interesting sub-string divisibility property. Let d 1 be the 1 st digit, d 2 be the 2 nd digit, and so on. In this way, we note the following: d 2 d 3 d 4 =406 is divisible by 2 d 3 d 4 d 5 =063 is divisible by 3 d 4 d 5 d 6 =635 is divisible by 5 d 5 d 6 d 7 =357 is divisible by 7 d 6 d 7 d 8 =572 is divisible by 11 d 7 d 8 d 9 =728 is divisible by 13 d 8 d 9 d 10 =289 is divisible by 17 Find the sum of all 0 to 9 pandigital numbers with this property. One might write a simple solution using direct if else statements for this problem. Using if else statements, the execution time may be a few seconds. But this is not a very good approach. I too had written a program with if else statement which will take each and every permutation of the 0-9 Pandigital and check for the conditions given in the qu...

Add/Embed SVG to Blogger website

In this post I will tell you my method(trick) of adding SVG images in a blogger website or blog. Before starting , the first thin g I am assu m ing is that you are aware of SVG if you are here. If not please see S calable V ec tor G raphics Recently when I tried to embed a SVG image for a post on pygal, I tried uploading the SVG file and blogger Image uploader came up with an error, because of which I had to find some other way.  SVG File upload Error in Blogger  I started sea rc hing Google " Embed SVG in Blogger " . I found blogorrhea , w h ich gave some i nformatio n on add ing SVG directly as a markup , which worked , but I faced another problem using this . Also th is guy has used lot of Javascript which was confusin g for me, being new to using SVG.   So I first t houg ht of learning on h ow to embed SVG in HTML and t his on e worked out. Actually we can embed SVG in HTML i n following ways: Using Object tag Using Iframe tag Using embed...