_mm_haddq_epu8
È necessario Visual Studio 2010 SP1.
Specifici di Microsoft
Genera l'istruzione XOP vphaddubq per eseguire l'aggiunta orizzontale di un intero senza segno dell'origine.
__m128i _mm_haddq_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 due interi senza segno a 64 bit.
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];
Requisiti
Intrinseco |
Architettura |
---|---|
_mm_haddq_epu8 |
XOP |
File di intestazione <intrin.h>
Note
Ognuno dei due set di otto valori Unsigned Integer a 8 bit in src viene aggiunto per produrre un risultato Unsigned Integer a 64 bit che viene archiviato come valore corrispondente nella destinazione. Non è possibile alcun overflow in questa istruzione.
L'istruzione vphaddubq è 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_haddq_epu8(a);
for (i = 0; i < 2; i++) printf_s(" %I64u", d.m128i_u64[i]);
printf_s("\n");
}
Vedere anche
Riferimenti
Altre risorse
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. |