Hallo, ich habe ein Problem. Ich möchte ein Char Array in ein float bzw. double Wert Konvertieren. Ich meinem Array habe ish folgendes stehen: 101234.1239 Jetzt wandle ich mit atof den Wert um. Als Ergebnis erhalte ich aber 101234.1171 Gibt es eine andere Möglichkeit die Konvertierung genauer hinzubekommen? mfg. Frank
Frank B. schrieb: > float bzw. double Das ist ein himmelweiter Unterschied. float ist auf 6 … 7 Dezimalstellen genau, double auf 14. Deine gewünschte Auflösung lässt sich nur mit double realisieren.
Frank B. schrieb: > Gibt es eine andere Möglichkeit die Konvertierung genauer hinzubekommen Nein. Das ist die nächstliegende binäre float-Zahl an deiner Dezimalzahl, und dann wieder bei der Rückumwandlung die nächstliegende Dezimalzahl zu dem binären float. Musst du halt double verwenden oder BCD Arithmetik
Fritz Fischer schrieb: > Oder mit 10000 multiplizieren und als integer 32 oder 64 > weiterrechnen. Einen String multiplizieren?
Die Zahl .1239 (und damit auch 101234.1239) ist überhaupt nicht binär repräsentierbar, denn es wäre eine periodische Zahl, d.h. egal wie viele binär-Ziffern man hinzufügt ist es immer noch nicht genau, egal ob man float, double, long double... verwendet. Ist letztlich genau wie 1/3, was sich im Dezimalsystem auch nicht mit (endlich vielen) Ziffern darstellen lässt. Wenn man die Zahl als "double" speichert und "direkt" z.B. mit printf("%f") ausgibt, sieht es zwar so aus als wäre die Zahl korrekt gespeichert, aber das stimmt nicht - printf rundet hier standardmäßig. Gibt man sie mit voller Präzision aus ("%.17f") sieht man die Abweichung. Das Problem ist also nicht lösbar. Wenn du alle rationalen Zahlen darstellen möchtest, musst du Nenner und Zähler speichern. Wenn du nur alle dezimal darstellbaren Zahlen speichern können möchtest (also z.B. nicht 1/3), reicht eine Dezimal-Float/Fixed-Darstellung. Wenn du diese Zahl gar nicht absolut exakt darstellen möchtest sondern die Abweichung von ca. 0.000000000006 okay ist, nimm einfach "double".
Stefan ⛄ F. schrieb: > Achtung, der avr-gcc kennt nur float. Double ist dort in Wirklichkeit > float. Das war so bis v9. Ab v10 wird auch 64-Bit (long) double unterstützt: http://gcc.gnu.org/gcc-10/changes.html#avr
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.