Как преобразовать шестнадцатеричный формат в двоичный формат IEEE754?C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Как преобразовать шестнадцатеричный формат в двоичный формат IEEE754?

Сообщение Anonymous »

Я пытаюсь понять, как преобразовать число с плавающей запятой (например, 5.1) в двоичную форму в C++, используя стандарт IEEE754.
Насколько я понимаю, 5.1 в IEEE754 должен быть представлен с помощью 0 10000000001 0100011001100110011001100110011001100110011001100110.
Я пытался получить этот формат, используя следующую функцию
std::string hexToBinaryIEEE754(const std::string& hexStr) {
// Convert hex string to unsigned long long
unsigned long long hexValue = std::stoull(hexStr, nullptr, 16);

// Convert hex value to IEEE 754 binary representation
std::bitset bits(hexValue);
return bits.to_string();
}

К сожалению, возвращается значение 010000000001010001100110011001100110000000000000000000000000000
Любая идея о том, как вернуть код в двоичном формате, который можно использовать в CVC5< /code> в такой функции, как:
Term v = slv->mkBitVector(32, );


Подробнее здесь: https://stackoverflow.com/questions/783 ... ary-format
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C++»