Please enter what you're looking for to continue your search
 

_mm512_min_epi16
ADD TO COMPARE ADDED TO COMPARE

 Location: Math Functions  >  Vector Minimum
 CPU Extensions: AVX512BW
Purpose:
Compare packed signed 16-bit integers in "a" and "b", and store packed minimum values in "dst".
Result:

__m512i

Example:
#include <immintrin.h>
#include <stdio.h>
int main() {
 __m512i a = _mm512_set_epi16(1, 200, -300, 400, -500, 600, -700, 800,                                 -900, 1000, -1100, 1200, -1300, 1400, -1500, 1600,                                 1700, 1800, 1900, 2000, 2100, 2200, 2300, 2400,                                 2500, 2600, 2700, 2800, 2900, 3000, 3100, 3200);
 __m512i b = _mm512_set_epi16(0, 100, -100, 500, -600, 500, -800, 700,                                 -1000, 900, -1200, 1100, -1400, 1300, -1600, 1500,                                 1600, 1700, 1800, 1900, 2000, 2100, 2200, 2300,                                 2400, 2500, 2600, 2700, 2800, 2900, 3000, 3100);
 __m512i r = _mm512_min_epi16(a, b);
 int* p = (int*)&r;
 for (int i = 0; i < 32; i++) {
   printf("%d ", p[i]);
  }

  return 0;
 }

Prototypes

Assembly Instruction:
vpminsw
Usage:
__m512i result = _mm512_min_epi16( __m512i a, __m512i b )
Performance Metrics:
📊 Unlock Performance Insights

Get access to detailed performance metrics including latency, throughput, and CPU-specific benchmarks for this intrinsic.

SIMD Intrinsics Summary
SIMD Engines: 6
C Intrinsics: 10444
NEON: 4353
AVX2: 405
AVX512: 4717
SSE4.2: 598
VSX: 192
IBM-Z: 179