Алгоритм альфа макс плюс бета мин - Alpha max plus beta min algorithm

Геометрическое место точек, которые дают одинаковое значение в алгоритме для разных значений альфа и бета.

В алгоритм альфа макс плюс бета мин представляет собой высокоскоростное приближение квадратный корень суммы двух квадратов. Квадратный корень из суммы двух квадратов, также известный как Пифагорейское сложение, полезная функция, потому что она находит гипотенуза прямоугольного треугольника с учетом длины двух сторон, норма 2-D вектор, или величина из комплексное число z = а + бя дал настоящий и воображаемый части.

Алгоритм избегает выполнения операций извлечения квадратного корня и извлечения квадратного корня, вместо этого используются простые операции, такие как сравнение, умножение и сложение. Некоторые варианты выбора параметров α и β алгоритма позволяют свести операцию умножения к простому сдвигу двоичных цифр, что особенно хорошо подходит для реализации в высокоскоростных цифровых схемах.

Приближение выражается как

куда - максимальное абсолютное значение а и б, и - минимальное абсолютное значение а и б.

Для наиболее близкого приближения оптимальные значения для и находятся и , что дает максимальную ошибку 3,96%.

Наибольшая ошибка (%)Средняя ошибка (%)
1/11/211.808.68
1/11/411.613.20
1/13/86.804.25
7/87/1612.504.91
15/1615/326.253.08
3.962.41
Alpha Max Beta Min аппроксимация.png

Улучшения

Когда , становится меньше, чем (что геометрически невозможно) вблизи осей, где близка к нулю. Это можно исправить, заменив результат на всякий раз, когда это больше, по существу разделяя линию на два разных сегмента.

В зависимости от оборудования это улучшение может быть почти бесплатным.

Использование этого улучшения изменяет оптимальные значения параметров, поскольку им больше не требуется точное соответствие для всего интервала. Более низкий и выше таким образом может еще больше повысить точность.

Повышение точности: При таком разделении линии на две можно было бы еще больше повысить точность, заменив первый сегмент более точной оценкой, чем , и отрегулируйте и соответственно.

Наибольшая ошибка (%)
107/817/32−2.65%
1029/3261/128+2.4%
11/87/833/64−1.7%
15/3227/3271/1281.22%
127/1283/1627/3271/128−1.13%

Однако помните, что ненулевое значение потребует по крайней мере одного дополнительного сложения и некоторых битовых сдвигов (или умножения), что, вероятно, почти удвоит стоимость и, в зависимости от оборудования, возможно, в первую очередь лишит цели использования приближения.

Смотрите также

  • Гипотеза, точная функция или алгоритм, который также защищен от переполнения и потери значимости.

Рекомендации

  • Лайонс, Ричард Дж.. Понимание цифровой обработки сигналов, раздел 13.2. Прентис Холл, 2004 ISBN  0-13-108989-7.
  • Гриффин, Грант. Уловка DSP: оценщик величины.

внешняя ссылка