Hallo, Gibt es ein Rezept für die ein 16 Bit Wert / 96 Division bei /128 müsste das noch mit LSL und ROR gehen aber bei 96 so glaube ich wird es dann nicht mehr so einfach als Ergebniss benötige ich einen auf ganze Zahlen gerundeten Wert ohne Komma usw.
>Super Klappt Danke
Und was bekommst Du heraus, wenn Dein Wert -1 beträgt?
;-)
Der Divident ist nie kleiner als 600 also dürfte das kein Problem sein.
Dann ist gut. Nur manchmal wissen die Dividenden nicht, daß sie diese Bedingungen einhalten müssen und geben dem Programm ein völlig unerwarteten Verlauf. Dann kann stundenlange Suche angesagt sein. Wenn man das Vorzeichen beachtet, erspart man sich diese Mühe.
oder
Wert * (2^16 / 96) / 2^16 == (Wert * 683) >> 16
Wenn man einen ATMega nimmt hat der eine HW-Multiplikation und die
dürfte dann schneller sein als die vielen Shiftoperationen. Die obige
>>16 Operation kann man sich einsparen, das Zwischenergebnis=Wert * 683
ist ein 32 Bit von dem man nur die obersten 2 bytes als Resulat benutzt,
also implizites Rechtsshift mit 16.
Gruß Hagen
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.