С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.70/46: Рейтинг темы: голосов - 46, средняя оценка - 4.70
1 / 1 / 0
Регистрация: 31.07.2008
Сообщений: 4

Тип данных учетверенной точности в C/C++

05.10.2009, 02:13. Показов 8936. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, имеется ли в C/C++ тип данных учетверенной точности (16 байт), т.е. удвоенной по сравнению с double? В фортране такая штука есть, а вот в C? Нужно ли что-нибудь подключать для этого?
Заранее спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.10.2009, 02:13
Ответы с готовыми решениями:

Тип Extended. Как добиться максимальной точности?
Как добиться максимальной точности в Extended? В частности, чтобы ноль было равно 0, а не 0.00000000001465713. Можно ли использовать...

Как сделать тип данных или уже есть такой тип данных который состоит из всех печатыемых символов?
Как сделать тип данных или уже есть такой тип данных который состоит из всех печатыемых символов? Если есть то как он называется ?

Подскажите тип данных в ADO, если в SQL сервере тип Text ?
Господа подскажите тип данных в ADO, если в SQL сервере тип Text ?

15
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.10.2009, 13:24
Есть библиотека gmp.
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
05.10.2009, 13:59
Есть long double. В случае x86 максимум это:
long double: 1.18973149535723176502e+4932
double: 1.7976931348623157e+308
float: 3.402823466e+38
Является это учетверённой точностью или нет - считай сам, я в математике не силён
0
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.10.2009, 14:12
C
1
2
3
4
5
6
7
8
9
10
#include <stdio.h>
 
int main( void ) {
 
long double ld;
 
printf( "%d\n", sizeof(ld) );
return 0;
 
}
gcc 3.4 на Windows XP 32-bit пишет 12.
gcc 4.1 на CentOS/amd64 пишет 16.
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
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'а

C
1
2
3
4
#include <float.h>
LDBL_MANT_DIG
LDBL_MIN_EXP
LDBL_MAX_EXP
Code
1
2
3
4
5
$ gcc t.c -E
...
64
(-16381)
16384
Итого получается 64 бита мантисса, 15 бит экспонента (именно столько нужно для хранения диапазона от -16381 до 16384) и 1 бит на знак. Итого 80 бит

Добавлено через 11 минут
Причём если посмотреть на аналогичные макросы для float и double и те же самые макросы для sparc, то там знаковый бит не надо приплюсовывать, потому как он учитывается в длине мантиссы. Зачем сделали так непонятно, но причина этого следующая. В стандатрах float32 и float64 для мантиссы хранится только часть после запятой, т.к. целая часть в экспотенциальной форме для двоичного числа всегда равна единице. На sparc'е аналогичным образом сделан и long double. А вот на intel'е long double сделан не как у людей и в мантиссе у них хранится ещё и старшая единица. Т.е. для "нормальных" чисел у них этот бит всегда взведён в единицу. При этом есть ещё какие-то "ненормальные" числа, но я толком не помню, что это такое
0
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.10.2009, 14:36
Ну значит long double не годится.
И можно использовать библиотеку gmp

Добавлено через 58 секунд
Ненормальные числа - это ненормированная мантиса, а также всякие NaN, -INF, +INF.
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
05.10.2009, 14:38
Цитата Сообщение от odip Посмотреть сообщение
Ну значит long double не годится.
И можно использовать библиотеку gmp
Ну это смотря что понимать под учетверённой точностью. Если диапазон значений, то вроде бы как соотношение между long double и double примерно такое же, как между double и long dooble. Если количесво знаков после запятой, то тут уже не влезает, ибо мантиссы соотвественно равны 24, 53 и 64 бита
0
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.10.2009, 14:46
вроде бы как соотношение между long double и double примерно такое же, как между double и long dooble.
Читал, много думал. Ничего понял

Ну это смотря что понимать под учетверённой точностью.
А тут думать много не нужно - достаточно почитать
http://ru.wikipedia.org/wiki/Ч... й_точности

Число́ четверно́й то́чности (англ. Quadruple precision) — компьютерный формат представления чисел, занимающий в памяти четыре последовательных ячейки (компьютерных слова; в случае 32-битного компьютера — 128 бит или 16 байт). Как правило, обозначает формат числа с плавающей запятой binary128 стандарта IEEE 754.

Формат числа четверной точности
Бит знака: 1
Длина значения экспоненты: 15
Мантисса: 112

Добавлено через 3 минуты
Вот еще http://ru.wikipedia.org/wiki/Ч... ей_запятой
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
05.10.2009, 14:53
Цитата Сообщение от odip Посмотреть сообщение
Читал, много думал. Ничего понял
Ну, если для x86 взять размеры мантиссы и экспоненты, то значения такие:
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

Цитата Сообщение от odip Посмотреть сообщение
Бит знака: 1
Длина значения экспоненты: 15
Мантисса: 112
Что совпадает с sparc'овским long double
0
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
05.10.2009, 14:57
Т.е. с точки зрения экспоненты соотношение размера экспоненты у double и float примерно такое же, как у long double и double
Ну просто ты в посте #7 совсем другую фразу написал

Добавлено через 1 минуту
Что совпадает с sparc'овским long double
Bigsun:~/work$ ./a.out
113 -16381 16384

Точно!

Это значит sparc нативно считает с помощью типа binary128 ?

Странно что в amd64 такую штуку не сделали.
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
05.10.2009, 15:03
Цитата Сообщение от odip Посмотреть сообщение
Ну просто ты в посте #7 совсем другую фразу написал
Как обычно, когда хочешь выразиться коротко, то как правило получается неясно. Да и с ошибкой ещё

Цитата Сообщение от odip Посмотреть сообщение
Это значит sparc нативно считает с помощью типа binary128 ?
Если binary128 - это такой тип из указанной библиотеки, то логично было бы предположить, что именно так

Цитата Сообщение от odip Посмотреть сообщение
Странно что в amd64 такую штуку не сделали.
А зачем? Им же в этих процессорах ещё и совместимость с i386 надо тащить. А если long double не менять, то нужно меньше транзисторов (ну и вообще схемотехника окажется проще)
0
Эксперт С++
 Аватар для odip
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
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
05.10.2009, 15:05
Цитата Сообщение от odip Посмотреть сообщение
Похоже есть инструкции для работы с 128-битными регистрами.
Осталось только понять что там за инструкции
Я в этом не разбираюсь, но по прочитанному в википедии возникло сильное подозрение, что эти 128-битные регистры используются для векторых операций (т.е. в одном регистре хранятся либо 2 по 64 бита, либо 4 по 32 бита)
0
Эксперт С++
 Аватар для odip
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
Эксперт С++
 Аватар для odip
7176 / 3234 / 82
Регистрация: 17.06.2009
Сообщений: 14,164
07.10.2009, 22:58
Через библиотеку gmp можно пользоваться.
А так нативно архитектуры I386 и AMD64 похоже не поддерживают работу с типом binary128.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.10.2009, 22:58
Помогаю со студенческими работами здесь

Какой тип данных использует VBA, если тип явно не объявлен
Какой тип данных использует VBA, если тип явно не объявлен

Enum и типы данных. Как задать тип значений явно, и какой тип будет при переполнении?
Пытаюсь сделать функцию с передачей нескольких параметров,используя битовые операции. В качестве параметров думаю использовать не...

Определить в сегменте данных число двойной расширенной точности (real10)
В FPU есть возможность работать с числами размером 4 байта, 8 байт и 10 байт. 4 байта хранят в DWORD, 8 байт в QWORD. А вот как правильно...

Перечисляемый тип данных.Символьный тип.
1.type месяц = ( янв, фев, мар, апр, май, июн, июл, авг, сен, окт, ноя, дек ); год = (високосный, невисокосный); var d:28..31;...

C++ Builder 6.0 - преобразование hex данных с компорта в вещественное число двойной точности
Доброго всем времени суток. Данные с компорта записываю во временный буфер queue &lt;unsigned char&gt; TmpBuffer;По логике в переменную...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «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/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru