_mm_hsubd_epi16
Visual Studio 2010 SP1 est requis
Spécifique à Microsoft
Génère l'instruction XOP vphsubwd pour exécuter une opération de soustraction horizontale d'un entier de sa source.
__m128i _mm_hsubd_epi16 (
__m128i src
);
Paramètres
- [in] src
Un paramètre de 128 bits qui contient huit entiers de 16 bits signés.
Valeur de retour
Résultat r de 128 bits qui contient quatre entiers signés de 32 bits.
r[i] := src[2*i] - src[2*i+1];
Configuration requise
Intrinsèque |
Architecture |
---|---|
_mm_hsubd_epi16 |
XOP |
Fichier d'en-tête <intrin.h>
Notes
Pour chacune des quatre paires indexées (pair-impair) des valeurs de l'entier signé de 16 bits dans src, la valeur de poids fort est soustraite de la valeur de poids faible pour produire un résultat d'un entier signé de 32 bits qui est stocké comme valeur correspondante dans la destination.
L'instruction vphsubwd 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, d;
int i;
for (i = 0; i < 8; i++) {
a.m128i_i16[i] = ((20011*i) % 32749);
}
d = _mm_hsubd_epi16(a);
for (i = 0; i < 8; i++) printf_s(" %5d", a.m128i_i16[i]);
printf_s("\n");
for (i = 0; i < 4; i++) printf_s(" %11d", d.m128i_i32[i]);
printf_s("\n");
}
Voir aussi
Référence
Autres ressources
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. |