Rundungsfehler bei Float-Werten

Felder und Variable vom Typ Float (Gleitkomma) werden in den meisten Applikationen für die Speicherung und Verarbeitung von numerischen Daten verwendet, die Nachkommastellen benötigten. Das Format entspricht dem "IEEE 754 double"-Format und belegt 8 Bytes pro Wert. Die Vorteile dieses Variablentyps sind der große Wertebereich (-1.0E307 bis +1.0E307), die ausreichende Genauigkeit (15 Stellen) und die zahlreichen mathematischen Funktionen, die für diesen Typ zur Verfügung stehen. Darüberhinaus ist auch ein binärer Datenaustausch mit anderen Programmen möglich.


Ein Nachteil dieser Gleitkomma-Werte besteht in der binären Kodierung. Während bei ganzzahligen Variablen immer eine exakte Umrechnung von Binär nach Dezimal und umgekehrt möglich ist, gilt dies nicht für Nachkommastellen, die ja einen Bruchteil von 1 darstellen. Beispielsweise ist ein 1/3 nicht mit einer endlichen Zahl dezimaler Nachkommastellen exakt darstellbar (0,3333333….), bei binären Werten ist dies ähnlich. Während es sich bei dezimalen Nachkommastellen um Zehntel, Hunderstel, Tausendstel etc. von 1 handelt, repräsentieren binäre Nachkommastellen die Hälfte, ein Viertel, Achtel, Sechzehntel, Zweiundreißigstel etc. von 1.

Daher lassen sich bestimmte Dezimalwerte nicht als exakte Binärwerte darstellen, die Zahl 17.33 entspricht als Float-Wert eher der Zahl 17,329999999999998. Die Zahl 17.35 liegt dagegen bei 17,350000000000001. Da die Abweichungen zunächst nur an der letzten Stelle auftreten, erscheint der Rundungsfehler vernachlässigbar. Bei einer größeren Anzahl von Rechenschritten kann die Ungenauigkeit jedoch zunehmen, wodurch bei größeren Werten mit vielen Vorkommastellen bereits Abweichungen nach wenigen Stellen hinter dem Komma auftreten können. Viel gefährlicher sind jedoch Funktionen, die die Nachkommastellen einfach abtrennen, wie beispielsweise trn(). trn(17.31 * 100.0) liefert nicht den Wert 1731 sondern 1730 – das Resultat von 17.31 * 100.00 ist 1730,9999999999999, nach Abschneiden der Nachkommastellen verbleibt nur noch 1730. Bei Einsatz der Rundungsfunktion ist das Ergebnis dagegen korrekt: rnd(17.31 * 100.00) liefert 1731.

Als Resümee der Rundungsproblematik sind für den Entwickler zwei Dinge wichtig: Erstens ist der Einsatz der Funktion trn(), ceil(), floor() und fract() auf die Fälle zu beschränken, in denen die Auswirkung von Nachkommadifferenzen berücksichtigt werden. Zweitens sollten Zwischenresultate mittels rnd() auf die erforderlichen Nachkommastellen gerundet werden, um einer schleichende Zunahme von Abweichungen zu begegnen.

Klicken Sie hier, um die Nutzungsbedingungen für unseren Blog zu lesen.

Eine Antwort

Schreiben Sie einen Kommentar

Ihre E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Leave the field below empty!

Terms of use of the comment function in the blog

1. General information

Vectorsoft AG (‘Provider’) provides a public blog for Internet users (‘Users’) on the vectorsoft.de website. The public blog is intended for the exchange of information and ideas. Users who participate with contributions and comments undertake to comply with the blog terms of use and are responsible for the accuracy, appropriateness and freedom from legal infringements of their contributions. By using the comment function in our blog, you accept these terms of use.

2. Netiquette

We ask you to refrain from personal attacks and provocations based on other opinions. Please argue objectively and maintain a constructive discussion culture. Your comment should always be related to the topic in question in order to avoid digressions into other topics. Posting the same comment or several similar comments more than once is not permitted.

3. Prohibition of illegal content

By submitting your comment, you confirm that you are not violating any copyrights or other rights of third parties. Inciting, racist statements, instructions for criminal offences and their glorification, depictions of violence, pornographic content and statements that violate personal rights are prohibited.

4. No advertising

The use of the comment function is not permitted for commercial or party-political purposes. Advertising contributions of any kind will be deleted immediately.

5. Details of the name

When entering your name, pay attention to the principles mentioned above.

6. Source references

If you intend to publish quotes or contributions from third parties, please indicate the respective sources and explain how they relate to the blog post.

7. Violation of the terms of use

Posts that violate this policy will be deleted immediately. If you notice any violations yourself, please send us the link to the comment in question by e-mail to . We expressly point out that we will exclude individual users in the event of repeated or serious violations of these terms of use.

As of: Sept. 2024

Nutzungsbedingungen der Kommentarfunktion im Blog

1. Allgemeines

Vectorsoft AG („Anbieter“) stellt für Internetnutzer („Nutzer“) auf der Website
vectorsoft.de einen öffentlichen Blog bereit. Der öffentliche Blog dient dem
Informations- und Gedankenaustausch. Die Nutzer, welche sich mit Beiträgen und
Kommentaren beteiligen, verpflichten sich dazu, die Blog-Nutzungsbedingungen
einzuhalten und tragen die Verantwortung für die Richtigkeit und Angemessenheit
sowie Freiheit von Rechtsverletzungen ihrer Beiträge. Mit Nutzung der
Kommentarfunktion in unserem Blog akzeptieren Sie diese Nutzungsbedingungen.

2. Netiquette

Wir bitten Sie von persönlichen Angriffen und Provokationen aufgrund anderer
Meinungen abzusehen. Bitte argumentieren Sie sachlich und bewegen Sie sich auf
der Basis einer konstruktiven Diskussionskultur. Ihr Kommentar sollte stets im
Zusammenhang mit dem jeweiligen Thema sein, um Ausschweifungen in andere
Themenbereiche zu vermeiden. Das mehrmalige Posten desselben Kommentars
oder mehrerer ähnlicher Kommentare ist nicht erlaubt.

3. Verbot rechtswidriger Inhalte

Mit Absenden Ihres Kommentars bestätigen Sie, dass Sie keine Urheberrechte oder andere Rechte Dritter verletzen. Volksverhetzende, rassistische Äußerungen, Anleitungen zu Straftaten und deren Verherrlichung, Gewaltdarstellungen, pornografische Inhalte und Äußerungen, die Persönlichkeitsrechte verletzen sind untersagt.

4. Keine Werbung

Die Nutzung der Kommentarfunktion ist für kommerzielle oder parteipolitische
Zwecke nicht erlaubt. Werbliche Beiträge aller Art werden von uns umgehend
gelöscht.

5. Angaben zum Namen

Bei der Eingabe Ihres Namens achten Sie auf die zuvor genannten Grundsätze.

6. Quellenangaben

Bitte geben Sie bei der beabsichtigten Veröffentlichung von Zitaten oder Beiträgen
Dritter die jeweiligen Quellen an und erläutern dessen Bezug zum Blogbeitrag.

7. Verstoß gegen die Nutzungsbedingungen

Beiträge, die gegen diese Richtlinie verstoßen werden umgehend gelöscht. Sollten
Sie selbst Verstöße bemerken, so senden Sie uns bitte den Link des betreffenden
Kommentars per E-Mail an . Wir weisen ausdrücklich daraufhin, dass wir einzelne Nutzer bei wiederholten oder schweren Verstößen gegen diese
Nutzungsbedingungen ausschließen werden.

Stand: Sept. 2024

Get your Trial Version now!

Test yeet free of charge

Deine Trial Version - jetzt anfordern!

Teste yeet - unverbindlich und kostenfrei

IHRE EVALUIERUNGSLIZENZ - JETZT ANFORDERN!

TESTEN SIE DIE CONZEPT 16 VOLLVERSION - UNVERBINDLICH und KOSTENFREI

Melden Sie sich bei unserem Newsletter an

Anrede*
     
Zustimmung zur Datenverarbeitung gem. DSGVO*



WordPress Cookie-Hinweis von Real Cookie Banner