|
1 / 1 / 0
Регистрация: 31.07.2008
Сообщений: 4
|
|
Тип данных учетверенной точности в C/C++05.10.2009, 02:13. Показов 8936. Ответов 15
Метки нет (Все метки)
Подскажите, имеется ли в C/C++ тип данных учетверенной точности (16 байт), т.е. удвоенной по сравнению с double? В фортране такая штука есть, а вот в C? Нужно ли что-нибудь подключать для этого?
Заранее спасибо.
0
|
|
| 05.10.2009, 02:13 | |
|
Ответы с готовыми решениями:
15
Подскажите тип данных в ADO, если в SQL сервере тип Text ? |
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 05.10.2009, 13:24 | |
|
Есть библиотека gmp.
0
|
|
|
|
|
| 05.10.2009, 13:59 | |
|
Есть long double. В случае x86 максимум это:
long double: 1.18973149535723176502e+4932 double: 1.7976931348623157e+308 float: 3.402823466e+38 Является это учетверённой точностью или нет - считай сам, я в математике не силён
0
|
|
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
||||||
| 05.10.2009, 14:12 | ||||||
gcc 4.1 на CentOS/amd64 пишет 16.
0
|
||||||
|
|
|||||||||||
| 05.10.2009, 14:33 | |||||||||||
|
В данном случае sizeof не показателен. Если я ничего не путаю, то на x86 аппаратный long double равен 80 битам (10 байтам), но из-за выравнивания он вытянут до 12 байт (т.е. 2 байта не используются вообще). На amd64 может быть то же самое, о вытянуто до 16 байт, а может мантисса длинная, как на sparc'е
Более правильно подключать файл <float.h> и смотреть значения макросов: LDBL_MANT_DIG - количество бит под мантиссу LDBL_MAX_EXP - максимальное значение экспоненты (она знаковая), исходя из этого вычисляется её битовый размер, а сумма этих двух величин - это и есть битовое значение размера аппаратного long double'а
Добавлено через 11 минут Причём если посмотреть на аналогичные макросы для float и double и те же самые макросы для sparc, то там знаковый бит не надо приплюсовывать, потому как он учитывается в длине мантиссы. Зачем сделали так непонятно, но причина этого следующая. В стандатрах float32 и float64 для мантиссы хранится только часть после запятой, т.к. целая часть в экспотенциальной форме для двоичного числа всегда равна единице. На sparc'е аналогичным образом сделан и long double. А вот на intel'е long double сделан не как у людей и в мантиссе у них хранится ещё и старшая единица. Т.е. для "нормальных" чисел у них этот бит всегда взведён в единицу. При этом есть ещё какие-то "ненормальные" числа, но я толком не помню, что это такое
0
|
|||||||||||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 05.10.2009, 14:36 | |
|
Ну значит long double не годится.
И можно использовать библиотеку gmp ![]() Добавлено через 58 секунд Ненормальные числа - это ненормированная мантиса, а также всякие NaN, -INF, +INF.
0
|
|
|
|
||
| 05.10.2009, 14:38 | ||
|
0
|
||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|||
| 05.10.2009, 14:46 | |||
![]()
http://ru.wikipedia.org/wiki/Ч... й_точности Число́ четверно́й то́чности (англ. Quadruple precision) — компьютерный формат представления чисел, занимающий в памяти четыре последовательных ячейки (компьютерных слова; в случае 32-битного компьютера — 128 бит или 16 байт). Как правило, обозначает формат числа с плавающей запятой binary128 стандарта IEEE 754. Формат числа четверной точности Бит знака: 1 Длина значения экспоненты: 15 Мантисса: 112 Добавлено через 3 минуты Вот еще http://ru.wikipedia.org/wiki/Ч... ей_запятой
0
|
|||
|
|
|||
| 05.10.2009, 14:53 | |||
|
float: 24, 8 double: 53, 11 long double: 64, 16 Т.е. с точки зрения экспоненты соотношение размера экспоненты у double и float примерно такое же, как у long double и double (т.е. 11/8 ~ 16/11). Т.е. с точки зрения диапазона представления чисел действиетльно можно считать, что интеловский long double - учетверённый по отношению к float А вот для мантиссы такое соотношение не выполняется (т.е. 53/24 совесм не равно 64/53), поэтому с точки зрения точности представления чисел интеловский long double уже не является учетверённым. Если автору в первую очередь важна работа с большими числами, то можно использовать long double
0
|
|||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|||
| 05.10.2009, 14:57 | |||
![]() Добавлено через 1 минуту
113 -16381 16384 Точно! Это значит sparc нативно считает с помощью типа binary128 ? Странно что в amd64 такую штуку не сделали.
0
|
|||
|
|
||||
| 05.10.2009, 15:03 | ||||
|
0
|
||||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 05.10.2009, 15:03 | |
|
http://ru.wikipedia.org/wiki/SSE4
... Ни одна из SSE4 инструкций не работает с 64-х битными mmx регистрами (только с 128-ми битными xmm0-15). ... Похоже есть инструкции для работы с 128-битными регистрами. Осталось только понять что там за инструкции
0
|
|
|
|
||
| 05.10.2009, 15:05 | ||
|
0
|
||
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 05.10.2009, 15:13 | |
|
Похоже так и есть. Я там больше 64-бит вещественных не нашел
0
|
|
|
1 / 1 / 0
Регистрация: 31.07.2008
Сообщений: 4
|
|
| 07.10.2009, 22:56 [ТС] | |
|
Спасибо, много интересного.
Меня интересует именно как можно большее количество знаков после запятой, т.е. длина мантиссы(точно не знаю сколько, но лучше не меньше 24-26 знаков). Степени больше пятидесятой не нужны. Я не совсем понял, что вы писали про тип binary128. Как можно его использовать (по характеристикам - в самый раз)? Можно ли им пользоваться в винде, и если да, то какой компилятор его поддерживает? P.S. Можно и в линуксе..
0
|
|
|
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
|
|
| 07.10.2009, 22:58 | |
|
Через библиотеку gmp можно пользоваться.
А так нативно архитектуры I386 и AMD64 похоже не поддерживают работу с типом binary128.
0
|
|
| 07.10.2009, 22:58 | |
|
Помогаю со студенческими работами здесь
16
Какой тип данных использует VBA, если тип явно не объявлен
Определить в сегменте данных число двойной расширенной точности (real10)
C++ Builder 6.0 - преобразование hex данных с компорта в вещественное число двойной точности Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Сочетание глобально распределённой вычислительной мощности и инновационных. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|