Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
Delphi 10.2 Tokyo Professional
|
AW: Mal wieder HexToFloat
6. Jul 2017, 16:34
Falls es sich doch um ein 16-Bit Float handeln sollte habe ich mal was gebaut.
Ist sicherlich nicht das schönste auf der Welt, aber funktioniert soweit ich das getestet habe:
EDIT: Diese Version ist fehlerhaft! Ein paar Posts weiter unten ist die korrigierte Version!
Delphi-Quellcode:
function HexToFloat16(hex: String): Single;
function FractionToFloat(frac: Cardinal): Single;
var i: Integer;
begin
Result := 0;
for i:=0 to 10 do
begin
if (frac shr (10-i)) <> 0 then
Result := Result + Power(2, -(11-i));
end;
end;
var tmp: Word;
resultBin: Cardinal;
sign: Cardinal;
exp: Cardinal;
frac: Cardinal;
begin
tmp := StrToInt('$' + hex);
frac := (tmp and $3FF);
exp := ((tmp shr 10) and $1F);;
sign := (tmp shr 15);
if (exp = $1F) then
begin
if (frac = 0) then
begin
if (Sign = 0) then
Result := Infinity
else
Result := NegInfinity;
end
else
Result := NaN;
end
else
if (exp = 0) then
begin
if (frac = 0) then
begin
if (Sign = 0) then
Result := 0
else
Result := -0;
end
else
begin // Subnormals
if (sign = 0) then
Result := Power(2,-14) * FractionToFloat((frac shl 1) + 1)
else
Result := -Power(2,-14) * FractionToFloat((frac shl 1) + 1);
end;
end
else
begin
resultBin := (frac shl 13) or ((exp - 15 + 127) shl 23) or (sign shl 31);
Move(resultBin, Result, SizeOf(Cardinal));
end;
end;
Michael "Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
Geändert von Neutral General ( 7. Jul 2017 um 11:16 Uhr)
|