mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik ATmega8: Divison durch 1000


Autor: Christoph H. (arrow)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hi,
ich möchte in Assembler (mit ATmega8) folgende Berechnung machen:
y = k*1,125
wobei k ganzzahlig ist und einen Wert von 500 bis 10.000 annehmen kann.

Natürlich kann man das Komma zunächst ignorieren, mit einer 16-bit 
Multiplikation arbeiten, das Ergebnis durch 1000 teilen und anschließend 
die Nachkommastellen wegwerfen (diese Genauigkeit reicht hier aus).

Die 16-bit Multiplikation ist dabei kein Problem, es gibt es ja genügend 
Beispiele, aber wer kann mir bei der Division durch 1000 helfen und wie 
werde ich die Nachkommastellen los? Oder gibt es vielleicht eine andere, 
elegantere Lösung?
Danke im Voraus.

Autor: der mechatroniker (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Da steht doch

y = k * (9/8),

gleichwertig mit  (Assoziativgesetz der Multiplikation)

y = (k * 9) / 8.

Durch 8 zu teilen heißt shiften.

Autor: Kevin K. (nemon) Benutzerseite
Datum:

Bewertung
0 lesenswert
nicht lesenswert
y = k + k shr 3

Autor: Stefan Ernst (sternst)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Und wenn du dazwischen auch noch 4 addierst, hast du auch noch ein 
gerundetes Ergebnis.

Autor: ich (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
0,125 ist zufällig 1/8
also:
y = k + k/8

und k/8 ist eine eifache Schiebeoperation um 3 Stellen nach rechts

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.