Partager via


_mm_nmsub_ss

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère l'instruction XMM FMA4 vfnmsubss pour exécuter une opération négative multiplier-soustraire à virgule flottante avec un seul arrondi des valeurs à virgule flottante de poids faible de ses sources.

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

Paramètres

  • [in] src1
    Un paramètre de 128 bits qui contient une valeur à virgule flottante 32 bits dans le mot double de poids faible.

  • [in] src2
    Un paramètre de 128 bits qui contient une valeur à virgule flottante 32 bits dans le mot double de poids faible.

  • [in] src3
    Un paramètre de 128 bits qui contient une valeur à virgule flottante 32 bits dans le mot double de poids faible.

Valeur de retour

Résultat r de 128 bits qui contient quatre valeurs à virgule flottante de 32 bits.

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

Configuration requise

Intrinsèque

Architecture

_mm_nmsub_ss

FMA4

Fichier d'en-tête <intrin.h>

Notes

La valeur à virgule flottante simple précision de poids faible dans src1 est multipliée par la valeur correspondante dans src2. Le résultat est mis en négatif, la valeur correspondante dans src3 est soustraite de ce résultat, 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 les trois valeurs à virgule flottante de poids fort du résultat ont la valeur 0. L'opération négative multiplication-soustraction 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 vfnmsubss 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()
{
    __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");
}
  

Voir aussi

Référence

__cpuid, __cpuidex

Autres ressources

_mm256_nmsub_ps

_mm_nmsub_ps

_mm_nmsub_sd

_mm_macc_ss

_mm_nmacc_ss

_mm_msub_ss

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.