Operación multiplicar-acumular


En computación , especialmente en el procesamiento de señales digitales , la operación multiplicar-acumular ( MAC ) o multiplicar-sumar ( MAD ) es un paso común que calcula el producto de dos números y suma ese producto a un acumulador . La unidad de hardware que realiza la operación se conoce como multiplicador-acumulador ( unidad MAC ); la operación en sí también suele denominarse operación MAC o MAD. La operación MAC modifica un acumulador a :

Cuando se hace con números de punto flotante , se puede realizar con dos redondeos (típico en muchos DSP ) o con un solo redondeo. Cuando se realiza con un solo redondeo, se denomina multiplicación-suma fusionada ( FMA ) o multiplicación-acumulación fusionada ( FMAC ).

Las computadoras modernas pueden contener un MAC dedicado, que consta de un multiplicador implementado en lógica combinacional seguido de un sumador y un registro acumulador que almacena el resultado. La salida del registro se retroalimenta a una entrada del sumador, de modo que en cada ciclo de reloj, la salida del multiplicador se suma al registro. Los multiplicadores combinacionales requieren una gran cantidad de lógica, pero pueden calcular un producto mucho más rápido que el método de cambiar y sumar típico de las computadoras anteriores. Percy Ludgate fue el primero en concebir un MAC en su Máquina Analítica de 1909, [1] y el primero en explotar un MAC para la división (usando la multiplicación sembrada por recíproco, a través de la serie convergente (1+x ) −1 ). Los primeros procesadores modernos que se equiparon con unidades MAC fueron los procesadores de señales digitales , pero la técnica ahora también es común en los procesadores de propósito general. [2] [3] [4] [5]

Cuando se hace con números enteros , la operación suele ser exacta ( módulo calculado alguna potencia de dos ). Sin embargo, los números de punto flotante tienen solo una cierta cantidad de precisión matemática . Es decir, la aritmética digital de punto flotante generalmente no es asociativa ni distributiva . (Consulte Coma flotante § Problemas de precisión ). Por lo tanto, hay una diferencia en el resultado si la suma y multiplicación se realiza con dos redondeos o en una sola operación con un solo redondeo (una suma y multiplicación fusionada). IEEE 754-2008 especifica que debe realizarse con un redondeo, lo que arroja un resultado más preciso. [6]

Una multiplicación-suma fusionada ( FMA o fmadd ) [7] es una operación de multiplicación-suma de punto flotante realizada en un solo paso, con un solo redondeo. Es decir, donde una multiplicación-suma no fusionada calcularía el producto b × c , lo redondearía a N bits significativos, sumaría el resultado a a y redondearía a N bits significativos, una multiplicación-suma fusionada calcularía la expresión completa a + ( b × c ) con toda su precisión antes de redondear el resultado final a N bits significativos.

Un FMA rápido puede acelerar y mejorar la precisión de muchos cálculos que involucran la acumulación de productos: