JLI Spieleprogrammierung Foren-Übersicht JLI Spieleprogrammierung

 
 FAQFAQ   SuchenSuchen   MitgliederlisteMitgliederliste   BenutzergruppenBenutzergruppen 
 medals.php?sid=49e61e241d0b3952e575662f0464926bMedaillen   RegistrierenRegistrieren   ProfilProfil   Einloggen, um private Nachrichten zu lesenEinloggen, um private Nachrichten zu lesen   LoginLogin 

float-Genauigkeit

 
Neues Thema eröffnen   Neue Antwort erstellen    JLI Spieleprogrammierung Foren-Übersicht -> Fragen, Antworten und Kritik
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen  
Autor Nachricht
Mat
Senior JLI'ler


Alter: 36
Anmeldedatum: 17.09.2005
Beiträge: 205
Wohnort: Koblenz
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 10:17    Titel: float-Genauigkeit Antworten mit Zitat

Hey,

es ist ja bekannt, das Variablen vom Typ float bei Rechenoperationen ungenau sind.
Ich sitze derzeit jedoch an einer Anwendung, wo diese Ungenauigkeit zum Tragen kommt.

Es scheitert leider an so kleinigkeiten wie hier:
CPP:
_Zoom -= ZOOM_SPEED; // Abweichung von Ergebnis 0,000477%
_Zoom *= 100.f; // Abweichung von Ergebnis 0,000008%
_Zoom = abs(_Zoom);
_Zoom /= 100.f;


Die erste Zeile alleine errechnet eine Ungenauigkeit von 0,000477%. Wenn ich dann das Ergebnis runde (hier kommt es nur auf die 2. Stelle hinter dem Komma an - wie der Code zeigt) hält sich die Ungenauigkeit in Grenuen (nurnoch 0,000008%) -> gibt es evtl. einen Variablentyp oder spezielle Funktionen, mit denen ich Exakte Werte erhalte ?
_________________
- - - - - - - - - - - - - - - - - - - -
-> http://www.sea-productions.de
-> http://www.krawall.de
- - - - - - - - - - - - - - - - - - - -
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden Website dieses Benutzers besuchen
manu
Super JLI'ler


Alter: 35
Anmeldedatum: 09.03.2006
Beiträge: 327
Wohnort: allgäu (DE)
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 10:37    Titel: Re: float-Genauigkeit Antworten mit Zitat

Mat hat Folgendes geschrieben:
Hey,

es ist ja bekannt, das Variablen vom Typ float bei Rechenoperationen ungenau sind.
Ich sitze derzeit jedoch an einer Anwendung, wo diese Ungenauigkeit zum Tragen kommt.

Es scheitert leider an so kleinigkeiten wie hier:
CPP:
_Zoom -= ZOOM_SPEED; // Abweichung von Ergebnis 0,000477%
_Zoom *= 100.f; // Abweichung von Ergebnis 0,000008%
_Zoom = abs(_Zoom);
_Zoom /= 100.f;


Die erste Zeile alleine errechnet eine Ungenauigkeit von 0,000477%. Wenn ich dann das Ergebnis runde (hier kommt es nur auf die 2. Stelle hinter dem Komma an - wie der Code zeigt) hält sich die Ungenauigkeit in Grenuen (nurnoch 0,000008%) -> gibt es evtl. einen Variablentyp oder spezielle Funktionen, mit denen ich Exakte Werte erhalte ?


exakte werte wirst du nie erhalten Wink
3/9.2 ist exakt
0,326086956521 nicht Wink ^^

aber wenn mich nicht alles täuscht ist double doch etwas genauer...
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
Maxim
Senior JLI'ler



Anmeldedatum: 28.03.2004
Beiträge: 249

Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 10:53    Titel: Antworten mit Zitat

ja, double ich genauer. die ganze ungenauigkeit liegt an dem internen aufbau von float und double.
wenn du es wirklich genau haben willst, dann schau dir das an:
http://cplus.kompf.de/artikel/gmp.html
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
PeaceKiller
JLI Master


Alter: 36
Anmeldedatum: 28.11.2002
Beiträge: 970

Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 11:23    Titel: Antworten mit Zitat

Und wenn du`s ganz genau haben willst kannst du long double verwenden.
_________________
»If the automobile had followed the same development cycle as the computer, a Rolls-Royce would today cost $100, get a million miles per gallon, and explode once a year, killing everyone inside.«
– Robert X. Cringely, InfoWorld magazine
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden Website dieses Benutzers besuchen
Mat
Senior JLI'ler


Alter: 36
Anmeldedatum: 17.09.2005
Beiträge: 205
Wohnort: Koblenz
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 12:26    Titel: Antworten mit Zitat

long double verwende ich teilweise auch schon - kann zwar viele Stellen hinter dem Komma fassen, hat aber sehr ähnliche Probleme mit der Genauigkeit wie float.
http://cplus.kompf.de/artikel/gmp.html sieht interessant aus, außerdem überlege ich, einfach eine Bruchklasse zu schreiben, so dass Ungenauigkeit wenn überhaupt bei einer einzigen Division eintreten.

Danke Wink
_________________
- - - - - - - - - - - - - - - - - - - -
-> http://www.sea-productions.de
-> http://www.krawall.de
- - - - - - - - - - - - - - - - - - - -
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden Website dieses Benutzers besuchen
AFE-GmdG
JLI MVP
JLI MVP


Alter: 45
Anmeldedatum: 19.07.2002
Beiträge: 1374
Wohnort: Irgendwo im Universum...
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 12:41    Titel: Antworten mit Zitat

In den allermeisten Fällen sollte Float eine ausreichende Genauigkeit haben, wenn diese nicht reicht, kann man noch auf Double zurückgreifen. mit 63 Bit Verarbeitungslänge ist Double allerdings nicht mehr so schnell wie ein 16 Bit Float. Long Double verwendet meines Wissens nach 128 Bit, ist aber im Vergleich zu Double mindestens 4x langsamer.
Wenn du wie in deinem Fall nur 2 Nachkommastellen benötigst würde ich versuchen, die Berechnung auf Integer-Basis durchzuführen und im letzten Schritt den Int in ein Float umrechnen... (FloatVal = IntVal / 100.0f)
_________________
CPP:
float o=0.075,h=1.5,T,r,O,l,I;int _,L=80,s=3200;main(){for(;s%L||
(h-=o,T= -2),s;4 -(r=O*O)<(l=I*I)|++ _==L&&write(1,(--s%L?_<(L)?--_
%6:6:7)+\"World! \\n\",1)&&(O=I=l=_=r=0,T+=o /2))O=I*2*O+h,I=l+T-r;}
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden Website dieses Benutzers besuchen
GreveN
JLI Master


Alter: 38
Anmeldedatum: 08.01.2004
Beiträge: 901
Wohnort: Sachsen - Dresden
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 12:59    Titel: Antworten mit Zitat

AFE-GmdG hat Folgendes geschrieben:
In den allermeisten Fällen sollte Float eine ausreichende Genauigkeit haben, wenn diese nicht reicht, kann man noch auf Double zurückgreifen. mit 63 Bit Verarbeitungslänge ist Double allerdings nicht mehr so schnell wie ein 16 Bit Float. Long Double verwendet meines Wissens nach 128 Bit, ist aber im Vergleich zu Double mindestens 4x langsamer.
Wenn du wie in deinem Fall nur 2 Nachkommastellen benötigst würde ich versuchen, die Berechnung auf Integer-Basis durchzuführen und im letzten Schritt den Int in ein Float umrechnen... (FloatVal = IntVal / 100.0f)

Argh... was meinst du mit 63 Bit Verarbeitungslänge? Double dürfte auf den meisten heutigen Plattformen 64 Bit lang sein, 1 Bit Vorzeichen, 52 Bit Mantisse und 11 Bit Exponent, wirklich langsamer muss es nicht sein, hängt eben von der CPU-Architektur ab. Float wird wohl auf keiner gängigen Hardware 16 Bit sein, sondern 32 Bit - 1 Bit Vorzeichen, 23 Bit Mantisse, 8 Bit Exponent - das schreibt der IEEE 754-Standard vor. Long-Double ist auf den meisten Plattformen 80 Bit groß, mindestens jedoch 78, aber das gibt IEEE 754 nicht genau vor.

Float bietet 7-8 Stellen Genauigkeit, Double 15-16 und Long-Double 19-20.
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden Yahoo Messenger MSN Messenger
AFE-GmdG
JLI MVP
JLI MVP


Alter: 45
Anmeldedatum: 19.07.2002
Beiträge: 1374
Wohnort: Irgendwo im Universum...
Medaillen: Keine

BeitragVerfasst am: 29.04.2007, 19:13    Titel: Antworten mit Zitat

Stimmt wohl. So genau hatte ich die Bitanzahl wohl nicht mehr im Kopf.
Hab die Bits durcheinandergewürfelt - tut mir leid.
Trotzdem ist eine Long Double Berechnung wesentlich langsamer als Double, da für ihre Berechnung mehrere CPU-Schritte in Microcode notwendig sind, während Floats noch komplett in die Prozessorregister passen. Bei Doubels muss auch schon gesplittet werden, wenn man nicht schon einen neuen 64-Bit-Prozessor hat... (und das Programm für 64 Bit Kompiliert wurde)
_________________
CPP:
float o=0.075,h=1.5,T,r,O,l,I;int _,L=80,s=3200;main(){for(;s%L||
(h-=o,T= -2),s;4 -(r=O*O)<(l=I*I)|++ _==L&&write(1,(--s%L?_<(L)?--_
%6:6:7)+\"World! \\n\",1)&&(O=I=l=_=r=0,T+=o /2))O=I*2*O+h,I=l+T-r;}
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden Website dieses Benutzers besuchen
DirectXer
Dark JLI'ler



Anmeldedatum: 05.02.2005
Beiträge: 1201
Wohnort: Köln
Medaillen: Keine

BeitragVerfasst am: 04.05.2007, 19:06    Titel: Antworten mit Zitat

ich hatte vor etwas längerer zeit mal dasselbe problem, vllt hilft dir das ja weiter: http://www.jliforum.de/board/viewtopic.php?t=4527&highlight=apfloat

Gruß DXer
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden
Beiträge der letzten Zeit anzeigen:   
Neues Thema eröffnen   Neue Antwort erstellen    JLI Spieleprogrammierung Foren-Übersicht -> Fragen, Antworten und Kritik Alle Zeiten sind GMT
Seite 1 von 1

 
Gehe zu:  
Du kannst keine Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum nicht antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.


Powered by phpBB © 2001, 2005 phpBB Group
Deutsche Übersetzung von phpBB.de

Impressum