Форум программистов, компьютерный форум CyberForum.ru

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 106, средняя оценка - 4.87
YuliLa
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
07.06.2012, 12:31     Вещественные числа с плавающей точкой, точность вычислений #1
Работаю над проектом, требующим большую точность вычисления вещественных чисел.
Решила использовать long double в надежде получить точность побольше.
Столкнулась с тем, что C++ Builder просто отказывается давать желаемую точность.
Точность необходима до 10^20. То есть до 20 числа после запятой.
Подскажите пожалуйста как решить данную проблему.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.06.2012, 12:31     Вещественные числа с плавающей точкой, точность вычислений
Посмотрите здесь:

Усечение числа с плавающей точкой C++
Точность числа с плавающей точкой C++
Как получить дробную часть числа с плавающей точкой? C++
Отличить целое от числа с плавающей точкой в 32-разрядном регистре C++
Перевод из десятичной системы счисления в двоичную числа с плавающей точкой C++
C++ Ifstream считать из файла числа с плавающей точкой
C++ Неправильный вывод числа с плавающей точкой
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Avazart
Нарушитель
6954 / 5192 / 256
Регистрация: 10.12.2010
Сообщений: 22,778
Записей в блоге: 17
12.06.2012, 00:41     Вещественные числа с плавающей точкой, точность вычислений #61
Хм, а у вас что за VS? (по тому как моя еще хуже Buildlr-a считает)

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

Точности нет после выполнения функции Prognoz ()
Ну это понятно где конкрено - важно...
Например может быть что и fsyg () тоже нужно переписывать...
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
YuliLa
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
12.06.2012, 00:43  [ТС]     Вещественные числа с плавающей точкой, точность вычислений #62
Цитата Сообщение от Avazart Посмотреть сообщение
Хм, а у вас что за VS? (по тому как моя еще хуже Buildlr-a считает)
у меня все старенькое, VS 6.0
Avazart
Нарушитель
6954 / 5192 / 256
Регистрация: 10.12.2010
Сообщений: 22,778
Записей в блоге: 17
12.06.2012, 00:46     Вещественные числа с плавающей точкой, точность вычислений #63
VS 6.0 блин афигеть а у меня VS 10....
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
12.06.2012, 00:49     Вещественные числа с плавающей точкой, точность вычислений #64
Цитата Сообщение от YuliLa Посмотреть сообщение
Что я заметила, что если выполнять все в VS, то в Watch данные числа отображаются одинаково, но разность имеет значение 1*10^-17 в Builder'e же эта разность сразу равна 0
Я ж уже просил. Если было непонято, тогда более конкретно: покажи, что напечатает следующий код (чтобы говорить предметно, а не гадать):

C
1
printf ("%d\n", sizeof (long double));
YuliLa
 Аватар для YuliLa
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;
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16946 / 5351 / 329
Регистрация: 30.03.2009
Сообщений: 14,389
Записей в блоге: 26
12.06.2012, 01:01     Вещественные числа с плавающей точкой, точность вычислений #66
Тогда весьма и весьма странно, что у builder'а точность меньше.

Вообще, как мне кажется, стадию постановки диагноза по телефону пора заканчивать. И нужно выкладывать полный код или сокращённую версию кода, которую мог бы запустить кто-то другой и воспроизвести ошибку у себя на машине
Avazart
Нарушитель
6954 / 5192 / 256
Регистрация: 10.12.2010
Сообщений: 22,778
Записей в блоге: 17
12.06.2012, 01:07     Вещественные числа с плавающей точкой, точность вычислений #67
И нужно выкладывать полный код
И я о том же...

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

Про логарифм что забыли?
YuliLa
 Аватар для YuliLa
4 / 4 / 0
Регистрация: 15.10.2010
Сообщений: 71
12.06.2012, 01:19  [ТС]     Вещественные числа с плавающей точкой, точность вычислений #68
Значит проблема в коде. Вопросов больше не имею. Всем спасибо за помощь.
Avazart
Нарушитель
6954 / 5192 / 256
Регистрация: 10.12.2010
Сообщений: 22,778
Записей в блоге: 17
12.06.2012, 01:28     Вещественные числа с плавающей точкой, точность вычислений #69
Значит проблема в коде
Ну не знаю мы ведь его не видели полностью.

И как уже выяснили проблема до вычисления логарифма....
Поидее если логарифм можно вычислить обычным способом, но после точного вычисления разности...
Avazart
Нарушитель
6954 / 5192 / 256
Регистрация: 10.12.2010
Сообщений: 22,778
Записей в блоге: 17
15.06.2012, 22:43     Вещественные числа с плавающей точкой, точность вычислений #70
Самому стало интересно решил добится большей точности с помощью gmp
http://www.cyberforum.ru/blogs/131347/blog488.html
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.08.2015, 11:45     Вещественные числа с плавающей точкой, точность вычислений
Еще ссылки по теме:

Округлить числа с плавающей точкой C++
Конструирование значения целого числа или числа с плавающей точкой по его дампу C++
C++ Вывод числа с плавающей точкой
Выделить подстроку представляющую запись вещественного числа с плавающей точкой C++
Перевод числа с плавающей точкой из шестнадцатиричного в двоичный вид C++

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

Или воспользуйтесь поиском по форуму:
George_
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 32
08.08.2015, 11:45     Вещественные числа с плавающей точкой, точность вычислений #71
YuliLa: "Значит проблема в коде."

Скорее всего, в опциях компилятора, связанными с округлением вещественных чисел.
Yandex
Объявления
08.08.2015, 11:45     Вещественные числа с плавающей точкой, точность вычислений
Ответ Создать тему
Опции темы

Текущее время: 03:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru