Обычная операция, которую я выполняю в своей программе, - это масштабирование векторов скаляром (V * s, например, [1,2,3,4] * 2 == [2,4,6,8]).Есть ли для этого инструкция SSE (или AVX), кроме первой загрузки скаляра в каждой позиции в векторе (например, _mm_set_ps (2,2,2,2)), а затем умножения?
Эточто я делаю сейчас:
__m128 _scalar = _mm_set_ps(s,s,s,s);
__m128 _result = _mm_mul_ps(_vector, _scalar);
Я ищу что-то вроде ...
__m128 _result = _mm_scale_ps(_vector, s);