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?
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" :-)
Schneehexe schrieb: > Vorzeichen -------> 1bit > Mantisse ---------> 24bit > Exponent ---------> 7bit > ========================== > Summe ------------> 32bit
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.
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.
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?
> ...buskompatibel machen.
Zu welchem Bus sollen die Daten gesendet werden?
Mein alter Berufsschullehrer hat immer minimisieren gesagt. xD
Ich würde die Zahl auf einen Zettel schreiben und diesen durch den Bus zum Empfänger tragen.. .
Vielleicht so ähnlich? http://www.mikrocontroller.net/articles/Plattformunabh%C3%A4ngige_Programmierung_in_C#.C3.9Cbertragung_zwischen_Ger.C3.A4ten
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.
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.
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.