_mm_scalef_ps
Classification
AVX-512, Miscellaneous, CPUID Test: AVX512F
Header File
immintrin.h
Instruction
VSCALEFPS xmm, xmm, xmm
Synopsis
 _mm_scalef_ps(__m128 a, __m128 b);
Description
Scale the packed single-precision (32-bit) floating-point elements in "a" using values from "b", and store the results in "dst".
Operation
DEFINE SCALE(src1, src2) {
	IF (src2 == NaN)
		IF (src2 == SNaN)
			RETURN QNAN(src2)
		FI
	ELSE IF (src1 == NaN)
		IF (src1 == SNaN)
			RETURN QNAN(src1)
		FI
		IF (src2 != INF)
			RETURN QNAN(src1)
		FI
	ELSE
		tmp_src2 := src2
		tmp_src1 := src1
		IF (IS_DENORMAL(src2) AND MXCSR.DAZ)
			tmp_src2 := 0
		FI
		IF (IS_DENORMAL(src1) AND MXCSR.DAZ)
			tmp_src1 := 0
		FI
	FI
	dst[31:0] := tmp_src1[31:0] * POW(2.0, FLOOR(tmp_src2[31:0]))
	RETURN dst[31:0]
}
FOR j := 0 to 3
	i := j*32
	dst[i+31:i] := SCALE(a[i+31:0], b[i+31:i])
ENDFOR
dst[MAX:128] := 0