Forum: Mikrocontroller und Digitale Elektronik Q-Format umrechnung


von Matthias H. (streno)


Lesenswert?

Hallo zusammen,

ich habe eine kurze Frage zum Q-Format.

Ich rechne mit Q3.12

Ich habe z.B. 2.5 und möchte diese ins Q-Format umwandeln:

Also 2.5*2^12 bzw 2.5<<12 und erhalte 10240.

Soweit so gut habe ich das verstanden.

Jetzt möchte ich das meinen µC machen lassen währrend der Laufzeit.

Ich habe also float a=2.5

Bei dem Befehl
1
 int ergebnis= a<<12
 meckert er. Ich weiß allerdings nicht wie ich das umschreiben soll.

Vielleicht iat diese Frage einfach, aber ich weiß hier gibt es jemanden 
der eine ANtwort weiß.

Danke und viele Grüße
Matthias

von Chris (Gast)


Lesenswert?

int16_t x;
x=(uint16_t)(2.5*pow(2,12));

so sollte das funktionieren.
Schiebe-Operationen geht nur mit Binärzahlen nicht mit float oder 
double.

von Helmut L. (helmi1)


Lesenswert?

Matthias H. schrieb:
> Bei dem Befehl int ergebnis= a<<12

12 mal nach links schieben ist aber auch x 4096 nehmen.

also  ergebnis = (int)(a * 4096.0)

von Matthias H. (streno)


Lesenswert?

Helmut L. schrieb:
> 12 mal nach links schieben ist aber auch x 4096 nehmen.
>
> also  ergebnis = (int)(a * 4096.0)

Oh gott, ja natürlich...

Danke für die Antworten!

von (º°)·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.· (Gast)


Lesenswert?

> Jetzt möchte ich das meinen µC machen lassen währrend der Laufzeit.

Solche Ansinnen werden die Groesse des kompilierten Programms
deutlichst wachsen lassen.

Protipp: Pruefen ob float reicht. Dann muss/darf aber nichts
anderes als 2.5f und aehnliches auftauchen.
Mann ahnt gar nicht wo sich doubles ueberall verstecken koennen.

Besser: Solche Wandlungen in ein oder mehrere Festkommaoperationen
stueckeln.

von Jim M. (turboj)


Lesenswert?

(º°)·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.·´¯`·.¸¸.· schrieb im Beitrag 
#5083935:
> Mann ahnt gar nicht wo sich doubles ueberall verstecken koennen.

Der AVR-GCC kennt AFAIK kein Double und nimmt immer float als Fallback.

Richtig blöd ist das mit den Double auf Cortex-M4F, denn dort sind nur 
die float Berechnungen in Hardware möglich - in C schiesst man sich 
dadurch gerne in den Fuss mit einem vergessenen f am Ende einer Zahl...

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.