インテル® C++ コンパイラー 15.0 ユーザー・リファレンス・ガイド
int64 インデックスを使用して、int32 ベクトルを集約 (Gather) します。対応する命令は VPGATHERDQ です。この組込み関数は、インテル® メニー・インテグレーテッド・コア (インテル® MIC) アーキテクチャーにのみ適用されます。
マスクなし __m512i _mm512_i64extgather_epi64(_m512i index, void const* mv, _MM_UPCONV_EPI64_ENUM conv, int scale, int hint); __m512i _mm512_i64gather_epi64(_m512i index, void const* mv, int scale); |
マスク付き __m512i _mm512_mask_i64extgather_epi64(_m512 v1_old, __mmask8 k1, __m512i index, void const* mv, _MM_UPCONV_EPI64_ENUM conv, int scale, int hint); __m512i _mm512_mask_i64gather_epi64(_m512 v1_old, __mmask8 k1, __m512i index, void const* mv, int scale); |
ベースアドレス mv と int64 インデックス・ベクトル index により指定される 8 つのメモリー位置に対して、スケールファクター scale を使用して順方向変換を行い、結果を int64 ベクトルに集約 (Gather) します。
マスク付きの結果ベクトルには、書き込みマスクベクトル k1 の対応するビットがセットされている要素がコピーされます。マスク付きの結果ベクトルの残りの要素には、v1_old の要素がコピーされます。
マスクなしの組込み関数は、フルマスク (k1=0xffff) のマスク付き組込み関数と同等です。
順方向変換集約操作の結果。