Forum: PC-Programmierung Transportierung einer Zahl durch einen Bus


von Schneehexe (Gast)


Lesenswert?

Hallo, ich möchte gerne eine Floatzahl durch einen Bus transportieren. 
Dazu muss ich die Zahl durch Binarisierung buskompatibel machen.

Leider weis ich noch nicht so recht, wie ich das machen soll. 
Angenommen, ich habe einen 32-bit breiten Float, dann steht bei 
Wikipedia,

Vorzeichen ------->  24bit
Mantisse --------->   7bit
Exponent --------->   1bit
==========================
Summe ------------>  32bit

Ich würde es jetzt gerne hinbekommen, den Float zu binarisieren. Eine 
Funktion, um aus einem Float ein Binär zu machen, habe ich nicht 
gefunden. Ich habe nur eine Funktion zur Hexadezimalisierung gefunden, 
ich kann also den Float mir als Hexadecimalwert anzeigen lassen. Das 
Ergebnis wird aber in einen String überführt:

float ----------> 2324786.9382746983
umgewandelt ----> 0x1.1bc99781962a4p+21
neuer Datentyp ist aber nicht mehr Zahl, sondern ein String.

Ich weis hier grade nicht weiter, wie ich den Hexwert nun durch einen 
Bus binär senden soll.

Kann mir jemand von Euch helfen?

von Wegstaben V. (wegstabenverbuchsler)


Lesenswert?

input error ... to less information ....

von nix (Gast)


Lesenswert?

Schneehexe schrieb:
> Kann mir jemand von Euch helfen?

Die Zahl in einen String umwandlen, den String bitweise durch den Bus 
schicken und am Ziel wieder "Floatisieren" :-)

von Schaf (Gast)


Lesenswert?

Schneehexe schrieb:
> Vorzeichen ------->   1bit
> Mantisse --------->  24bit
> Exponent --------->   7bit
> ==========================
> Summe ------------>  32bit

von Peter II (Gast)


Lesenswert?

Schneehexe schrieb:
> Ich würde es jetzt gerne hinbekommen, den Float zu binarisieren. Eine
> Funktion, um aus einem Float ein Binär zu machen, habe ich nicht
> gefunden.

einfach memcpy( xx, float, sizeof(float) ) verwenden, schon hat man die 
Binary Daten, das geht auch andersrum genauso.

von Bitflüsterer (Gast)


Lesenswert?

Was man als Float, ASCII etc. bezeichnet ist immer und in jedem Fall 
auch als eine Folge von Bits, z.B. 001010110010111110001101010 zu 
interpretieren. Ob Float, ASCII etc. ist nur eine Frage der 
Interpretation.

Ein Bit 0 kann einer Spannung 0V und ein Bit 1 einer Spannung 5V 
zugeordnet werden. Das ist was auf einem Bus, im Speicher, in Register 
etc. passiert. (Mit Variationen).

Zur Übertragung ist also eine Uminterpretation nicht notwendig.

Und Worte wie "Transportierung", "Binarisierung" existieren schlicht 
nicht.


Bitte stelle Deine Frage unter Berücksichtigung dieser Tatsachen neu.

von Bonner (Gast)


Lesenswert?

Tja... was soll ich sagen. Ich mach mal nicht weiter wie die anderen und 
frag mal wo dein Problem ist. Wo ist genau dein Problem?

Du hast doch schon geschrieben wie dein float aufgebaut ist.
Schick doch erst die 24bit vom Vorzeichen dann die 7bit deiner Mantisse 
und dann dein 1bit Exponent. Falls du damit nichts anfangen kannst musst 
du wohl deine Frage etwas genauer erläutern.

Du trollst oder?

von Bonner (Gast)


Lesenswert?

Das heißt wennschon Transportisierung.

von Helmut S. (helmuts)


Lesenswert?

> ...buskompatibel machen.

Zu welchem Bus sollen die Daten gesendet werden?

von Bonner (Gast)


Lesenswert?

Mein alter Berufsschullehrer hat immer minimisieren gesagt. xD

von Nachtaktiver (Gast)


Lesenswert?

Ich würde die Zahl auf einen Zettel schreiben und diesen durch den Bus 
zum Empfänger tragen.. .

von Fabian O. (xfr)


Lesenswert?


von Rolf M. (rmagnus)


Lesenswert?

Schneehexe schrieb:
> Dazu muss ich die Zahl durch Binarisierung buskompatibel machen.

Die Daten sind schon binär - wie alles, was in einem Computer 
gespeichert ist. Was anderes kann der nämlich gar nicht.

> Leider weis ich noch nicht so recht, wie ich das machen soll.
> Angenommen, ich habe einen 32-bit breiten Float, dann steht bei
> Wikipedia,
>
> Vorzeichen ------->  24bit
> Mantisse --------->   7bit
> Exponent --------->   1bit

Das wäre eine äußerst eigenwillige Anordnung.

von Christian B. (casandro)


Lesenswert?

Ich frag mich immer warum sich die Leute das Leben schwer machen.
Als Austauschformat, und somit auf Bussen, nimmt man am Besten immer 
Text. Binärformate verwendet man nur dann, wenn die sehr gut 
dokumentiert sind und es wirklich schwerwiegende Gründe gibt. Mal so 
einfach "memcopy" von Fließkommazahlen zu machen kann wirklich in die 
Hose gehen, da es noch mehr inkompatible Fließkommazahlformate gibt als 
Integerformate.

von Jürgen S. (jurs)


Lesenswert?

Schneehexe schrieb:
> Leider weis ich noch nicht so recht, wie ich das machen soll.
> Angenommen, ich habe einen 32-bit breiten Float, dann steht bei
> Wikipedia,

Du schreibst es selbst: Deine 4-Byte bzw. 32-bit breite "float" 
Gleitkommazahl besteht aus 4 Bytes bzw. 32 Bits.

Je nachdem, ob Dein Bus Byteweise überträgt oder Bitweise, überträgst Du 
über den Bus 4 Bytes oder du überträgst 32 einzelne Bits.

Mal angenommen der Bus wäre TWI/I2C, dann überträgst Du byteweise die 4 
Bytes, aus denen die Gleitkommazahl als float-Variable besteht.

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.