Bug 410988

Summary: Bad math when multiplying
Product: [Plasma] kdeplasma-addons Reporter: S. Christian Collins <s_chriscollins>
Component: calculatorAssignee: Nisarg <nisshah1499>
Status: RESOLVED FIXED    
Severity: normal CC: kde, nate, nisshah1499
Priority: VHI Keywords: junior-jobs
Version: 5.16.4   
Target Milestone: ---   
Platform: Neon   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:

Description S. Christian Collins 2019-08-16 14:28:42 UTC
STEPS TO REPRODUCE
1. In the calculator widget, multiply 62 x 1.3.

OBSERVED RESULT
The calculator widget gives the answer "8.06e1".

EXPECTED RESULT
The answer should be "80.6".

SOFTWARE/OS VERSIONS
OS: KDE neon 5.16 User Edition
KDE Plasma Version: 5.16.4
KDE Frameworks Version: 5.61.0
Qt Version: 5.12.3
Comment 1 Nate Graham 2019-08-16 14:50:36 UTC
Wow.
Comment 2 2wxsy58236r3 2019-08-17 03:35:05 UTC
"8.06e1" is theoretically correct (8.06 x 10^1 = 80.6), but it is not necessary to use scientific notation in this case because the widget has enough space to display the number.
Comment 3 Christoph Feck 2019-09-09 14:23:16 UTC
Since it is using binary instead of decimal arithmetic, the result is probably 80.6000000000000001 or something similar. For "long" results, it decides to use scientific notation.

It should always round to 15 significant decimal digits before any further processing, because IEEE double precision is limited.

I haven't checked if number.toString() offers options for precision.

https://cgit.kde.org/kdeplasma-addons.git/tree/applets/calculator/package/contents/ui/calculator.qml#n244
Comment 4 Nisarg 2019-10-03 17:31:12 UTC
Is this issue still on to work on this?
Comment 5 Nate Graham 2019-10-03 18:25:18 UTC
Yes, please feel free to work on this if you'd like!
Comment 6 Nisarg 2019-10-04 04:13:33 UTC
(In reply to Nate Graham from comment #5)
> Yes, please feel free to work on this if you'd like!

Yes I would like to work on this issue. Please assign this issue to me. Thanks!!
Comment 7 Nisarg 2019-10-07 04:34:44 UTC
(In reply to Nate Graham from comment #5)
> Yes, please feel free to work on this if you'd like!

What is the mailing list or IRC Channel for this project where I can discuss my doubts and ask questions?
Comment 8 Nate Graham 2019-10-07 04:42:53 UTC
plasma-devel@kde.org
Comment 9 Nisarg 2019-10-08 13:11:36 UTC
Can I get the link of few resources to learn Qt. Actually I am new to KDE so I have just set up the development environment and I tried to learn Qt, but I can't find some good resources?
Comment 10 Nate Graham 2019-10-08 14:51:13 UTC
(In reply to Nisarg from comment #9)
> Can I get the link of few resources to learn Qt. Actually I am new to KDE so
> I have just set up the development environment and I tried to learn Qt, but
> I can't find some good resources?
https://community.kde.org/Get_Involved/development#New_to_C.2B.2B.2FQt_software_development.3F
Comment 11 David Edmundson 2020-01-14 22:38:54 UTC
>I haven't checked if number.toString() offers options for precision.

No, it doesn't.
Comment 12 David Edmundson 2020-01-15 00:36:18 UTC
Git commit a51086867c0f0f7e19b0dd2b9d59657542c46901 by David Edmundson.
Committed on 15/01/2020 at 00:36.
Pushed by davidedmundson into branch 'master'.

[applets/calculator] Use Qt's in-built number formatting

Summary:
Gets rid of a load of code.
Correctly handles floating point issues.
Results are correct.

Potentially this inadvertedly introduces a behaviour change
of including group separators depending on locale. This could be
considered a good thing, but if it's problematic we can always add a
.replace() at the end of this line.

Test Plan:
62 * 1.3 = 80.6

100000000 * 5000000 = 5e+17
(with whatever the right number of zeroes is)

42 * 1.33333 = 6.6666665

Reviewers: #plasma

Subscribers: plasma-devel

Tags: #plasma

Differential Revision: https://phabricator.kde.org/D26676

M  +2    -18   applets/calculator/package/contents/ui/calculator.qml

https://commits.kde.org/kdeplasma-addons/a51086867c0f0f7e19b0dd2b9d59657542c46901