Share via


_mm_haddd_epu16

Se requiere Visual Studio 2010 SP1.

Específicos de Microsoft

Genera la instrucción XOP vphaddwd para realizar la suma de un entero horizontal sin signo de su origen.

__m128i _mm_haddd_epu16 (
   __m128i src
); 

Parámetros

  • [in] src
    Un parámetro de 128 bits que contiene ocho enteros sin signo de 16 bits.

Valor devuelto

Un resultado de 128 bits r que contiene cuatro enteros sin signo de 32 bits.

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

Requisitos

Intrínseco

Arquitectura

_mm_haddd_epu16

XOP

Archivo de encabezado <intrin.h>

Comentarios

Cada uno de los cuatro pares indizados par-impar de valores de entero sin signo de 16 bits en src se agrega para generar un resultado de entero sin signo de 32 bits que se almacena como el valor correspondiente en el destino. Ningún desbordamiento es posible en esta instrucción.

La instrucción vphaddwd forma parte de la familia XOP de instrucciones. Antes de utilizar este intrínseco, debe asegurarse de que el procesador admite esta instrucción. Para determinar la compatibilidad del hardware para obtener esta instrucción, llame a __cpuid intrínseco con InfoType = 0x80000001 y compruebe el bit 11 de CPUInfo [2] (ECX). Este bit es 1 cuando se admite la instrucción, de lo contrario es 0.

Ejemplo

#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");
}
  

Vea también

Referencia

__cpuid, __cpuidex

Otros recursos

_mm_haddw_epu8

_mm_haddq_epu16

_mm_haddd_epu8

_mm_haddd_epi16

Intrínsecos XOP agregados para Visual Studio 2010 SP1

Historial de cambios

Fecha

Historial

Motivo

Marzo de 2011

Se agrega este contenido.

Cambio de características de SP1.