https://mathweb.ru/numberconverter.html?id=244969

Перевод -0.0005 из десятичной в двоичную систему счисления

Введите число:
Его система счисления:
Двоичная
Троичная
Восьмеричная
Десятичная
Шестнадцатиричная
Двоично-десятичная
Другая
Дополнительно

Переведем число 0.000510 в двоичное вот так:

Дробная часть числа находится умножением на основание новой системы счисления:

Перевод чисел из одной системы счисления в другую
0.0005*2
0.001*2
0.002*2
0.004*2
0.008*2
0.016*2
0.032*2
0.064*2
0.128*2
0.256*2
0.512*2

В результате преобразования получилось:

0.000510 = 0.00000000002

Вы указали что размер вашего числа 8 байт.

На данный момент отрицательные дробные числа не поддерживаются. Поэтому в дальнейшем переводе участвует только целая часть числа.

Дополним число знаковым битом вот так:

02 = 10000000000000000000000000000000000000000000000000000000000000002

Так-как введенное Вами число отрицательное то необходимо перевести его из прямого кода в дополнительный.

Для этого сначала выполним преобразование из прямого кода в обратный инвертированием всех битов кроме знакового, затем получим прямой код добавлением 1 бита.

1000000000000000000000000000000000000000000000000000000000000000 прямой код
...............................................................
1111111111111111111111111111111111111111111111111111111111111111обратный код
+1+1 бит
1000000000000000000000000000000000000000000000000000000000000000дополнительный код
Ответ: -0.000510 = 10000000000000000000000000000000000000000000000000000000000000002 (8 байт)