Forum: Mikrocontroller und Digitale Elektronik runden mit keil und c164


von SiO2 (Gast)


Lesenswert?

Hi, ich möchte gerade zahlen runden lassen, jedoch gibts anscheinend 
keine Rundungsfunktion. Ich habe die math.h eingebunden, jedoch kommt 
nur die Meldung, dass round undefined ist.
Gibts ne andre möglichkeit, ohne sich eine rundungsfunktion selbst zu 
schreiben?

Thnx SiO2

von johnny.m (Gast)


Lesenswert?

> ich möchte gerade zahlen runden lassen
Du meinst vermutlich "ganze Zahlen", also Integer-Werte...

Es gibt da im Prinzip zwei Möglichkeiten:
1.: Zur Zahl 0.5 addieren und dann nach integer konvertieren (das bringt 
aber Gleitkommaarithmetik mit sich und ist nicht sinnvoll, wenn man 
nicht sowieso schon Gleitkommafunktionen im Programm hat, da dies den 
Code extrem aufbläht).

2.: Rundungsprobleme bei Integer-Werten treten eigentlich nur bei 
Divisionen auf. In diesem Fall kann man sich mit einem Trick behelfen: 
Vor der Division den Dividenden mit 2 multiplizieren. Nach der Division 
das Endergebnis mit
Endergebnis = Ergebnis/2 + Ergebnis%2
berechnen. Die Multiplikation mit 2 geht aber nur dann reibungslos, wenn 
sichergestellt ist, dass kein Zahlenbereichsüberlauf stattfindet (also 
wenn gewährleistet ist, dass Dividend*2 und Endergebnis*2 noch im 
Zahlenraum des betreffenden Datentyps sind). Ist das nicht 
gewährleistet, muss man vor der Rechnung auf den nächstgrößeren Datentyp 
casten (bei int also auf long), was aber meist immer noch schneller und 
ressourcenschonender ist als eine Gleitkommaberechnung.

von SiO2 (Gast)


Lesenswert?

Ich arbeite mit Double und divisionen, wo ich am Ende nen long benötige. 
Und das Casten haut ne menge weg. Die einfache Addition von 0.5 ist auch 
nur ne notlösung.
Werde auch mal weiter googlen.

SiO2

von johnny.m (Gast)


Lesenswert?

Wenn Du sowieso in Gleitkomma rechnest, wo liegt dann das Problem? Genau 
in diesem Fall ist doch die Addition von 0.5 die einfachste Lösung... 
Eine Rundungsfunktion, so es sie denn gibt, macht vermutlich auch nichts 
anderes, und wenn doch, dann wahrscheinlich mit wesentlich mehr Code.

von G. Nicht (Gast)


Lesenswert?

>Die einfache Addition von 0.5 ist auch nur ne notlösung.

Stimmt! Negative Werte kann man so nicht runden :-)

Für Faule: sprintf() und dann sscanf().

von johnny.m (Gast)


Lesenswert?

> Stimmt! Negative Werte kann man so nicht runden :-)
Stimmt tatsächlich...

> Für Faule: sprintf() und dann sscanf().
...und für Leute mit zuviel Speicher.

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.