Heim Backend-Entwicklung C++ Warum führt Gleitkomma-Arithmetik in C zu Präzisionsfehlern?

Warum führt Gleitkomma-Arithmetik in C zu Präzisionsfehlern?

Nov 04, 2024 pm 01:06 PM

Why Does Floating-Point Arithmetic in C   Lead to Precision Errors?

Gleitkomma-Präzision in C

In C sind Gleitkommazahlen bis zu einer bestimmten Anzahl von Dezimalstellen präzise. Es gibt jedoch Einschränkungen dieser Präzision, die zu unerwarteten Ergebnissen führen können.

Problemstellung

Beachten Sie den folgenden Codeausschnitt:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

<code class="cpp">double a = 0.3;

std::cout.precision(20);

std::cout &lt;&lt; a &lt;&lt; std::endl;

 

// Print 0.2999999999999999889

 

double a, b;

a = 0.3;

b = 0;

for (char i = 1; i &lt;= 50; i++) {

  b = b + a;

};

std::cout.precision(20);

std::cout &lt;&lt; b &lt;&lt; std::endl;

 

// Print 15.000000000000014211

Nach dem Login kopieren

Wie dargestellt, ist a etwas kleiner als 0,3, aber wenn man es mit 50 multipliziert, wird b etwas größer als 15,0. Diese Abweichung vom erwarteten Ergebnis kann auf die Einschränkungen der Gleitkommagenauigkeit zurückgeführt werden.

Lösung

Um die richtigen Ergebnisse zu erhalten, ist es wichtig, die Einstellung zu vermeiden Die Genauigkeit ist höher als die verfügbare Genauigkeit für den numerischen Typ. Der folgende überarbeitete Codeausschnitt demonstriert diesen Ansatz:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<code class="cpp">#include &lt;iostream&gt;

#include &lt;limits&gt;

int main() {

  double a = 0.3;

  std::cout.precision(std::numeric_limits&lt;double&gt;::digits10);

  std::cout &lt;&lt; a &lt;&lt; std::endl;

 

  double b = 0;

  for (char i = 1; i &lt;= 50; i++) {

    b = b + a;

  };

  std::cout.precision(std::numeric_limits&lt;double&gt;::digits10);

  std::cout &lt;&lt; b &lt;&lt; std::endl;

}</code>

Nach dem Login kopieren

Dieser Ansatz stellt sicher, dass die Genauigkeit auf das für den Double-Datentyp maximal verfügbare Maximum eingestellt wird. Es ist wichtig zu beachten, dass der akkumulierte Fehler schließlich spürbar werden würde, wenn die Schleife für eine wesentlich größere Anzahl von Iterationen ausgeführt würde, beispielsweise 5000 statt 50, unabhängig von der Präzisionseinstellung. Dies ist eine inhärente Einschränkung der Gleitkomma-Arithmetik.

Das obige ist der detaillierte Inhalt vonWarum führt Gleitkomma-Arithmetik in C zu Präzisionsfehlern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Mar 03, 2025 pm 05:52 PM

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert?

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte Mar 03, 2025 pm 05:53 PM

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte

GULC: C -Bibliothek von Grund auf neu gebaut GULC: C -Bibliothek von Grund auf neu gebaut Mar 03, 2025 pm 05:46 PM

GULC: C -Bibliothek von Grund auf neu gebaut

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Mar 03, 2025 pm 05:53 PM

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die?

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Mar 03, 2025 pm 05:51 PM

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher?

eindeutiger Gebrauch und Phrasenfreigabe eindeutiger Gebrauch und Phrasenfreigabe Mar 03, 2025 pm 05:51 PM

eindeutiger Gebrauch und Phrasenfreigabe

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Mar 12, 2025 pm 04:50 PM

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)?

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Mar 12, 2025 pm 04:52 PM

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient?

See all articles