絶対値組み込み関数

このインテル® ストリーミング SIMD 拡張命令 3 補足命令 (インテル® SSSE3) 組み込み関数は、絶対値を計算するのに使用されます。これらの組み込み関数のプロトタイプは、tmmintrin.h 内にあります。これらの組み込み関数に対して ia32intrin.h ヘッダーファイルを使用することもできます。

extern __m128i _mm_abs_epi8 (__m128i a);

符号付きバイトの絶対値を計算します。

符号付き 8 ビット整数の配列として ar を解釈します。

for (i = 0; i < 16; i++){

   r[i] = abs(a[i]);

}

 

extern __m128i _mm_abs_epi16 (__m128i a);

符号付きワードの絶対値を計算します。

符号付き 16 ビット整数の配列として ar を解釈します。

for (i = 0; i < 8; i++){

   r[i] = abs(a[i]);

}

 

extern __m128i _mm_abs_epi32 (__m128i a);

符号付きダブルワードの絶対値を計算します。

符号付き 32 ビット整数の配列として ar を解釈します。

for (i = 0; i < 4; i++) {

   r[i] = abs(a[i]);

}

 

extern __m64 _mm_abs_pi8 (__m64 a);

符号付きバイトの絶対値を計算します。

符号付き 8 ビット整数の配列として ar を解釈します。

for (i = 0; i < 8; i++){

   r[i] = abs(a[i]);

}

 

extern __m64 _mm_abs_pi16 (__m64 a);

符号付きワードの絶対値を計算します。

符号付き 16 ビット整数の配列として ar を解釈します。

for (i = 0; i < 4; i++) {

   r[i] = abs(a[i]);

}

 

extern __m64 _mm_abs_pi32 (__m64 a);

符号付きダブルワードの絶対値を計算します。

符号付き 32 ビット整数の配列として ar を解釈します。

for (i = 0; i < 2; i++) {

   r[i] = abs(a[i]);

}