Russian Qt Forum
Март 28, 2024, 15:42 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: Какь сравнить 2 числа Float, если  (Прочитано 6005 раз)
Сергей85
Гость
« : Апрель 19, 2017, 19:31 »

 в нем постоянно присутствует погрешность на 8-10 знаке после запятой? Стринг 0.55 превращается в 0.550000003 - в результате равенство флоатов 0.55_с_погрешностью=0.55 не выполняется. Никакие округления, перетипирования, умножения и деления на миллионы не помогают.
Записан
Old
Джедай : наставник для всех
*******
Online Online

Сообщений: 4349



Просмотр профиля
« Ответ #1 : Апрель 19, 2017, 19:51 »

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

Сообщений: 290


Просмотр профиля
« Ответ #2 : Апрель 19, 2017, 20:12 »

Новичкам часто советуют забыть о существовании такого типа - float. И всегда использовать double. Хотя бы для того, чтобы не болела голова от такого рода вопросов.
Записан
Old
Джедай : наставник для всех
*******
Online Online

Сообщений: 4349



Просмотр профиля
« Ответ #3 : Апрель 19, 2017, 20:16 »

Новичкам часто советуют забыть о существовании такого типа - float. И всегда использовать double. Хотя бы для того, чтобы не болела голова от такого рода вопросов.
По устройству double ничем не отличается от float, кроме объема. Так что все ограничения остаются в силе.
Записан
Day
Частый гость
***
Offline Offline

Сообщений: 290


Просмотр профиля
« Ответ #4 : Апрель 19, 2017, 20:26 »

По устройству double ничем не отличается от float, кроме объема. Так что все ограничения остаются в силе.
Ну чтож, давайте использовать char вместо int. По устройству-то они ничем, кроме объема, не отличаются. А потом будем вздыхать, чего это результаты какие-то дурацкие. И циклы то кончаются, то никак не хотят...Улыбающийся
Записан
Old
Джедай : наставник для всех
*******
Online Online

Сообщений: 4349



Просмотр профиля
« Ответ #5 : Апрель 19, 2017, 20:38 »

Ну чтож, давайте использовать char вместо int. По устройству-то они ничем, кроме объема, не отличаются. А потом будем вздыхать, чего это результаты какие-то дурацкие. И циклы то кончаются, то никак не хотят...Улыбающийся
Топикстартер уперся не в объем числа, а в ограничения формата. Не все числа могут быть представлены числом с плавающей запятой, будь то float или double.
« Последнее редактирование: Апрель 19, 2017, 20:54 от Old » Записан
Apktyc
Самовар
**
Offline Offline

Сообщений: 128


Просмотр профиля
« Ответ #6 : Апрель 19, 2017, 20:43 »

Сравнивать на равенство два вещественных числа - это первый шаг к головняку.
Qt предлагает нам qFuzzyCompare. Или юзай любой свой эпсилон.

И да, поиск рулит
« Последнее редактирование: Апрель 19, 2017, 20:57 от Apktyc » Записан
__Heaven__
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 2130



Просмотр профиля
« Ответ #7 : Апрель 20, 2017, 09:22 »


Господа, а что значит предупреждение, выдаваемое анализатором clang напротив использования этого выражения?
Цитировать
'qFuzzyCompare' was marked unused but was used

Также хочу отметить, что если мы сравниваем float, полученный в результате каких-то операций, то погрешность его может выйти за пределы допуска qFuzzyCompare.
ИМХО, лучше самостоятельно определять этот допуск.
Записан
Igors
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 11445


Просмотр профиля
« Ответ #8 : Апрель 20, 2017, 11:34 »

в нем постоянно присутствует погрешность на 8-10 знаке после запятой? Стринг 0.55 превращается в 0.550000003 - в результате равенство флоатов 0.55_с_погрешностью=0.55 не выполняется. Никакие округления, перетипирования, умножения и деления на миллионы не помогают.
Просто так
Код
C++ (Qt)
if (fabs(f1 - f2) < 1.0e-8f) {
// примерно равны
}
else {
// не равны
}
Вероятно Вас смущает последняя тройка - откуда она взялась? Улыбающийся Это погрешность флота, точно представляются только числа выражающиеся степенью двойки (напр 4 = 2 ^ 2 или 0.25 = 2 ^ -2) для остальных хранится набор этих степеней в сумме дающий ближайшее.
Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.076 секунд. Запросов: 23.