Partager via


_mm_haddd_epi8

Visual Studio 2010 SP1 est requis

Spécifique à Microsoft

Génère l'instruction XOP vphaddbd pour exécuter une opération d'ajout horizontale d'un entier de sa source.

__m128i _mm_haddd_epi8 (
   __m128i src
);

Paramètres

  • [in] src
    Paramètre de 128 bits qui contient seize entiers signés de 8 bits.

Valeur de retour

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

r[i] := src[4*i] + src[4*i+1] + src[4*i+2] + src[4*i+3];

Configuration requise

Intrinsèque

Architecture

_mm_haddd_epi8

XOP

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

Notes

Chacun des quatre groupes de quatre valeurs consécutives de l'entier signé de 8 bits dans src est ajoutée pour produire un résultat d'un entier signé de 32 bits stocké comme valeur correspondante dans la destination. Aucun dépassement de capacité n'est possible dans cette instruction.

L'instruction vphaddbd 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;
    }
    d = _mm_haddd_epi8(a);
    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_haddw_epi8

_mm_haddq_epi8

_mm_haddd_epi16

_mm_haddd_epu8

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.