Конвертировать 64-битные шестнадцатеричные в плавающие в PHP

Я пытаюсь преобразовать 64-битное шестнадцатеричное число в число с плавающей точкой в ​​PHP.

40F82C719999999A

Если я запускаю это на странице преобразования IEEE-754 с плавающей запятой по адресу http://babbage.cs.qc.cuny.edu/IEEE-754.old/64bit.html он преобразуется в:

99015.100000000000

Какой номер я ищу. Но я не могу добраться до этого числа в PHP. Я пытался использовать различные комбинации pack() и unpack(), но я не близко.:(

2 ответа

function hex2float($strHex) {
    $hex = sscanf($strHex, "%02x%02x%02x%02x%02x%02x%02x%02x");
    $hex = array_reverse($hex);
    $bin = implode('', array_map('chr', $hex));
    $array = unpack("dnum", $bin);
    return $array['num'];
}

$float = hex2float('40F82C719999999A');
echo $float;

вернет 99015.1

Как преобразовать обратно плавающий в 64-битный гекс:

function float2hex($num) {
    $bin = pack("d", $num);
    $hex = array_map('ord', str_split($bin));
    $hex = array_reverse($hex);
    $strHex = vsprintf("%02x%02x%02x%02x%02x%02x%02x%02x", $hex);
    return $strHex;
}
$hex = float2hex(99015.100000000000);
echo strtoupper($hex);

вернется 40F82C719999999A

Другие вопросы по тегам