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

Проверить вычисления на переполнение и потерю точности - C++

Восстановить пароль Регистрация
 
MousePro
49 / 30 / 1
Регистрация: 25.04.2013
Сообщений: 366
14.08.2014, 19:37     Проверить вычисления на переполнение и потерю точности #1
Надо написать функции арифметических действий с проверкой переполнения,потери и генерировать исключение если оно случается.
Вообщем то как бы все просто, в функции сделать операцию в более широком типе и проверить с помощью констант INT_MAX, получается что для целочисленных типов максимум ULLONG_MAX.
Как проверить выше ULLONG_MAX и какой максимум для dobule - 1.79769e+308?

Добавлено через 10 минут
Выполнить операцию поразрядно в char массив например, посчитать разряды и если их больше то переполнение?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.08.2014, 19:37     Проверить вычисления на переполнение и потерю точности
Посмотрите здесь:

C++ Создать программу вычисления указанной величины. Результат проверить при заданных исходных значениях.
C++ Вычисления массива (проверить код)
Вычислить сумму ряда. Вычисления заканчивать при достижении заданной степени точности C++
C++ Не точности вычисления C++
Проверить int на переполнение C++
Ошибка точности C++
Вычисления до заданной точности C++
Проверить правильность вычисления по формулам C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6166 / 2895 / 282
Регистрация: 04.12.2011
Сообщений: 7,695
Записей в блоге: 3
16.08.2014, 01:32     Проверить вычисления на переполнение и потерю точности #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
bool IsNumber(double x) 
    {
        // This looks like it should always be true, 
        // but it's false if x is a NaN.
        return (x == x); 
    }
 
//Here DBL_MAX is a constant defined in float.h as the largest double that can be represented.
 
bool IsFiniteNumber(double x) 
    {
        return (x <= DBL_MAX && x >= -DBL_MAX); //можно разделить еа две булевых ф-ции, если интересно какое именно переполнение + или - infinity
    }
Подробнее:
http://www.johndcook.com/IEEE_exceptions_in_cpp.html
Yandex
Объявления
16.08.2014, 01:32     Проверить вычисления на переполнение и потерю точности
Ответ Создать тему
Опции темы

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