_mm512_reduce_round_ps
Classification
AVX-512, Miscellaneous, CPUID Test: AVX512DQ
Header File
immintrin.h
Instruction
VREDUCEPS zmm, zmm {sae}, imm8
Synopsis
 _mm512_reduce_round_ps(__m512 a, int imm8, int sae);
Description
Extract the reduced argument of packed single-precision (32-bit) floating-point elements in "a" by the number of bits specified by "imm8", and store the results in "dst". [round_imm_note][sae_note]
Operation
DEFINE ReduceArgumentPS(src1[31:0], imm8[7:0]) {
	m[31:0] := FP32(imm8[7:4]) // number of fraction bits after the binary point to be preserved
	tmp[31:0] := POW(FP32(2.0), -m) * ROUND(POW(FP32(2.0), m) * src1[31:0], imm8[3:0])
	tmp[31:0] := src1[31:0] - tmp[31:0]
	IF IsInf(tmp[31:0])
		tmp[31:0] := FP32(0.0)
	FI
	RETURN tmp[31:0]
}
FOR j := 0 to 15
	i := j*32
	dst[i+31:i] := ReduceArgumentPS(a[i+31:i], imm8[7:0])
ENDFOR
dst[MAX:512] := 0