Share via


_mm_nmsub_ss

Se requiere Visual Studio 2010 SP1.

Específicos de Microsoft

Genera la instrucción FMA4 XMM vfnmsubss para realizar un par multiplicar-restar en una única ronda de punto flotante negativo de los valores de punto flotante de orden inferior de sus orígenes.

__m128 _mm_nmsub_ss (
   __m128 src1,
   __m128 src2,
   __m128 src3
);

Parámetros

  • [in] src1
    Un parámetro de 128 bits que contiene un valor de punto flotante de 32 bits en la palabra doble baja.

  • [in] src2
    Un parámetro de 128 bits que contiene un valor de punto flotante de 32 bits en la palabra doble baja.

  • [in] src3
    Un parámetro de 128 bits que contiene un valor de punto flotante de 32 bits en la palabra doble baja.

Valor devuelto

Un resultado de 128 bits r que contiene cuatro valores de punto flotante de 32 bits.

r[0] := -(src1[0] * src2[0]) - src3[0];
r[1] := r[2] = r[3] = 0.;

Requisitos

Intrínseco

Arquitectura

_mm_nmsub_ss

FMA4

Archivo de encabezado <intrin.h>

Comentarios

El valor correspondiente en src2 multiplica el valor de punto flotante de precisión sencilla de orden inferior en src1. El resultado se niega, el valor correspondiente en src3 se resta de él y el resultado se almacena como el valor correspondiente en el destino. Los demás valores en src1, src2 y src3 se ignoran, y los tres valores de punto flotante de orden superior del resultado se establecen en 0. El par multiplicar-negar-restar se realiza al final en una única ronda, como si los resultados intermedios se calcularan con precisión infinita.

La instrucción vfnmsubss 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()
{
    __m128 a, b, c, d;
    int i;
    for (i = 0; i < 4; i++) {
        a.m128_f32[i] = i;
        b.m128_f32[i] = 2.;
        c.m128_f32[i] = 3.;
    }
    d = _mm_nmsub_ss(a, b, c);
    for (i = 0; i < 4; i++) printf_s(" %.3f", d.m128_f32[i]);
    printf_s("\n");
}
  

Vea también

Referencia

__cpuid, __cpuidex

Otros recursos

_mm256_nmsub_ps

_mm_nmsub_ps

_mm_nmsub_sd

_mm_macc_ss

_mm_nmacc_ss

_mm_msub_ss

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.