![]() |
Single wert ist unterschiedlich obwohl gleich
Versuch 1:
Delphi-Quellcode:
Ich weise diesen wert zu und schicke ihn an meine DLL.
const
SCALE_DEFAULT = 0.68;
Delphi-Quellcode:
gSprFace.GD_SetObjectScale(ID, SCALE_DEFAULT);
In der DLL jedoch kommt dieser wert an "0,68000000715" Wenn ich nun vergleiche
Delphi-Quellcode:
dann wird mir True zurückgegeben logisch der wert aus der DLL ist mehr als 0.68 (Aber er wird zum weg in die DLL verändert) also Falsch!
if (rScale > SCALE_DEFAULT) then
Denn wie man sehen kann habe ich einen anderen übergeben. Versuch 2:
Delphi-Quellcode:
Ich weise nun exakt diesen wert zu (der zur DLL verändert wird) und schicke ihn an meine DLL.
const
SCALE_DEFAULT = 0.68000000715;
Delphi-Quellcode:
gSprFace.GD_SetObjectScale(ID, SCALE_DEFAULT);
In der DLL kommt dieser wert an "0,68000000715" den ich auch übergeben habe. Wenn ich nun vergleiche
Delphi-Quellcode:
if (rScale > SCALE_DEFAULT) then
dann wird mir True zurückgegeben warum wenn beide werte gleich sind ? Zwei Problem treten auf. 1. Schicke ich den ersten wert mit 0.68 dann wird dieser zu 0,68000000715 verändert 2. Schicke ich nun exakt diesen wert zu wird bei der Abfrage ebenfalls true zurück gegeben. Kann ich nicht nachvollziehen. gruss |
AW: Single wert ist unterschiedlich obwohl gleich
Der Wert für 0.68 als Single ist 0.680000007152557373046875. Also ist er in der DLL richtig.
Wie ist rScale deklariert? Der Ausdruck `rScale > SCALE_DEFAULT` wird je nach Compiler als Double oder Extended ausgewertet. Speichere die Differenz mal als Single und schau das Ergbenis an. Wie gesagt: die Auswertung erfolgt mit Double/Extended, hier die Werte für Double
Code:
und für Extended
0.68000000715 -> 0.68000000714999997430965095190913416445255279541015625
0.68 -> 0.68000000000000004884981308350688777863979339599609375
Code:
0.68000000715 -> 0.68000000715000000000524243981558925042918417602777481079102
0.68 -> 0.68000000000000000000650521303491302660404471680521965026855 |
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
Zitat:
Hatte noch nie so ein Problem. OK habe es selbst herausgefunden. Danke!
Delphi-Quellcode:
Noch nie ein ähnliches Problem gehabt.
const
SCALE_DEFAULT: single = 0.68; gruss |
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
Delphi-Quellcode:
oder wahrscheinlich besser definiere SCALE_DEFAULT als single
tmpsingle := rScale - SCALE_DEFAULT;
if tmpsingle > 0 then ...
Delphi-Quellcode:
const
SCALE_DEFAULT: single = 0.68; |
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
Delphi-Quellcode:
gruss
const
SCALE_DEFAULT: single = 0.68; |
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
|
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
Danke trotzdem. Die kleine Abfrage hat bei mir 35% CPU Auslastung verursacht weil es immer true war. gruss |
AW: Single wert ist unterschiedlich obwohl gleich
Wenn das an einer Stelle wichtig ist, würde ich immer zusätzlich zum Vergleich IsZero benutzen um mit einem genügend kleinen Epsilon die Gleichheit auszuschließen.
|
AW: Single wert ist unterschiedlich obwohl gleich
Single = 7-8 signifikante Dezimalstellen, also im Wost-Case nur 7.
Die erste Signifikante ist von links die erste Nicht-Null. 0.68000000715 Selbst Schuld, wenn du einen Wertebereich haben willst, der nichtmals Ansatzweise in den Datentyp passt. Und selbst wenn, dann sind auch innerhalb der Signifikanten Rundungsfehler möglich, vor allem bei gewissen unendlich langen Werten ala 2/3. Single hat einen 8 Bit-Exponent und eine Mantisse von 23 Bit Länge, inkl. einem virtuellen Bit, wenn der Exponent 0 ist, also 24. 2^24 = 16.777.215 = nicht ganz 8 Dezimalstellen (nur 1. bis 7. können alles von 0 bis 9 sein) |
AW: Single wert ist unterschiedlich obwohl gleich
Zitat:
Nun gut wenn du das sagst ist es wohl so. Zitat:
Und wer erstellt diese? Genau! Delphi. Ich habe übergeben 0.68 und Delphi mach daraus deinen unendlich langen Werten 0.68000000715 lese doch bitte nochmal was ich geschrieben habe. Zitat:
Wie gesagt.. Ich habe 0.68 übergeben und erwarte eigentlich das dieser wert auch berechnet wird. gruss |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:16 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz