mikrocontroller.net

Forum: Mikrocontroller und Digitale Elektronik Probleme Division mit Negativen Werten


Autor: Montero (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo zusammen.

Habe ein kleinen Problem mit der Division von Netagiven werten.
Ich hab zwei Integerwerte welche ich nach in Double umwandle, das
Funktioniert noch. Nun ist es möglich das einer der beiden Werte oder
beide Werte negativ sein können. Anstatt ein Negativer Wert erhalte ich
eine gewaltige Zahl.

Example

x_axes und y_axes sind zwei signed integer
x_axes2 und y_axes2 und resultat sind double

nun mache ich folgendes

x_axes2=(double)x_axes;
y_axes2=(double)y_axes;

resultat=y_axes2/x_axes2;

Nun, sind die beiden Werte Positiv klappt alles.

ist y_axes = -30 und x_axes = 16 erhalte ich 4367.066
ist y_axes = -8 und x_axes = 29 erhalte ich 0.00044
ist y_axes = -8 und x_axes = -25 erhalte ich 1.00026

Compiler ist AVRGCC auf einem ATMEGA8

Ich danke schonmal für eure Tipps.

Autor: Philipp Sªsse (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
1. double ist m.W. nur float beim avrgcc; sollte hier aber egal sein
2. Wenn Du die Werte erst in Fließkommavariablen speicherst, würde
   würde ich mir die doch einmal ausgeben lassen, dann weißt Du
   immerhin schon mal, ob die Seltsamkeit bei der Umwandlung in
   float passiert oder bei der Division
3. Nur zur Sicherheit: hast Du Dir wirklich gut überlegt, ob Du
   die Fließkommedivision nicht vermeiden kannst. In fast jedem
   Fall tut es auch eine Fixkommadivision, die dem mega8 viel
   besser gefällt. Oder sie läßt sich gar ganz vermeiden!

Autor: Montero (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Mit den Werten berechne ich den arcustangens. Aber du hattest Recht! Hab
übersehen das der Fehler schon bei der Wandlung und nicht bei der
Division auftritt. Vielen Dank für die Hilfe.

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.