Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.71/109: Рейтинг темы: голосов - 109, средняя оценка - 4.71
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71

Вещественные числа с плавающей точкой, точность вычислений

07.06.2012, 12:31. Показов 20885. Ответов 70
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Работаю над проектом, требующим большую точность вычисления вещественных чисел.
Решила использовать long double в надежде получить точность побольше.
Столкнулась с тем, что C++ Builder просто отказывается давать желаемую точность.
Точность необходима до 10^20. То есть до 20 числа после запятой.
Подскажите пожалуйста как решить данную проблему.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.06.2012, 12:31
Ответы с готовыми решениями:

Точность числа с плавающей точкой
У типа float числа одинарной точности с плавающей запятой обеспечивают относительную точность 7-8 десятичных цифр. Внимание, вопрос!...

Максимальная точность для чисел с плавающей точкой
Суть поставленной задачи: дан вектор от 10_000 до 100_000 элементов, нужно проходить по вектору, брать два первых значения которые должны...

Представить вещественные числа в четырёхбайтовой ячейке памяти в формате с плавающей точкой
Пожалуйста помогите Представить вещественные числа в четырёхбайтовой ячейке памяти в формате с плавающей точкой. a) 0,5; б) 25,12; в)...

70
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
12.06.2012, 00:41
Студворк — интернет-сервис помощи студентам
Хм, а у вас что за VS? (по тому как моя еще хуже Buildlr-a считает)

Просто нужен кусок кода с которым можно было бы по эксперементировать... и желательно значения которые надо подставлять/получать...

Точности нет после выполнения функции Prognoz ()
Ну это понятно где конкрено - важно...
Например может быть что и fsyg () тоже нужно переписывать...
0
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
12.06.2012, 00:43  [ТС]
Цитата Сообщение от Avazart Посмотреть сообщение
Хм, а у вас что за VS? (по тому как моя еще хуже Buildlr-a считает)
у меня все старенькое, VS 6.0
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
12.06.2012, 00:46
VS 6.0 блин афигеть а у меня VS 10....
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
12.06.2012, 00:49
Цитата Сообщение от YuliLa Посмотреть сообщение
Что я заметила, что если выполнять все в VS, то в Watch данные числа отображаются одинаково, но разность имеет значение 1*10^-17 в Builder'e же эта разность сразу равна 0
Я ж уже просил. Если было непонято, тогда более конкретно: покажи, что напечатает следующий код (чтобы говорить предметно, а не гадать):

C
1
printf ("%d\n", sizeof (long double));
0
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
12.06.2012, 00:54  [ТС]
Цитата Сообщение от Evg Посмотреть сообщение
Я ж уже просил. Если было непонято, тогда более конкретно: покажи, что напечатает следующий код (чтобы говорить предметно, а не гадать):

C
1
printf ("%d\n", sizeof (long double));
Да, я видела:
Результат VS = 8;
Результат Builder = 10;
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
12.06.2012, 01:01
Тогда весьма и весьма странно, что у builder'а точность меньше.

Вообще, как мне кажется, стадию постановки диагноза по телефону пора заканчивать. И нужно выкладывать полный код или сокращённую версию кода, которую мог бы запустить кто-то другой и воспроизвести ошибку у себя на машине
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
12.06.2012, 01:07
И нужно выкладывать полный код
И я о том же...

Порылся в документации gmp не нашел вычисление логарифма, плюс нашел такое:
Здравствуйте, не подскажите как вычислить логарифм с точностью ~30-50 знаков после запятой? Пробовал разные библиотеки для длинной арифметики: Arageli, gmp.. но там нельзя вычислять логарифм из самих длинных чисел, только double. Просто у меня в программе логарифмы постоянно суммируются, в результате чего, накапливается приличная погрешность и мне надо ее максимально минимизировать.
Здесь Точный логарифм

Про логарифм что забыли?
0
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
12.06.2012, 01:19  [ТС]
Значит проблема в коде. Вопросов больше не имею. Всем спасибо за помощь.
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
12.06.2012, 01:28
Значит проблема в коде
Ну не знаю мы ведь его не видели полностью.

И как уже выяснили проблема до вычисления логарифма....
Поидее если логарифм можно вычислить обычным способом, но после точного вычисления разности...
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
15.06.2012, 22:43
Самому стало интересно решил добится большей точности с помощью gmp
https://www.cyberforum.ru/blog... og488.html
0
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 32
08.08.2015, 11:45
YuliLa: "Значит проблема в коде."

Скорее всего, в опциях компилятора, связанными с округлением вещественных чисел.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.08.2015, 11:45
Помогаю со студенческими работами здесь

В текстовом файле записаны вещественные числа с плавающей точкой. Преобразовать файл, заменив каждое число, округленным
Задача: В текстовом файле записаны вещественные числа с плавающей точкой. Преобразовать файл, заменив каждое число, округленным до десятых...

Преобразование чисел с плавающей точкой в числа с фиксированной точкой
Здравствуйте, подскажите пожалуйста как заменить вещественные числа с плавающей точкой, числами округленными до десятых, записанными в...

Точность вычислений в double (Обрезание числа)
Здравствуйте! Дело в том, что мне необходимо выводить большие числа с большим количеством знаков после запятой. Однако и double и float...

Числа с плавающей точкой
Здравствуйте, создаю я, значит, батник. И тут столкнулся с такое проблемой: при присвоении переменной числа с плавающей точкой вылетает...

Числа с плавающей точкой
Как отделить целую часть и дробную? Например имеем число 12.54 число 12 должно бить записано в textbox1 а число 54 в textbox2.


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

Или воспользуйтесь поиском по форуму:
71
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru