_mm_haddd_epu16
È necessario Visual Studio 2010 SP1.
Specifici di Microsoft
Genera l'istruzione XOP vphaddwd per eseguire l'aggiunta orizzontale di un intero senza segno dell'origine.
__m128i _mm_haddd_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 quattro interi senza segno a 32 bit.
r[i] := src[2*i] + src[2*i+1];
Requisiti
Intrinseco |
Architettura |
---|---|
_mm_haddd_epu16 |
XOP |
File di intestazione <intrin.h>
Note
Ognuna delle quattro coppie di valori Unsigned Integer a 16 bit con indice pari-dispari in src viene aggiunta 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 vphaddwd è 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 < 2; i++) {
a.m128i_i16[4*i] = -128;
a.m128i_i16[4*i+1] = i-128;
a.m128i_i16[4*i+2] = 10*i;
a.m128i_i16[4*i+3] = 127;
}
// Note that this intrinsic treats negative values as unsigned
// So, e.g., -1 becomes 65535
d = _mm_haddd_epu16(a);
for (i = 0; i < 4; i++) printf_s(" %u", d.m128i_u32[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. |