_mm_com_epi32
Требуется Visual Studio 2010 с пакетом обновления 1 (SP1).
Только для систем Microsoft
Формирует инструкцию XOP vpcomd для возвращения битовой маски, формируемой знаковым сравнением "двойное слово-двойное слово" своих первых двух источников с использованием условия, заданного третьим источником.
__m128i _mm_com_epi32 (
__m128i src1,
__m128i src2,
int condition
);
Параметры
[входящий] src1
Упакованный 128-битный массив из четырех 32-битных знаковых целых чисел.[входящий] src2
Упакованный 128-битный массив из четырех 32-битных знаковых целых чисел.[входящий] condition
32-битное целочисленное условие, используемое в сравнении. Допустимые значения — от 0 до 7.
Возвращаемое значение
Упакованный 128-битный массив r из четырех 32-битных целых чисел без знака, каждое из которых равно 0x00000000 или 0xFFFFFFFF. Если параметр cond — логический оператор, подразумеваемый значением параметра condition, то
r[i] := src1[i] cond src2[i] ? 0xFFFFFFFF : 0x00000000;
Требования
Встроенный объект |
Архитектура |
---|---|
_mm_com_epi32 |
XOP |
Файл заголовка <intrin.h>
Заметки
Эта инструкция сравнивает каждое двойное слово параметра src1 с соответствующим двойным словом параметра src2, используя оператор сравнения, описанный параметром condition. (Для каждой пары двойных слов используется тот же оператор сравнения.) Допустимые значения параметра condition — от 0 до 7. Включение заголовка <intrin.h> позволяет использовать следующие имена вместо числовых значений для параметра condition:
Целочисленное значение |
Символическое имя |
Значение |
---|---|---|
0 |
_MM_PCOMCTRL_LT |
r[i] = (src1[i] < src2[i]) ? 0xFFFFFFFF : 0x00000000 |
1 |
_MM_PCOMCTRL_LE |
r[i] = (src1[i] <= src2[i]) ? 0xFFFFFFFF : 0x00000000 |
2 |
_MM_PCOMCTRL_GT |
r[i] = (src1[i] > src2[i]) ? 0xFFFFFFFF : 0x00000000 |
3 |
_MM_PCOMCTRL_GE |
r[i] = (src1[i] >= src2[i]) ? 0xFFFFFFFF : 0x00000000 |
4 |
_MM_PCOMCTRL_EQ |
r[i] = (src1[i] == src2[i]) ? 0xFFFFFFFF : 0x00000000 |
5 |
_MM_PCOMCTRL_NEQ |
r[i] = (src1[i] != src2[i]) ? 0xFFFFFFFF : 0x00000000 |
6 |
_MM_PCOMCTRL_FALSE |
r[i] = 0x00000000 (маска, состоящая из всех нулей) |
7 |
_MM_PCOMCTRL_TRUE |
r[i] = 0xFFFFFFFF (маска, состоящая из всех единиц) |
При желании можно использовать следующие макросы, определяемые при включении заголовка <intrin.h>:
Макрос |
Значение |
---|---|
_mm_comlt_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 0) |
_mm_comle_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 1) |
_mm_comgt_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 2) |
_mm_comge_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 3) |
_mm_comeq_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 4) |
_mm_comneq_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 5) |
_mm_comfalse_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 6) |
_mm_comtrue_epi32(src1, src2) |
_mm_com_epi32(src1, src2, 7) |
Инструкция vpcomd входит в состав семейства инструкций XOP. Прежде чем использовать эту встроенную инструкцию, необходимо убедиться, что процессор ее поддерживает. Чтобы определить, имеется ли аппаратная поддержка этой инструкции, вызовите встроенную инструкцию __cpuid с InfoType = 0x80000001 и проверьте бит 11 в CPUInfo[2] (ECX). Этот бит равен 1, если инструкция поддерживается, и 0 в противном случае.
Пример
#include <stdio.h>
#include <intrin.h>
main()
{
__m128i a, b, d;
int i;
for (i = 0; i < 4; i++) {
a.m128i_i32[i] = 1000*i - 1500;
b.m128i_i32[i] = 2000*i - 2500;
}
printf("src1: ");
for (i = 0; i < 4; i++) printf_s(" %8d", a.m128i_i32[i]);
printf_s("\nsrc2: ");
for (i = 0; i < 4; i++) printf_s(" %8d", b.m128i_i32[i]);
printf_s("\n!= mask: ");
d = _mm_com_epi32(a, b, _MM_PCOMCTRL_NEQ);
for (i = 0; i < 4; i++) printf_s(" %08x", d.m128i_u32[i]);
printf_s("\ntrue mask: ");
d = _mm_com_epi32(a, b, _MM_PCOMCTRL_TRUE);
for (i = 0; i < 4; i++) printf_s(" %08x", d.m128i_u32[i]);
printf("\n");
}
См. также
Другие ресурсы
Встроенные объекты XOP, добавленные в Visual Studio 2010 с пакетом обновления 1 (SP1)
Журнал изменений
Дата |
Журнал |
Причина |
---|---|---|
Март 2011 |
Добавлено это содержимое. |
Изменение функции SP1. |