How can I increase the precision if I have around 45,000.

In an multinomial expansion I have 45,000 terms to add. The result should be less than 1. However due to addition of so many terms the error also gets magnified; and gives random deviations of significant values in the result. Using double() doesn't help either.

2 Comments

Using "double()" instead of what? Please describe the input data more explicitly.
I mean instead of calculating F=f(x)+g(x); I use F=double(f(x))+ double(g(x))

Answers (2)

I'm not sure if I understand the problem correctly: You calculate the summ and suffer from the limited accuracy? This would be one effect of the nature of the sum, which is numerical instable. As workaround you can increase the precision to 128 or 196 bit floating point accumulation using the "Knuth" methods in: FEX: XSum.

1 Comment

Yes; that's right, i suffer from a limited accuracy. for so many terms even if I write a multinomial series which should result in 0; I was getting around 10000. whereas for lower number of terms I get the right answer which is 0.
And do you have the matlab code for XSum also?
Yes; that's right, i suffer from a limited accuracy. for so many terms even if I write a multinomial series which should result in 0; I was getting around 10000. whereas for lower number of terms I get the right answer which is 0.

This question is closed.

Asked:

on 9 Jul 2013

Closed:

on 20 Aug 2021

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!