Hallo, ich verwende einen F28069 von Texas Instruments, um mit der SGEN Signal Generator Library einen Sinus zu erzeugen. Die Library benutzt eine Lookup-Tabelle im Q15-Datenformat (Die Amplitude ist also zwischen -1 und 1). Die positive Halbwelle des Sinus durchläuft in der Tabelle dementsprechend den Dezimalbereich von 0 bis ~32k, während die negative Halbwelle den Bereich von 65k bis 32k durchläuft. Ich hab also einen Wertesprung zwischen den Halbwellen. Das generierte Signal soll nun über SPI an einen DAC übertragen werden. Der DAC übernimmt dabei nicht die Werte im Q-Format, sondern die gespeicherten Integer-Werte der Tabelle. Als Ausgangssignal ergibt sich dadurch der vertikal verschobene Sinus, was natürlich unerwünscht ist. Wie ließe sich denn theoretisch das Datenformat so verändern, dass ich einen astreinen Sinus in Uint16 bekomme? Gibt es eine Möglichkeit Q15 nach Uint16 zu konvertieren? Oder wäre es am einfachsten, einfach die Tabelle umzuschreiben? Da ich Neuling in diesem Gebiet bin, ist für mich die Lösung leider nicht so offensichtlich. Hier ist ein Link zu der Tabelle: http://read.pudn.com/downloads93/sourcecode/embed/367628/Rectifier/SINTB360.asm__.htm
Der 28069 ist ein 16-Bitter. Also einfach eine union ueber den Q15 und und den Uint16 legen. Naeheres verraet ein C-Buch.
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.