Comments (6)
Agreed. Will look into this one. Thanks for the example!
from rust-decimal.
So there is definitely an underflow happening with addition whereby the last bit exceeds the allocated 96 bit storage space at that scale. While I could panic, I feel like this should rather work and instead round to 8314.622985886882835357072470
.
If I did this and instead provided checked functions would this help your case?
from rust-decimal.
Looking at some other libraries output it appears that rounding (or losing precision) in this case is the de facto. For consistency I think this is what I'll implement however do want to consider functions and cases whereby this loss of precision is unacceptable.
from rust-decimal.
rounding the last decimal places and loosing a tiny bit of precision sounds like a good solution for cases like this.
i can imagine there are users that don't want to silently loose even a tiny bit of precision and would like to know when overflow/rounding occurs. the checked functions sound like a good solution.
how do we ensure that there are no further cases like this, where an overflow silently results in completely wrong results? you describe the crate as suitable for financial calculations
. in financial applications errors like this could have pretty bad consequences.
i'd have more confidence in the crate if it tested common math invariants using something like https://github.com/BurntSushi/quickcheck. happy to add some quickcheck tests if you agree.
from rust-decimal.
QuickCheck looks interesting - I'd be happy to get this included. How would you intend on utilizing it?
from rust-decimal.
I'm going to pull implementing QuickCheck into a new issue so I can close this one once it's fixed.
from rust-decimal.
Related Issues (20)
- Update borsh crate due to a security vulnerability issue. HOT 4
- Can't deserialize with `float_option` when null in an internally tagged enum HOT 3
- `trunc_with_scale` issue HOT 4
- `serde-arbitrary-precision` without `serde-float` HOT 7
- `is_integer` has BUG HOT 1
- How to serialize Decimal and still keep the results in order (bitwise comparison) HOT 3
- Serialization V2 - brainstorming HOT 1
- feature request: JSON schema support via https://github.com/GREsau/schemars HOT 1
- Feature Request: Support wasm_bindgen for Decimal
- rlp (de)serialization? HOT 2
- Rust Decimal: Request for additional repository Owner/Collaborator(s) HOT 1
- Rescaling a value with significant scale 28 to scale 29 creates a value with scale 29 and overflows on subtraction HOT 1
- Support for mongo HOT 2
- To f64 losing accuracy for `100000.000000000000000000` HOT 1
- Scaling string representation differs from dividing by 10^x HOT 4
- too rubbish to called rust decimal HOT 3
- checked_powd takes exponentially long time to complete HOT 6
- Scale changes unexpectedly after operations HOT 3
- 1.34.0 breaks with cyclic dependency when installed with "macros" feature HOT 4
- Deserializing `Decimal`s from Postgres using the `db-postgres` feature can lead to invalid `Decimal` instances HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from rust-decimal.