_mm_nmacc_sd
Visual Studio 2010 SP1 est requis
Spécifique à Microsoft
Génère l'instruction XMM FMA4 vfnmaddsd pour exécuter une opération négative multiplier-ajouter à virgule flottante double précision avec un seul arrondi des valeurs à virgule flottante de poids faible de ses sources.
__m128d _mm_nmacc_sd (
__m128d src1,
__m128d src2,
__m128d src3
);
Paramètres
[in] src1
Un paramètre de 128 bits qui contient une valeur à virgule flottante 64 bits dans le mot quadruple de poids faible.[in] src2
Un paramètre de 128 bits qui contient une valeur à virgule flottante 64 bits dans le mot quadruple de poids faible.[in] src3
Un paramètre de 128 bits qui contient une valeur à virgule flottante 64 bits dans le mot quadruple de poids faible.
Valeur de retour
Résultat r de 128 bits qui contient deux valeurs à virgule flottante de 64 bits.
r[0] := -(src1[0] * src2[0]) + src3[0];
r[1] := 0.;
Configuration requise
Intrinsèque |
Architecture |
---|---|
_mm_nmacc_sd |
FMA4 |
Fichier d'en-tête <intrin.h>
Notes
La valeur à virgule flottante double précision de poids faible dans src1 est multipliée par la valeur correspondante dans src2. Le résultat est mis en négatif et ajouté à la valeur correspondante dans src3, et le résultat obtenu est stocké comme valeur correspondante dans la destination. Les autres valeurs dans src1, src2, et src3 sont ignorées, et la valeur à virgule flottante double précision de poids fort du résultat est égale à 0. L'opération négative multiplier-ajouter est exécutée avec un seul arrondi à la fin, comme si les résultats intermédiaires étaient calculés à une précision infinie.
L'instruction vfnmaddsd fait partie de la famille FMA4 des instructions. Avant d'utiliser cette fonction intrinsèque, vous devez vérifier que le processeur prend en charge cette instruction. Pour déterminer la prise en charge du matériel pour cette instruction, appelez la fonction intrinsèque __cpuid avec InfoType = 0x80000001 et vérifiez le bit 16 de CPUInfo[2] (ECX). Ce bit est égal à 1 lorsque l'instruction est prise en charge, sinon il est égal à 0.
Exemple
#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");
}
Voir aussi
Référence
Autres ressources
Fonctions FMA4 intrinsèques ajoutées pour Visual Studio 2010 SP1
Historique des modifications
Date |
Historique |
Motif |
---|---|---|
Mars 2011 |
Ce contenu a été ajouté. |
Modifications de fonctionnalités dans le SP1. |