WikiDer > BKM алгоритм

BKM algorithm

В BKM алгоритм это алгоритм сдвига и сложения для вычислений элементарные функции, впервые опубликовано в 1994 году Жан-Клодом Бажаром, Сильванусом Кла и Жан-Мишелем Мюллером. БКМ создан на базе вычислительного комплекса логарифмы (L-режим) и экспоненты (E-режим) методом, аналогичным алгоритму Генри Бриггс используется для вычисления логарифмов. Используя предварительно вычисленную таблицу логарифмов отрицательных степеней двойки, алгоритм BKM вычисляет элементарные функции, используя только операции сложения, сдвига и сравнения целых чисел.

BKM похож на КОРДИК, но использует таблицу логарифмы а не таблица арктангенсы. На каждой итерации выбор коэффициента производится из набора из девяти комплексных чисел 1, 0, −1, i, −i, 1 + i, 1 − i, −1 + i, −1 − i, а не только -1 или +1, как используется CORDIC. BKM обеспечивает более простой метод вычисления некоторых элементарных функций, и в отличие от CORDIC, BKM не требует масштабного коэффициента результата. Скорость сходимости BKM составляет приблизительно один бит на итерацию, как и CORDIC, но для BKM требуется больше предварительно вычисленных элементов таблицы для той же точности, поскольку таблица хранит логарифмы сложных операндов.

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

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

дальнейшее чтение

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