Condividi tramite


_mm_nmsub_sd

È necessario Visual Studio 2010 SP1.

Specifici di Microsoft

Genera l'istruzione FMA4 XMM vfnmsubsd per eseguire una funzione multiply-subtract negativa a virgola mobile e precisione doppia con un unico arrotondamento dei valori a virgola mobile meno significativi delle origini.

__m128d _mm_nmsub_sd (
   __m128d src1,
   __m128d src2,
   __m128d src3
);

Parametri

  • [in] src1
    Parametro a 128 bit che contiene un valore a virgola mobile a 64 bit nella parola quadrupla inferiore.

  • [in] src2
    Parametro a 128 bit che contiene un valore a virgola mobile a 64 bit nella parola quadrupla inferiore.

  • [in] src3
    Parametro a 128 bit che contiene un valore a virgola mobile a 64 bit nella parola quadrupla inferiore.

Valore restituito

Risultato a 128 bit r che contiene due valori a virgola mobile a 64 bit.

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

Requisiti

Intrinseco

Architettura

_mm_nmsub_sd

FMA4

File di intestazione <intrin.h>

Note

Il valore a virgola mobile a precisione doppia meno significativo in src1 viene moltiplicato per il valore corrispondente in src2. Il risultato viene negato, il valore corrispondente in src3 viene da esso sottratto e il risultato viene archiviato come valore corrispondente nella destinazione. Gli altri valori in src1, src2 e src3 vengono ignorati e il valore a virgola mobile a doppia precisione del risultato viene impostato su 0. La funzione multiply-negate-subtract viene eseguita con un unico arrotondamento alla fine, come se i risultati intermedi venissero calcolati a precisione infinita.

L'istruzione vfnmsubsd è parte della famiglia FMA4 di istruzioni. Prima di utilizzare questo intrinseco, è necessario assicurarsi che il processore supporti questa istruzione. Per determinare il supporto hardware per questa istruzione, chiamare l'intrinseco __cpuid con InfoType = 0x80000001 e il bit di controllo 16 di CPUInfo[2] (ECX). Questo bit è 1 quando l'istruzione è supportata, e 0 in caso contrario.

Esempio

#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_nmsub_sd(a, b, c);
    for (i = 0; i < 2; i++) printf_s(" %.3lf", d.m128d_f64[i]);
    printf_s("\n");
}
  

Vedere anche

Riferimenti

__cpuid, __cpuidex

Altre risorse

_mm256_nmsub_pd

_mm_nmsub_pd

_mm_nmsub_ss

_mm_macc_sd

_mm_nmacc_sd

_mm_msub_sd

Oggetti intrinseci FMA4 aggiunti per Visual Studio 2010 SP1

Cronologia delle modifiche

Data

Cronologia

Motivo

Marzo 2011

È stato aggiunto questo contenuto.

Modifica di funzionalità in SP1.