-
Notifications
You must be signed in to change notification settings - Fork 53
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
dtostrf convertig error #429
Comments
Nice find. Do you know if correct expected output is documented anywhere on Arduino.cc? I have not attempted to confirm this yet. |
That simply uses
|
Actually, looking at it, it's not quite that simple. I mis-read your values - 1.4000 != 1.04...! So this looks like the formatting isn't working, and is dropping leading zeros from the fractional part (it splits it into integer and fractional components then prints "%d.%d" of them). Maybe that second |
Yes this is exactly why i opened the issue, i written an interpollation function and had wondering why it is not correct. Do to String funktion also seem to use the dtostrf function it should be improved. @JacobChrist as majenkotech mentioned the return values are incorect, indepent from Arduino.cc |
Ah, I missed that. Formatting is not the issue. |
It would be great to have a fix for this. Anybody have time to submit a PR? |
I'd like to port dtostrf from avr-libc if possible. |
Very good. Let me know if you have a PR that needs testing and I'll help
out. Thanks for working on this Matt.
…On Fri, Jun 29, 2018 at 5:51 PM, Majenko Technologies < ***@***.***> wrote:
I'd like to port dtostrf from avr-libc if possible.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#429 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AAbeCBPZQtCkrXQUnMSAvj4Ln1woLzChks5uBq96gaJpZM4U3Flh>
.
|
Unfortunately, However I have just come across this implementation which is in pure C, using sprintf. Could be improved to use snprintf instead for greater security... and maybe improved formatting. |
I'm sure it can be shrunk down to just this:
There would be a more efficient way of doing it that doesn't rely on snprintf, such as taking portions of |
Ok, trimming is not needed, the Arduino defaults to 2 decimal places only, which threw me. Also snprintf needs an extra space in the width for NULL which dtostrf doesn't include. So with a bit of trial and error it's now formatting the same (ish). |
@pgunzelmann @JacobChrist Matt just pushed up some new code that should completely fix this issue. Can either of you confirm that the changes fix the reported issue? |
I haven't heard back from anybody that Matt's change fixed things for you, but I'm going to assume that it did, so I merged the change in. A new core version will be coming shortly which will include this change, so I'll close the issue then. |
example simplified to show only the problem:
Leads as output at serial using ATmega2560 Meaga to
1.04
but on chipKIT MAX32 to
1.40000
i tried to work arround useing the dtostrf function, but unfortunately the same occurance.
please try to simulate and may confirm or to reject
The text was updated successfully, but these errors were encountered: