mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik double / float Problem


Autor: Peter Haber (lalido)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo Leute,

ich brauche Informationen bezüglich dem Umgang mit float bzw. double 
Datentypen.

(Ich programmiere auf einem Atmega128 mit AVR Studio.)
Warum erhalte ich bei den unteren Beispielen schon ab der 9. bzw. 8 
Stelle Rundungsfehler? Die Datentypen float und double werden doch mit 4 
Byte (32 bit) dargestellt? Kann mir jemand den Hintergrund erklären?
unsigned char temp[200];
double f=123.1234567;

dtostrf( f, 12, 7, temp);   //Double in String wandeln
printf("\r\n1: %s",temp);
// Ausgabe: 1:  123.1234550 --> an der 9. Stelle ist ein Rundungsfehler aufgetreten

fk=12345678.1234567;
dtostrf( fk, 12, 7, temp);   //Double in String wandeln
printf("\r\n3: %s",temp);
// Ausgabe: 2: 12345677.6142120 --> an der 8. Stelle ist ein Rundungsfehler aufgetreten

Autor: Andreas K. (a-k)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Weil float=double nur auf 7 Stellen genau ist. Vergiss den Exponenten 
nicht, der braucht auch Platz.

Autor: Freizeitbastler (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert

Autor: Peter Haber (lalido)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Vielen Dank für Eure Beiträge!

Das 1. Bit (MSB = Bit 31) gibt das Vorzeichen an.
Die nächsten 8 Bit (Bits 30 downto 23) repräsentieren den Exponent.
Und somit bleiben nur noch 23 Bits für die Mantisse übrig.
(2^23 ergibt 8.388.608 --> also nur 7 Stellen Genauigkeit.)

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.