_mm_nmacc_ss
È necessario Visual Studio 2010 SP1.
Specifici di Microsoft
Genera l'istruzione FMA4 XMM vfnmaddss per eseguire una funzione multiply-add negativa a virgola mobile con un unico arrotondamento dei valori a virgola mobile meno significativi delle origini.
__m128 _mm_nmacc_ss (
__m128 src1,
__m128 src2,
__m128 src3
);
Parametri
[in] src1
Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.[in] src2
Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.[in] src3
Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.
Valore restituito
Risultato a 128 bit r che contiene quattro valori a virgola mobile a 32 bit.
r[0] := -(src1[0] * src2[0]) + src3[0];
r[1] := r[2] = r[3] = 0.;
Requisiti
Intrinseco |
Architettura |
---|---|
_mm_nmacc_ss |
FMA4 |
File di intestazione <intrin.h>
Note
Il valore a virgola mobile a precisione singola meno significativa 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 i tre valori a virgola mobile più significativi del risultato vengono impostati 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 vfnmaddss è 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()
{
__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_nmacc_ss(a, b, c);
for (i = 0; i < 4; i++) printf_s(" %.3f", d.m128_f32[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. |