www.mikrocontroller.net

Forum: Digitale Signalverarbeitung / DSP TigerSHARC 12bit ADC -> float


Autor: guest (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,

bisher habe ich noch keine Idee wie man schnell und komfortabel Werte 
eines 12bit ADCs, die im Zweierkomplement in signed ints vorliegen und 
Spannungen zwischen -10 und +10 V repräsentieren, nach float (single) 
konvertieren kann. Damit wird dann weiter gerechnet und zu einem 
späteren Zeitpunkt geht es über das 2er Komplement wieder zurück in 
einen DAC.

Google hat mir nicht helfen können. Zur Not muss ich die 2er Komplemente 
manuell zerlegen und umrechnen aber ich hoffe dass es auch einfacher 
geht...

Habt ihr einen Tipp für mich? Sonst muss ich

Grüße

Autor: Mark Brandis (markbrandis)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Das Beispiel hier ist zwar MATLAB und nicht C, aber vom Prinzip her ja 
das Gleiche:

http://www.s3.kth.se/signal/grad/smart_impl/downlo...

function y_float=Int2float(x_int)

% Function to be used when debugging linear assembler.

x_rem=x_int;
% Obtain 32bit-pattern

Bits=zeros(1,32);
if (x_int<0)
  Bits(1)=1;
  x_rem=x_rem+2^31;
end;

ip=2;
for i1=30:-1:0
   if ~(x_rem<(2^i1))
     Bits(ip)=1;
     x_rem=x_rem-2^i1;
   end;   
   ip=ip+1;
end;


e=sum(Bits(2:9).*(2.^(7:-1:0)));
f=sum(Bits(10:32).*(2.^(-(1:23))));

y_float=(1-2*Bits(1))*(2^(e-127))*(1+f);

Autor: Andreas Schwarz (andreas) (Admin) Benutzerseite Flattr this
Datum:

Bewertung
0 lesenswert
nicht lesenswert
x*(10.0/(2<<11))

Autor: guest (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Danke für die Vorschläge. Aufgabe ist gelöst :)

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.