Интервальная арифметика — различия между версиями
Sementry (обсуждение | вклад) (Начал писать статью. Пока копипаста из Википедии.) |
Sementry (обсуждение | вклад) м |
||
Строка 12: | Строка 12: | ||
Вырожденные интервалы, у которых начало и конец совпадают, можно отождествить с обычными вещественными числами. Для них данные выше определения совпадают с классическими арифметическими действиями. | Вырожденные интервалы, у которых начало и конец совпадают, можно отождествить с обычными вещественными числами. Для них данные выше определения совпадают с классическими арифметическими действиями. | ||
+ | |||
+ | == Применение в вычислительной геометрии == | ||
+ | |||
+ | Допустим, нам нужно определить знак некоторого выражения (это может потребоваться, например, при вычислении предиката [[Предикат "левый поворот" |"левый поворот"]]). Ясно, что минимальное значение будет, если все округлять вниз, а максимальное - если вверх. {{TODO| t=поподробнее об этом}} | ||
+ | |||
+ | == Проблемы и ограничения == | ||
+ | Переключение режима округления в процессоре является довольно длительной операцией, поэтому, если использовать его в каждой элементарной операции, это может сильно замедлить вычисления. Впрочем, эту проблему можно легко решить. {{TODO| t=написать о решении}} | ||
+ | |||
+ | Предполагается, что мы можем управлять округлением в операциях над вещественными числами. Стандарт IEEE 754 гарантирует такую возможность, но не все современные языки/архитектуры его выполняют. Например, согласно [http://www.cs.berkeley.edu/~wkahan/JAVAhurt.pdf этому] материалу, вещественная арифметика в Java не соответствует стандарту IEEE 754 (в частности, не позволяет указывать правила округления). Поэтому на Java нельзя реализовать интервальную арифметику с использованием только примитивных типов double/float. |
Версия 08:34, 16 октября 2011
Интервальная арифметика — математическая структура, которая для вещественных интервалов определяет операции, аналогичные обычным арифметическим. Данная математическая модель удобна для работы с величинами, значения которых известны только приближённо, то есть определён конечный интервал, в котором эти значения содержатся.
Операции над интервалами
Мы будем рассматривать всевозможные конечные вещественные интервалы
. Операции над ними определяются следующим образом:- Сложение:
- Вычитание:
- Умножение:
- Деление:
Из определения видно, что интервал-сумма содержит всевозможные суммы чисел из интервалов-слагаемых и определяет границы множества таких сумм. Аналогично трактуются прочие действия. Отметим, что операция деления определена только в том случае, когда интервал-делитель не содержит нуля.
Вырожденные интервалы, у которых начало и конец совпадают, можно отождествить с обычными вещественными числами. Для них данные выше определения совпадают с классическими арифметическими действиями.
Применение в вычислительной геометрии
Допустим, нам нужно определить знак некоторого выражения (это может потребоваться, например, при вычислении предиката "левый поворот"). Ясно, что минимальное значение будет, если все округлять вниз, а максимальное - если вверх. TODO: поподробнее об этом
Проблемы и ограничения
Переключение режима округления в процессоре является довольно длительной операцией, поэтому, если использовать его в каждой элементарной операции, это может сильно замедлить вычисления. Впрочем, эту проблему можно легко решить. TODO: написать о решении
Предполагается, что мы можем управлять округлением в операциях над вещественными числами. Стандарт IEEE 754 гарантирует такую возможность, но не все современные языки/архитектуры его выполняют. Например, согласно этому материалу, вещественная арифметика в Java не соответствует стандарту IEEE 754 (в частности, не позволяет указывать правила округления). Поэтому на Java нельзя реализовать интервальную арифметику с использованием только примитивных типов double/float.