[an error occurred while processing this directive]
[an error occurred while processing this directive]
|
Вариантов много, но все требуют умножений и длиньше 16 тактов.
y=1/x;
1. Как здесь предлагалось для квадратного корня. Ставите битик в x,
умножаете y*x, сравниваете с 1. Сбросили, ( оставили ) и так 16 раз.
2. Нормируете x, x=m*2^n, где m меньше 1 и больше_равно 0.5.
2а. Считаете y по ряду Чебышева от m-0.75. Для 16 бит ~ 7 коэффи-
центов. Значения коэффицентов не помню. Так считает ADI все функции.
2б. Есть разложение 1/(1-t)=(1+t)(1+t^2)(1+t^4)(1+t^8)...
Оборвал на 16 бит точности. Здесь t=m-0.75.
2в. Рекурсия. у(n+1)=y(n)*(2-y(n)*x). Сходимость быстрая, каждый
шаг удвоение точности. Нужно удачно выбрать y(0).
Есть еще, но подзабылись. Дерзайте.
E-mail: info@telesys.ru