Exportar (0) Imprimir
Expandir todo
Expandir Minimizar

_mm_min_epi8

Microsoft Specific

Emits the Streaming SIMD Extensions 4 (SSE4) instruction pminsb. This instruction chooses the smaller value of the two parameters.

__m128i _mm_min_epi8( 
   __m128i a,
   __m128i b 
);

[in] a

A 128-bit parameter that contains sixteen 8-bit signed integers.

[in] b

A 128-bit parameter that contains sixteen 8-bit signed integers.

A 128-bit parameter that can be defined with the following equations:

r0 := (a0 < b0) ? a0 : b0
r1 := (a1 < b1) ? a1 : b1
...
r15 := (a15 < b15) ? a15 : b15

Intrinsic

Architecture

_mm_min_epi8

x86, x64

Header file <smmintrin.h>

r0-r15, a0-a15, and b0-b15 are the sequentially ordered 8-bit components of return value r and parameters a and b. r0, a0, and b0 are the least significant 8 bits.

Before you use this intrinsic, software must ensure that the processor supports the instruction.

#include <stdio.h>
#include <smmintrin.h>

int main ()
{
    __m128i a, b;

    a.m128i_i8[0] = 1;
    a.m128i_i8[1] = 2;
    a.m128i_i8[2] = 4;
    a.m128i_i8[3] = 8;
    a.m128i_i8[4] = 16;
    a.m128i_i8[5] = 32;
    a.m128i_i8[6] = 64;
    a.m128i_i8[7] = 127;
    a.m128i_i8[8] = -15;
    a.m128i_i8[9] = 15;
    a.m128i_i8[10] = 1;
    a.m128i_i8[11] = -45;
    a.m128i_i8[12] = 31;
    a.m128i_i8[13] = -100;
    a.m128i_i8[14] = 100;
    a.m128i_i8[15] = -23;

    b.m128i_i8[0] = 127;
    b.m128i_i8[1] = -64;
    b.m128i_i8[2] = 32;
    b.m128i_i8[3] = -16;
    b.m128i_i8[4] = 8;
    b.m128i_i8[5] = -4;
    b.m128i_i8[6] = 2;
    b.m128i_i8[7] = -1;
    b.m128i_i8[8] = 0;
    b.m128i_i8[9] = 0;
    b.m128i_i8[10] = -1;
    b.m128i_i8[11] = -50;
    b.m128i_i8[12] = 31;
    b.m128i_i8[13] = -4;
    b.m128i_i8[14] = 50;
    b.m128i_i8[15] = -24;

    __m128i res = _mm_min_epi8(a, b);

    printf_s("   a\t   b\t res\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n",
                a.m128i_i8[0], b.m128i_i8[0], res.m128i_i8[0],
                a.m128i_i8[1], b.m128i_i8[1], res.m128i_i8[1],
                a.m128i_i8[2], b.m128i_i8[2], res.m128i_i8[2]);
    printf_s("%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n",
                a.m128i_i8[3], b.m128i_i8[3], res.m128i_i8[3],
                a.m128i_i8[4], b.m128i_i8[4], res.m128i_i8[4],
                a.m128i_i8[5], b.m128i_i8[5], res.m128i_i8[5],
                a.m128i_i8[6], b.m128i_i8[6], res.m128i_i8[6]);
    printf_s("%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n",
                a.m128i_i8[7], b.m128i_i8[7], res.m128i_i8[7],
                a.m128i_i8[8], b.m128i_i8[8], res.m128i_i8[8],
                a.m128i_i8[9], b.m128i_i8[9], res.m128i_i8[9],
                a.m128i_i8[10], b.m128i_i8[10], res.m128i_i8[10]);
    printf_s("%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n%4d\t%4d\t%4d\n",
                a.m128i_i8[11], b.m128i_i8[11], res.m128i_i8[11],
                a.m128i_i8[12], b.m128i_i8[12], res.m128i_i8[12],
                a.m128i_i8[13], b.m128i_i8[13], res.m128i_i8[13],
                a.m128i_i8[14], b.m128i_i8[14], res.m128i_i8[14]);
    printf_s("%4d\t%4d\t%4d\n",
                a.m128i_i8[15], b.m128i_i8[15], res.m128i_i8[15]);

    return 0;
}
   a       b     res
   1     127       1
   2     -64     -64
   4      32       4
   8     -16     -16
  16       8       8
  32      -4      -4
  64       2       2
 127      -1      -1
 -15       0     -15
  15       0       0
   1      -1      -1
 -45     -50     -50
  31      31      31
-100      -4    -100
 100      50      50
 -23     -24     -24

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft