![]() |
Добро пожаловать, гость ( Вход | Регистрация )
![]() |
рффшник |
![]()
Сообщение
#1
|
Новичок ![]() Группа: Пользователи Braingames Сообщений: 15 Регистрация: 21.4.2007 Пользователь №: 137 ![]() |
Я сам не программист, но для решения некоторых прикладных задач потребовалось изучить Си. И при решении одной из таких задач вылезла одна маленькая проблемка. Есть некоторая проверка истинности :
if ((выражение типа дабл)!=0){ нечто } но иногда выходит так, что выражение, которое должно быть равно нулю - равно некоторому очень маленькому числу, что приводит к ненужному выполнению условия (выражение типа дабл)!=0. Из-за этого программа работает не вполне корректно. Можно исправить проблему, если вместо проверки равенства сделать другую проверку: if (fabs(выражение типа дабл)>x) но встает вопрос, каким минимальным можно взять "х"? Эмпирически оно получается порядка 10^-14. Но у меня нет гарантий, что определенном стечении обтоятельств не потребуется, скажем, 10^-13. Как быть, господа программисты? ЗЫ если это важно: выражения типа дабл равно сумма квадратов n double чисел минус квадрат суммы n double чисел |
![]() ![]() |
Mouse |
![]()
Сообщение
#2
|
![]() и.о. админа ![]() ![]() Группа: Администраторы Сообщений: 86 Регистрация: 5.12.2006 Пользователь №: 20 ![]() |
QUOTE означают, что А-В посчитается с погрешностью меньшей 1е-15, при 0<A,B<1? не меньшей, а сравнимой. т.е. ошибка будет где-то в 15м знаке после запятой, зависит от методов округления. берите 1е-14 при 0<A,B<1.(учитывайте что разрядность двоичная, т.е. гарантируемая точность операции это спецификация процессора/системы) QUOTE Сегодня с утра я еще и не задумывался, что равно может быть на самом деле и не очень то равно сравните состояние милиордеров по версии различных источников(в одинаковое время), по теории равны, по разнице, бюджет малой(а может и несовсем) страны ![]() |
![]() ![]() |
![]() |
Упрощённая версия | Сейчас: 18.7.2025, 7:53 |