Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rounding errors in tax calculation #147

Closed
davidgeary opened this issue Sep 5, 2014 · 6 comments
Closed

Rounding errors in tax calculation #147

davidgeary opened this issue Sep 5, 2014 · 6 comments

Comments

@davidgeary
Copy link

The inherently inexact nature of floating point numbers used for the pricing values is resulting in rounding errors in the calculation of the tax values for certain totals/tax rates.

For example, using a subtotal amount of 302.00 and a tax rate of 0.2 (for GB VAT), the calculation of the tax value at these lines is:

302.00 * 0.2 = 60.400000000000006

The following lines are commented as explicitly rounding partial cents up, but this also means that floating point rounding errors are rounded up. In the above example, the tax therefore becomes 60.41 which will be an obvious error to the end-user.

(Performing all calculations in cents might be a more robust way to resolve this, though perhaps a pragmatic approach may simply be to truncate the tax value to, say, 4 decimal places before rounding up? This would still account for partial cents, but minimize the inclusion of floating point errors being included.)

@chrissrogers
Copy link
Member

Mm yes, lovely JS floating point rounding issues. Definitely aware of the Math troubles here. I think the most robust solution would be to use a library specifically designed to handle these Number issues, finally representing them as Strings -- which makes more sense to me because these final values are primarily intended for display purposes.

@davidgeary
Copy link
Author

It's irrelevant that they're primarily for display purposes. If our customers see that we can't even calculate a simple sum like that correctly, they're hardly going to trust us with their money.

The arithmetic is fundamentally wrong here - how can fixing that be considered an enhancement, rather than a bug? Isn't getting the math right a pretty basic expectation from a financial billing company?

@chrissrogers
Copy link
Member

@davidgeary I agree with you -- it's a bug. As for my comments about type changes, that was simply an aside. The crux of the issue lies in using a more robust mathematical implementation than Number allows.

@chrissrogers
Copy link
Member

In order to address the issue at hand, I implemented truncation to the 6th decimal during tax summation. This should resolve the issue as described.

I'd like to dog-ear a more robust solution involving a reliable BigDecimal (or similar) implementation.

The commit closed this issue .. I'll be sure to add a note here once a version containing the fix has been released.

@chrissrogers
Copy link
Member

This is in v3.0.6. As soon as that changes from pre-release to release, it will be available from our CDN.

@chrissrogers
Copy link
Member

Hi! This patch has been deployed to our CDN. I will create a new issue shortly detailing planned efforts to clean up the way we treat decimal values.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants