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

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

07.06.2012, 12:31. Показов 20506. Ответов 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
8484 / 6151 / 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
8484 / 6151 / 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
8484 / 6151 / 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
8484 / 6151 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
12.06.2012, 01:28
Значит проблема в коде
Ну не знаю мы ведь его не видели полностью.

И как уже выяснили проблема до вычисления логарифма....
Поидее если логарифм можно вычислить обычным способом, но после точного вычисления разности...
0
Эксперт С++
 Аватар для Avazart
8484 / 6151 / 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
Ответ Создать тему
Новые блоги и статьи
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/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru