4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
1

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

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

Author24 — интернет-сервис помощи студентам
Работаю над проектом, требующим большую точность вычисления вещественных чисел.
Решила использовать long double в надежде получить точность побольше.
Столкнулась с тем, что C++ Builder просто отказывается давать желаемую точность.
Точность необходима до 10^20. То есть до 20 числа после запятой.
Подскажите пожалуйста как решить данную проблему.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.06.2012, 12:31
Ответы с готовыми решениями:

Точность числа с плавающей точкой
У типа float числа одинарной точности с плавающей запятой обеспечивают относительную точность 7-8...

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

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

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

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

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

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

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

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

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

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

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

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

Скорее всего, в опциях компилятора, связанными с округлением вещественных чисел.
0
08.08.2015, 11:45
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.08.2015, 11:45
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
71
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru