Forum: Compiler & IDEs Float vergleichen


von Jens (Gast)


Lesenswert?

Hallo,
wie kann ich in einer if-abrage zwei Float-Zahlen miteinander 
vergleichen, so dass aber nur die Vorkommastelle verglichen wird?

Danke schonmal im Vorraus

von Sven P. (Gast)


Lesenswert?

Indem du vor dem Vergleich in ein C-Buch deiner Wahl schaust und dich 
über Rundungsmethoden informierst.

$ man trunc

von Grrrr (Gast)


Lesenswert?

Stelle Dir vor, Du müsstest es per Hand machen.
Wie würdest Du vorgehen?
Runden oder Nachkommastellen abschneiden?
Genauso machst Du es dann im Programm.

von Jens (Gast)


Lesenswert?

Habe es jetzt wie folgt gelöst

        int vswr_new = vswr;
        int vswr_cutout_value_new = vswr_cutout_value;

        if (vswr_new >= vswr_cutout_value_new)



ist das geschickt oder eher nicht ?

von (prx) A. K. (prx)


Lesenswert?

Nur dann geschickt, wenn "int" gross genug für alle Werte ist.

von Karl H. (kbuchegg)


Lesenswert?

Jens schrieb:
> Habe es jetzt wie folgt gelöst
>
>         int vswr_new = vswr;
>         int vswr_cutout_value_new = vswr_cutout_value;
>
>         if (vswr_new >= vswr_cutout_value_new)
>
>
>
> ist das geschickt oder eher nicht ?

Das kommt drauf an :-)

Floating Point Rechnereien sind nicht so einfach, wie man das gerne 
hätte oder wie man sich das gemeinhin so vorstellt.

Wenn du zb zu einem Ausgangswert von 0, 10 mal 0.1 dazuzählst
1
  double result = 0;
2
  for( i = 0; i < 10; ++i )
3
    result += 0.1;

dann stehen die Chancen schlecht, dass da exakt 1.0 herauskommt. Wenn in 
deinem Floating Point System da 1.00000001 herauskommt, dann bist du mit 
dem einfachen Abschneiden der Nachkommastellen auf der sicheren Seite.

   int i = result;

bekommt den Wert 1.

Wenn sich aber da ein Wert von 0.99999999999 ergibt, dann ist der für 
praktische Zwecke zwar ebenfalls 1, aber er ist einen winzig kleinen 
Bruchteil kleiner als 1.

   int j = result;

wird zu 0.

Tja. Jetzt hast du ein Dilemma: Dem Buchstaben deiner Definition nach, 
ist der zu 0.999999999 gehörende Integer natürlich 0. Ob dir das aber 
klar ist, wenn du 10 mal 0.1 aufsummierst und dann 0 heraus kommt, ist 
eine andere Frage.

von Karl H. (kbuchegg)


Lesenswert?

Und nein:
Floating Point Arithmetik hat das Problem, dass man sich jeden einzelnen 
Fall genau ansehen muss. Es gibt da kein universal gültiges 
Patentrezept.

von Jens (Gast)


Lesenswert?

Okay... Vielen Dank für euere schnellen Antworten @ Karl heinz 
Buchegger, danke für die ausfühliche Erklärung, da habe ich in der Tat 
nicht weiter drüber nach gedacht :)... nunja dann währe eventuell runden 
doch eher passend....




Danke und Gruß

Jens

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
Noch kein Account? Hier anmelden.