как из double сделать float16?

кухня спальня

сейчас в проекте используется double.
мне надо редуцировать размер сохраняемых данных вчетверо. Я хочу это сделать путем замены double->{half-precesion}, но вот беда, я не знаю как указать тип этот. В стандартном С такого нет, но есть iee754-2008, и значит что в gnu он должен быть или либой специальной, или ключиком к gcc делающим float двухбайтовым, а не четырехбайтовым.

Гуглю уже с 6ти вечера. %(

ps. точность 3 знака после запятой - устраивает.
Ответы:
Ну, увы тогда. Я такого не видел в GCC выше 3.1. Сделать то легко через define float16 WORD , но все действия придётся переписать через асм на сопроцессор(что несложно, но придётся пользовать функции вместо +-*/), в таком раскладе проще вообще всё через асм переписывать - далее конкретика зависит от задачи, много данных или очень мало места.


13 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.