_mm_nmacc_sd
È necessario Visual Studio 2010 SP1.
Specifici di Microsoft
Genera l'istruzione FMA4 XMM vfnmaddsd per eseguire una funzione multiply-add negativa a virgola mobile e precisione doppia con un unico arrotondamento dei valori a virgola mobile meno significativi delle origini.
__m128d _mm_nmacc_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_nmacc_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 e aggiunto al valore corrispondente in src3 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-add viene eseguita con un unico arrotondamento alla fine, come se i risultati intermedi venissero calcolati a precisione infinita.
L'istruzione vfnmaddsd è 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_nmacc_sd(a, b, c);
for (i = 0; i < 2; i++) printf_s(" %.3lf", d.m128d_f64[i]);
printf_s("\n");
}
Vedere anche
Riferimenti
Altre risorse
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. |