_mm_msub_sd
Se requiere Visual Studio 2010 SP1.
Específicos de Microsoft
Genera la instrucción FMA4 XMM vfmsubsd para realizar un par multiplicar-restar en una única ronda de punto flotante de doble precisión de los valores de punto flotante de orden inferior de sus orígenes.
__m128d _mm_msub_sd (
__m128d src1,
__m128d src2,
__m128d src3
);
Parámetros
[in] src1
Un parámetro de 128 bits que contiene un valor de punto flotante de 64 bits en la palabra cuádruple baja.[in] src2
Un parámetro de 128 bits que contiene un valor de punto flotante de 64 bits en la palabra cuádruple baja.[in] src3
Un parámetro de 128 bits que contiene un valor de punto flotante de 64 bits en la palabra cuádruple baja.
Valor devuelto
Un resultado de 128 bits r que contiene dos valores de punto flotante de 64 bits.
r[0] := src1[0] * src2[0] - src3[0];
r[1] := 0.;
Requisitos
Intrínseco |
Arquitectura |
---|---|
_mm_msub_sd |
FMA4 |
Archivo de encabezado <intrin.h>
Comentarios
El valor correspondiente en src2 multiplica el valor de punto flotante de doble precisión de orden inferior en src1, el valor correspondiente en src3 se resta del producto y el resultado se almacena como el valor correspondiente en el destino. Los demás valores de src1, src2 y src3 se ignoran y el valor de punto flotante de doble precisión de orden superior del resultado, se establece en 0. El par multiplicar-restar se realiza al final en una única ronda, como si los resultados intermedios se calcularan con precisión infinita.
La instrucción vfmsubsd forma parte de la familia FMA4 de instrucciones. Antes de utilizar este intrínseco, debe asegurarse de que el procesador admite esta instrucción. Para determinar la compatibilidad del hardware para obtener esta instrucción, llame a __cpuid intrínseco con InfoType = 0x80000001 y compruebe el bit 16 de CPUInfo [2] (ECX). Este bit es 1 cuando se admite la instrucción, de lo contrario es 0.
Ejemplo
#include <stdio.h>
#include <intrin.h>
int main()
{
__m128d a, b, c, d;
int i;
for (i = 0; i < 2; i++) {
a.m128d_f64[i] = i;
b.m128d_f64[i] = 2.;
c.m128d_f64[i] = 3.;
}
d = _mm_msub_sd(a, b, c);
for (i = 0; i < 2; i++) printf_s(" %.3lf", d.m128d_f64[i]);
printf_s("\n");
}
Vea también
Referencia
Otros recursos
Intrínsecos FMA4 agregados para Visual Studio 2010 SP1
Historial de cambios
Fecha |
Historial |
Motivo |
---|---|---|
Marzo de 2011 |
Se agrega este contenido. |
Cambio de características de SP1. |