byte to float

stehohrhase

Mitglied
Hallo zusammen

ich möchte mir aus 4 Byte eine Floatzahl zusammenbauen,
was aber nicht so recht funktionieren will.

Dazu habe ich folgendes gemacht:

Java:
float f = ((ibuf[0]& 0x00FF) << 24) + ((ibuf[1]& 0x00FF) << 16) + ((ibuf[2]& 0x00FF) << 8) + (ibuf[3]& 0x00FF);
System.out.println(f);

Für die Werte (00, 00, 65, -64) erhalte ich 16832 (soll aber 24),
für die Werte (00, 00, -63, 32) erhalte ich 49440 (soll aber -10),
für die Werte (00, 00, 67, 2) erhalte ich 17154 (soll aber 130).

Wenn ich zum Testen eine fertige Software verwende, wo ich die Darstellung wählen kann,
dann bekomme ich bei der Auswahl "long AB CD" meine falschen Werte angezeigt.
Wähle ich "float CD AB", dann bekomme ich die richtigen Werte (soll) angezeigt.

Muss ich das noch mal wandeln, oder mache ich den Fehler schon beim zusammenstellen ?

Habe alle Varianten versucht.. passt nix.. Hat jemand einen Tip ?

Gruß, stehohrhase
 
Zuletzt bearbeitet:

X5-599

Top Contributor
Warum soll bei 65, -64 eine 24 rauskommen? Das ist mir nicht klar. Wenn ich nachrechne komme ich auf: 16832.

Code:
0000 0000 0100 0001 == 65 dez
0000 0000 1111 1111
&-verknüpft--------
0000 0000 0100 0001

<<8
0100 0001 0000 0000            ---+
                                  |
                                  +--> 0100 0001 0000 0000  == 16640 dez
                                  +--> 0000 0000 1100 0000  ==   192 dez
0000 0000 1100 0000 == -64 dez    |
0000 0000 1111 1111               |
&-verknüpft--------               |
0000 0000 1100 0000            ---+
 

kay73

Bekanntes Mitglied
ich möchte mir aus 4 Byte eine Floatzahl zusammenbauen,
was aber nicht so recht funktionieren will.
... denn in Wirklichkeit baust Du ein (vorzeichenbehaftetes) int, das nach float konvertiert wird. Die Bit-Darstellung von Fließkommazahlen ist gänzlich anders und es ist ein erheblicher Aufwand das von Hand zu implementieren. Java hat eine solche Konvertierung zum Glück eingebaut: Float.inBitsToFloat (Auch für Double). Deine Bytes stimmen auch, es sind allerdings HIWORD und LOWORD vertauscht,
Java:
System.out.println(String.format("%04X", Float.floatToIntBits(24.0f)));
System.out.println(String.format("%04X", Float.floatToIntBits(-10.0f)));
System.out.println(String.format("%04X", Float.floatToIntBits(130.0f)));
ergibt:
Code:
41C00000 (41h = 65, C0h = 192 - 256 = -64) 
C1200000 (C1h = 193 - 256 = -63, 12h = 32)
43020000 (43h = 67, 02h = 2)
 
Zuletzt bearbeitet:

stehohrhase

Mitglied
Hier ist ein Dokument dazu (Seit 7 und 8):
http://martens-elektronik.com/datenblatt/de/Modbus_Schnittstelle.pdf

Auf der 8. Seite geht es um die Zahl –17,479. Kriege die nicht hin.

Habe es mit diesen beiden Varianten probiert:

Java:
float x = ((0xD4 & 0x00FF) << 24) + ((0x96 & 0x00FF) << 16) + ((0xC1 & 0x00FF) << 8) + (0x8B& 0x00FF);
float y = ((0xC1 & 0x00FF) << 24) + ((0x8B & 0x00FF) << 16) + ((0xD4 & 0x00FF) << 8) + (0x96& 0x00FF);
System.out.println(x);
System.out.println(y);
 

stehohrhase

Mitglied
... denn in Wirklichkeit baust Du ein (vorzeichenbehaftetes) int, das nach float konvertiert wird. Die Bit-Darstellung von Fließkommazahlen ist gänzlich anders und es ist ein erheblicher Aufwand das von Hand zu implementieren. Java hat eine solche Konvertierung zum Glück eingebaut: Float.inBitsToFloat (Auch für Double). Deine Bytes stimmen auch, es sind allerdings HIWORD und LOWORD vertauscht,
Java:
System.out.println(String.format("%04X", Float.floatToIntBits(24.0f)));
System.out.println(String.format("%04X", Float.floatToIntBits(-10.0f)));
System.out.println(String.format("%04X", Float.floatToIntBits(130.0f)));
ergibt:
Code:
41C00000 (41h = 65, C0h = 192 - 256 = -64) 
C1200000 (C1h = 193 - 256 = -63, 12h = 32)
43020000 (43h = 67, 02h = 2)

Dein Antwort hat sich mit meiner Frage Überschnitten. DANKE !
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Datentypen Byte, Float und Boolean Java Basics - Anfänger-Themen 13
T Operatoren Float in byte umwandeln Java Basics - Anfänger-Themen 3
O 64bit- OS byte, short, int oder long bzw. float oder double? Java Basics - Anfänger-Themen 13
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
I Dateigröße von einem InputStream oder byte[] bekommen Java Basics - Anfänger-Themen 2
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
G ImageIcon in Byte-Array ablegen Java Basics - Anfänger-Themen 7
D Best Practice Parameter int vs byte Java Basics - Anfänger-Themen 16
J RSA Verschlüsselung Testen / byte[] in Objekt umwandeln Java Basics - Anfänger-Themen 1
S Byte-Array kann chars speichern? Java Basics - Anfänger-Themen 3
N Datentypen Image zu Byte-Array Java Basics - Anfänger-Themen 4
F byte, short oder doch int? Java Basics - Anfänger-Themen 6
S Performance von byte[], short[], int[]..? Java Basics - Anfänger-Themen 24
D Methoden int to byte array und zurück? Java Basics - Anfänger-Themen 5
P int zu byte Java Basics - Anfänger-Themen 8
F Byte Array wachsen lassen Java Basics - Anfänger-Themen 5
M Java Klasse Byte Java Basics - Anfänger-Themen 10
F Byte Ausgabe plötzlich falsch Java Basics - Anfänger-Themen 0
V String in Byte umwandeln Java Basics - Anfänger-Themen 11
O Input/Output Ein (negatives) Byte über PrintWriter hinausschreiben Java Basics - Anfänger-Themen 3
T byte[] zu String mit Sonderzeichen Java Basics - Anfänger-Themen 2
W Nullpointer bei Objekt Serialisierung mit ArrayList<byte[]> etc. Java Basics - Anfänger-Themen 2
J byte - Ausgabe Java Basics - Anfänger-Themen 2
F Teil eines Byte Array an eine Methode übergeben Java Basics - Anfänger-Themen 5
J Byte Folge erkennen Java Basics - Anfänger-Themen 5
M sehr großes Byte Array Java Basics - Anfänger-Themen 3
M Byte Array und Co. Java Basics - Anfänger-Themen 12
Y File to byte[] and byte[] to sysout Java Basics - Anfänger-Themen 3
P Wann Byte-Stream und wann Character-Stream? Java Basics - Anfänger-Themen 11
F Hexfolge in Byte Array ersetzen Java Basics - Anfänger-Themen 8
P String in byte konvertieren, wie? Java Basics - Anfänger-Themen 4
T Erste Schritte Byte Java Basics - Anfänger-Themen 3
R byte[] zu String und Ausgabe Java Basics - Anfänger-Themen 2
H Variablen short <-> byte[] Java Basics - Anfänger-Themen 15
X Datentypen String in byte[] Java Basics - Anfänger-Themen 29
H Variablen 32bit Zählwert als Byte-Array Java Basics - Anfänger-Themen 9
H Variablen string nach byte Java Basics - Anfänger-Themen 12
B Frage zur Effizienz von read und read(byte[]) Java Basics - Anfänger-Themen 23
R Erste Schritte Rechnenoperationen mit byte, short und char Java Basics - Anfänger-Themen 8
V Datentypen Frage zum Datentyp Byte Java Basics - Anfänger-Themen 11
L Byte[] to String, doch bits sind gespiegelt (MSB/LSB) Java Basics - Anfänger-Themen 3
S Von byte[] nach String zurueck nach byte[]. Arrays sind nicht identisch :( Java Basics - Anfänger-Themen 6
S ArrayList<Byte> in String umwandeln Java Basics - Anfänger-Themen 5
V unsigned byte? Java Basics - Anfänger-Themen 27
M byte Array Mindestlänge Java Basics - Anfänger-Themen 19
U short[] nach byte[] Java Basics - Anfänger-Themen 11
D [jni] jbytearray <-> byte array Java Basics - Anfänger-Themen 8
S Datentypen Ändern eines byte[] Arrays Java Basics - Anfänger-Themen 4
B byte-weise Verschlüsselung Java Basics - Anfänger-Themen 6
P byte Array aus ImageIcon Java Basics - Anfänger-Themen 10
S Input/Output String in byte umwandeln? Java Basics - Anfänger-Themen 5
F von Byte zu 2 Stellig Hex Java Basics - Anfänger-Themen 3
G byte[] (Base64) korrekt übergeben Java Basics - Anfänger-Themen 4
V Jar-Datei von Byte-Array oder Stream laden? Java Basics - Anfänger-Themen 9
G Binär in Byte speichern Java Basics - Anfänger-Themen 7
T Datentypen byte -Division..mal gehts mit cast mal ohne Java Basics - Anfänger-Themen 5
T Datentypen default ist int, cast zu byte nötig... Java Basics - Anfänger-Themen 2
F Byte nach Zahl umwandeln Java Basics - Anfänger-Themen 11
E Datentypen type cast problem (int, byte,) Java Basics - Anfänger-Themen 5
T Datentypen unsigned byte? Java Basics - Anfänger-Themen 9
G Integar zu Byte Java Basics - Anfänger-Themen 4
P Byte mit 0...255? Java Basics - Anfänger-Themen 5
N Datentypen Fehler beim Umwandeln in byte Java Basics - Anfänger-Themen 3
L Umwandlung int <--> byte Java Basics - Anfänger-Themen 2
L Datentypen 250 und byte? Java Basics - Anfänger-Themen 4
L Datentypen byte[] in String und wieder zurück Java Basics - Anfänger-Themen 3
H Datentypen Byte-Array RSA Java Basics - Anfänger-Themen 9
H Datentypen Rechnen mit signed Byte-Array - unsinged byte Java Basics - Anfänger-Themen 3
N Files mit Byte an Socket versenden Java Basics - Anfänger-Themen 2
V Byte -> String -> Byte verlustfrei Java Basics - Anfänger-Themen 12
Hindi93 Byte to Int Java Basics - Anfänger-Themen 4
H Datentypen byte[] to int Java Basics - Anfänger-Themen 9
S hex zu byte Java Basics - Anfänger-Themen 4
M Byte Array: Werte größer 127? Java Basics - Anfänger-Themen 11
S Addition zweier 32 Byte langer ByteArrays Java Basics - Anfänger-Themen 5
H 1 Byte Status Variable Java Basics - Anfänger-Themen 3
P Datentypen Byte und char Typecast Java Basics - Anfänger-Themen 2
M Bit/Byte Operationen Java Java Basics - Anfänger-Themen 8
W Datentypen int -> byte Java Basics - Anfänger-Themen 2
H Datentypen Byte-Array aus Stream lesen Java Basics - Anfänger-Themen 3
F Typenumwandlung byte <=> int verstehen Java Basics - Anfänger-Themen 3
S Byte eines arrays Java Basics - Anfänger-Themen 17
N Frage zu Datentyp byte Java Basics - Anfänger-Themen 14
B unsigned byte Problem Java Basics - Anfänger-Themen 9
S 2 Byte Arrays addieren Java Basics - Anfänger-Themen 45
S Unbekannte Daten einlesen, speichern und in einem byte Array speichern Java Basics - Anfänger-Themen 3
S Alle Datentypen in byte Array und zurückwandeln Java Basics - Anfänger-Themen 2
H Frage zu Byte-Streams Java Basics - Anfänger-Themen 2
Z Wie Byte[] in einen String oder int konvertieren Java Basics - Anfänger-Themen 2
0 byte[] -> hex Java Basics - Anfänger-Themen 2
G char[] in byte[] konvertieren? Java Basics - Anfänger-Themen 2
V Byte Arrays in Strings umwandeln und splitten Java Basics - Anfänger-Themen 2
M unsigned byte Java Basics - Anfänger-Themen 4
F Byte 0 und 1 einzelnd zuweisen? Java Basics - Anfänger-Themen 17
G byte [] aus uRL erhalten Java Basics - Anfänger-Themen 11
J Byte-Array als Hex-Datei speichern? Java Basics - Anfänger-Themen 9
G Hex to Byte Java Basics - Anfänger-Themen 13
S Byte in Zahl umwandeln Java Basics - Anfänger-Themen 3
M Double-Wert in Byte[] umwandeln Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben