Algoritmo alfa max mas beta min
El algoritmo Alfa max más Beta min es una aproximación lineal de alta velocidad de la raíz cuadrada de la suma de dos cuadrados. La raíz cuadrada de la suma de dos cuadrados, también conocida como suma pitagórica, es una función útil porque encuentra la hipotenusa de un triángulo rectángulo dadas las longitudes de los dos lados, la norma de un vector 2-D o la magnitud de un número complejo z = a + bi dadas las partes real e imaginaria .
El algoritmo evita realizar las operaciones de raíz cuadrada y cúbica, y en su lugar utiliza operaciones simples como comparación, multiplicación y suma. Algunas elecciones de los parámetros α y β del algoritmo permiten que la operación de multiplicación se reduzca a un simple cambio de dígitos binarios que es particularmente adecuado para la implementación en circuitos digitales de alta velocidad.
La aproximación se expresa como
dónde es el valor absoluto máximo de a y b, y es el valor absoluto mínimo de a y b.
Para la aproximación más cercana, los valores óptimos para y son y , dando un error máximo de 3,96%.
Error máximo(%) | Error medio (%) | ||
---|---|---|---|
1/1 | 1/2 | 11.80 | 8.68 |
1/1 | 1/4 | 11.61 | 3.20 |
1/1 | 3/8 | 6.80 | 4.25 |
7/8 | 7/16 | 12.50 | 4.91 |
15/16 | 15/32 | 6.25 | 3.08 |
3.96 | 2.41 |
Mejoras
editarCuando , se vuelve más pequeño que (lo cual es geométricamente imposible) cerca de los ejes donde está cerca de 0. Esto se puede remediar reemplazando el resultado con siempre que sea mayor, esencialmente dividiendo la línea en dos segmentos diferentes.
El uso de esta mejora cambia qué valores de parámetros son óptimos, porque ya no necesitan una coincidencia cercana para todo el intervalo. Una baja y más alto por lo tanto, puede aumentar aún más la precisión. Al dividir la línea en dos como esta, se podría mejorar la precisión aún más reemplazando el primer segmento por una mejor estimación que y ajustar y respectivamente.
Error máximo(%) | ||||
---|---|---|---|---|
1 | 0 | 7/8 | 17/32 | −2,65% |
1 | 0 | 29/32 | 61/128 | +2,4% |
1 | 0 | 0.898204193266868 | 0.485968200201465 | ±2,12% |
1 | 1/8 | 7/8 | 33/64 | −1,7% |
1 | 5/32 | 27/32 | 71/128 | 1,22% |
127/128 | 3/16 | 27/32 | 71/128 | −1,13% |
Sin embargo, se debe tener en cuenta que un valor distinto de cero requeriría al menos una adición adicional y algunos cambios de bits (o una multiplicación), probablemente casi duplicando el costo y, dependiendo del hardware, frustrando el propósito de usar una aproximación en primer lugar.
Referencias
editar- Lyons, Richard G. Understanding Digital Signal Processing, section 13.2. Prentice Hall, 2004 ISBN 0-13-108989-7.
- Griffin, Grant. DSP Trick: Magnitude Estimator.
Enlaces externos
editar- «Extension to three dimensions». Stack Exchange. 14 de mayo de 2015.