How to fix the digits for the summation?
2 次查看(过去 30 天)
显示 更早的评论
Dear All, I have a code that finds the percentage of each case from the total population, I have 10 cases and the summation of their percentages must be 100% or 0 for example, but the problem is that I am still getting a summation of 100.01 or 99.99 or 99.98, what is the reason here and how can I fix it please, Notice: I rounded the results into 2 digits before I calculate the summation.
2 个评论
Adam
2019-4-10
It is not possible to store every floating point number precisely so there are errors that accumulate when they are summed (or other operations) which is why you will not get exactly 100 as your answer.
Read up about floating point arithmetic to understand further.
采纳的回答
Star Strider
2019-4-10
See the documentation section on Floating-Point Numbers (link). You are most likely seeing the result of floating-point approximation error. Also, rounding the numbers first loses precision, and likely results in the inaccuracies you get. The solution is not to round the intermediate values, only the results, and the only if necessary.
4 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Logical 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!