_mm_haddq_epu8
Visual Studio 2010 SP1 est requis
Spécifique à Microsoft
Génère l'instruction XOP vphaddubq pour exécuter une opération d'ajout horizontale d'un entier non signé de sa source.
__m128i _mm_haddq_epu8 (
__m128i src
);
Paramètres
- [in] src
Paramètre de 128 bits qui contient seize entiers non signés de 8 bits.
Valeur de retour
Résultat r de 128 bits qui contient deux entiers non signés de 64 bits.
r[i] := src[8*i] + src[8*i+1] + src[8*i+2] + src[8*i+3] +
src[8*i+4] + src[8*i+5] + src[8*i+6] + src[8*i+7];
Configuration requise
Intrinsèque |
Architecture |
---|---|
_mm_haddq_epu8 |
XOP |
Fichier d'en-tête <intrin.h>
Notes
Chacune des deux séries de huit valeurs de l'entier non signé de 8 bits dans src est ajoutée pour produire un résultat d'un entier non signé de 64 bits stocké comme valeur correspondante dans la destination. Aucun dépassement de capacité n'est possible dans cette instruction.
L'instruction vphaddubq 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 < 4; i++) {
a.m128i_i8[i] = -128;
a.m128i_i8[i+4] = i-128;
a.m128i_i8[i+8] = 10*i;
a.m128i_i8[i+12] = 127;
}
// Note that this intrinsic treats negative values as unsigned
// So, e.g., -128 becomes +128
d = _mm_haddq_epu8(a);
for (i = 0; i < 2; i++) printf_s(" %I64u", d.m128i_u64[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. |