Partager via


_mm_maddsd_epi16

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère l'instruction XOP vpmadcswd pour exécuter une opération cumulative multiplier-additionner de saturation d'un entier de ses sources.

__m128i _mm_maddsd_epi16 (
   __m128i src1,
   __m128i src2,
   __m128i src3
);

Paramètres

  • [in] src1
    Un paramètre de 128 bits qui contient huit entiers de 16 bits signés.

  • [in] src2
    Un paramètre de 128 bits qui contient huit entiers de 16 bits signés.

  • [in] src3
    Un paramètre de 128 bits qui contient quatre entiers signés de 32 bits.

Valeur de retour

Résultat r de 128 bits qui contient quatre entiers signés de 32 bits.

tempeven[i] := src1[2*i] * src2[2*i]; // 16*16->32
tempodd[i] := src1[2*i+1] * src2[2*i+1]; // 16*16->32
r[i] = tempeven[i] + tempodd[i] + src3[i];

Configuration requise

Intrinsèque

Architecture

_mm_maddsd_epi16

XOP

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

Notes

Chaque valeur de l'entier signé de 16 bits à index pair dans src1 est multipliée par la valeur de l'entier signé de 16 bits correspondante dans src2. La valeur de l'entier signé de 16 bits (index impair) suivante dans src1 est multipliée par la valeur de l'entier signé de 16 bits correspondante dans src2. Les produits de l'entier signé de 32 bits sont ajoutés, leur somme est ajoutée à la valeur de l'entier signé de 32 bits correspondante dans src3, et le résultat sous forme d'entier de 32 bits signé est stocké comme valeur correspondante dans la destination.

Si le résultat de l'opération cumulative multiplier-ajouter est supérieur à 2147483647 (0x7FFFFFFF) ou inférieur à -2147483648 (0x80000000), l'opération cumulative multiplier-ajouter sature en affectant respectivement 2147483647 ou -2147483648 à la valeur du résultat.

L'instruction vpmadcswd fait partie de la famille XOP 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 11 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()
{
    __m128i a, b, c, d;
    int i;
    for (i = 0; i < 8; i++) {
        a.m128i_i16[i] = 8000*(i-4);
        b.m128i_i16[i] = 10000;
    }
    for (i = 0; i < 4; i++) {
        c.m128i_i32[i] = -1900000000;
    }
    d = _mm_maddsd_epi16(a, b, c);
    for (i = 0; i < 4; i++) printf_s(" %d", d.m128i_i32[i]);
    printf_s("\n");
}
  

Voir aussi

Référence

__cpuid, __cpuidex

Autres ressources

_mm_maddd_epi16

Fonctions XOP 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.