Condividi tramite


_mm_haddq_epu16

È necessario Visual Studio 2010 SP1.

Specifici di Microsoft

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

__m128i _mm_haddq_epu16 (
   __m128i src
); 

Parametri

  • [in] src
    Parametro a 128 bit che contiene otto interi senza segno a 16 bit.

Valore restituito

Risultato a 128 bit r che contiene due interi senza segno a 64 bit.

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

Requisiti

Intrinseco

Architettura

_mm_haddq_epu16

XOP

File di intestazione <intrin.h>

Note

Ognuno dei due gruppi di quattro valori Unsigned Integer a 16 bit in src viene aggiunto per produrre una somma Unsigned Integer a 64 bit che viene archiviata come valore corrispondente nella destinazione. Non è possibile alcun overflow in questa istruzione.

L'istruzione vphadduwq è 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_i16[i] = i-128;
        a.m128i_i16[i+4] = 127-i;
    }
    // Note that this intrinsic treats negative values as unsigned
    // So, e.g., -1 becomes +65535
    d = _mm_haddq_epu16(a);
    for (i = 0; i < 2; i++) printf_s(" %I64u", d.m128i_u64[i]);
    printf_s("\n");
}
  

Vedere anche

Riferimenti

__cpuid, __cpuidex

Altre risorse

_mm_haddw_epu8

_mm_haddd_epu16

_mm_haddq_epu8

_mm_haddq_epu32

_mm_haddq_epi16

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.