__m64_pavg2_nraz
[このドキュメントはプレビュー版であり、後のリリースで変更されることがあります。 Blank topics are included as placeholders.]
Microsoft 固有の仕様 →
入力引数の各 16 ビット ブロックの 2 ビットの符号なし短整数の平均を計算し結果の対応する 16 ビット ブロックにその平均を配置は並列平均 pavg2() 命令のバイトのフォームを生成します。
__m64 __m64_pavg2_nraz(
__m64 a,
__m64 b
);
パラメーター
[入力] a
4 個の 16 ビット符号なし整数の配列を含む __m64 の和集合。[入力] b
4 個の 16 ビット符号なし整数の配列を含む __m64 の和集合。
戻り値
各要素は元の配列の対応する整数の平均値である 4 個の 16 ビット符号なし整数の配列を含む __m64 の和集合。
必要条件
組み込み |
アーキテクチャ |
---|---|
__m64_pavg2_nraz |
IPF |
ヘッダー ファイル <intrin.h>
解説
ほとんどの場合各平均の不適切な結果は最も近い整数に丸められます。 サフィックス nraz になります。「 Zero の丸め」を付けます。
使用例
// pavg2_nraz.cpp
// processor: IPF
#include <stdio.h>
#include <intrin.h>
#pragma intrinsic(__m64_pavg2_nraz)
void print4u(unsigned __int16* ia)
{
printf_s("{ %8u, %8u, %8u, %8u }\n", ia[0], ia[1], ia[2], ia[3] );
}
int main()
{
__m64 m, n, result;
unsigned __int16 ra[4], i;
unsigned __int16 ma[4] = { 10, 100, 70, 10000 };
unsigned __int16 na[4] = { 1, 95, 50, 5000 };
for (i = 0; i < 4; i++)
{
m.m64_u16[i] = ma[i];
n.m64_u16[i] = na[i];
}
printf_s("a: \n");
print4u(ma);
printf_s("b: \n");
print4u(na);
printf_s("\n");
result = __m64_pavg2_nraz(m, n);
printf_s("Parallel Average (a[]+b[])/2 : \n");
print4u(result.m64_u16);
printf_s("\n");
// This operation is commutative.
result = __m64_pavg2_nraz(n, m);
printf_s("Parallel Average (b[]+a[])/2 : \n");
print4u(result.m64_u16);
printf_s("\n");
}