Condividi tramite


_mm_haddd_epu8

È necessario Visual Studio 2010 SP1.

Specifici di Microsoft

Genera l'istruzione XOP vphaddubd per eseguire l'aggiunta orizzontale di un intero senza segno dell'origine.

__m128i _mm_haddd_epu8 (
   __m128i src
); 

Parametri

  • [in] src
    Parametro a 128 bit che contiene sedici interi senza segno a 8 bit.

Valore restituito

Risultato a 128 bit r che contiene quattro interi senza segno a 32 bit.

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

Requisiti

Intrinseco

Architettura

_mm_haddd_epu8

XOP

File di intestazione <intrin.h>

Note

Ognuno dei quattro gruppi di valori Unsigned Integer a 8 bit in src viene aggiunto per produrre un risultato Unsigned Integer a 32 bit che viene archiviato come valore corrispondente nella destinazione. Non è possibile alcun overflow in questa istruzione.

L'istruzione vphaddubd è parte della famiglia XOP di istruzioni. Prima di utilizzare questo intrinseco, è necessario assicurarsi che il processore supporti questa istruzione. Per determinare il supporto hardware per questa istruzione, chiamare l'intrinseco __cpuid con InfoType = 0x80000001 e il bit di controllo 11 di CPUInfo[2] (ECX). Questo bit è 1 quando l'istruzione è supportata, e 0 in caso contrario.

Esempio

#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_haddd_epu8(a);
    for (i = 0; i < 4; i++) printf_s(" %u", d.m128i_u32[i]);
    printf_s("\n");
}
  

Vedere anche

Riferimenti

__cpuid, __cpuidex

Altre risorse

_mm_haddw_epu8

_mm_haddq_epu8

_mm_haddd_epu16

_mm_haddd_epi8

Oggetti intrinseci XOP aggiunti per Visual Studio 2010 SP1

Cronologia delle modifiche

Data

Cronologia

Motivo

Marzo 2011

È stato aggiunto questo contenuto.

Modifica di funzionalità in SP1.