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

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

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

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

Целая часть числа находится делением на основание новой системы счисления:

172
-1682
1-842
0-422
0-21
0
Перевод чисел из одной системы счисления в другую

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

Перевод чисел из одной системы счисления в другую
0.12*2
0.24*2
0.48*2
0.96*2
1.92*2
1.84*2
1.68*2
1.36*2
0.72*2
1.44*2
0.88*2

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

17.1210 = 10001.00011110102

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

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

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

100012 = 10000000000000000000000000000000000000000000000000000000000100012

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

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

1000000000000000000000000000000000000000000000000000000000010001 прямой код
1111111111111111111111111111111111111111111111111111111111101110обратный код
+1+1 бит
1111111111111111111111111111111111111111111111111111111111101111дополнительный код
Ответ: -17.1210 = 11111111111111111111111111111111111111111111111111111111111011112 (8 байт)