image/svg+xml VRANGEPS—Range Restriction Calculation For Packed Pairs of Float32 ValuesInstruction Operand EncodingDescriptionThis instruction calculates 4/8/16 range operation outputs from two sets of packed input single-precision FP values in the first source operand (the second operand) and the second source operand (the third operand). The range outputs are written to the destination operand (the first operand) under the writemask k1. Bits7:4 of imm8 byte must be zero. The range operation output is performed in two parts, each configured by a two-bit control field within imm8[3:0]:Imm8[1:0] specifies the initial comparison operation to be one of max, min, max absolute value or min absolute value of the input value pair. Each comparison of two input values produces an intermediate result that combines with the sign selection control (Imm8[3:2]) to determine the final range operation output.Imm8[3:2] specifies the sign of the range operation output to be one of the following: from the first input value, from the comparison result, set or clear.The encodings of Imm8[1:0] and Imm8[3:2] are shown in Figure5-27.When one or more of the input value is a NAN, the comparison operation may signal invalid exception (IE). Details with one of more input value is NAN is listed in Table 5-10. If the comparison raises an IE, the sign select control (Imm8[3:2]) has no effect to the range operation output, this is indicated also in Table 5-10.When both input values are zeros of opposite signs, the comparison operation of MIN/MAX in the range compare operation is slightly different from the conceptually similar FP MIN/MAX operation that are found in the instructions VMAXPD/VMINPD. The details of MIN/MAX/MIN_ABS/MAX_ABS operation for VRANGEPD/PS/SD/SS for magni-tude-0, opposite-signed input cases are listed in Table 5-11.Additionally, non-zero, equal-magnitude with opposite-sign input values perform MIN_ABS or MAX_ABS compar-ison operation with result listed in Table 5-12.Opcode/InstructionOp / En64/32 bit Mode SupportCPUID Feature FlagDescriptionEVEX.128.66.0F3A.W0 50 /r ibVRANGEPS xmm1 {k1}{z}, xmm2, xmm3/m128/m32bcst, imm8AV/VAVX512VLAVX512DQCalculate four RANGE operation output value from 4 pairs of single-precision floating-point values in xmm2 and xmm3/m128/m32bcst, store the results to xmm1 under the writemask k1. Imm8 specifies the comparison and sign of the range operation.EVEX.256.66.0F3A.W0 50 /r ibVRANGEPS ymm1 {k1}{z}, ymm2, ymm3/m256/m32bcst, imm8AV/VAVX512VLAVX512DQCalculate eight RANGE operation output value from 8 pairs of single-precision floating-point values in ymm2 and ymm3/m256/m32bcst, store the results to ymm1 under the writemask k1. Imm8 specifies the comparison and sign of the range operation.EVEX.512.66.0F3A.W0 50 /r ibVRANGEPS zmm1 {k1}{z}, zmm2, zmm3/m512/m32bcst{sae}, imm8AV/VAVX512DQCalculate 16 RANGE operation output value from 16 pairs of single-precision floating-point values in zmm2 and zmm3/m512/m32bcst, store the results to zmm1 under the writemask k1. Imm8 specifies the comparison and sign of the range operation.Op/EnTuple TypeOperand 1Operand 2Operand 3Operand 4AFullModRM:reg (w)EVEX.vvvv (r)ModRM:r/m (r)Imm8

image/svg+xmlOperationRangeSP(SRC1[31:0], SRC2[31:0], CmpOpCtl[1:0], SignSelCtl[1:0]){// Check if SNAN and report IE, see also Table 5-10IF (SRC1=SNAN) THEN RETURN (QNAN(SRC1), set IE);IF (SRC2=SNAN) THEN RETURN (QNAN(SRC2), set IE);Src1.exp := SRC1[30:23];Src1.fraction := SRC1[22:0];IF ((Src1.exp = 0 ) and (Src1.fraction != 0 )) THEN// Src1 is a denormal numberIF DAZ THEN Src1.fraction := 0;ELSE IF (SRC2 <> QNAN) Set DE; FI;FI;Src2.exp := SRC2[30:23];Src2.fraction := SRC2[22:0];IF ((Src2.exp = 0 ) and (Src2.fraction != 0 )) THEN// Src2 is a denormal numberIF DAZ THEN Src2.fraction := 0;ELSE IF (SRC1 <> QNAN) Set DE; FI;FI;IF (SRC2 = QNAN) THEN{TMP[31:0] := SRC1[31:0]}ELSE IF(SRC1 = QNAN) THEN{TMP[31:0] := SRC2[31:0]}ELSE IF (Both SRC1, SRC2 are magnitude-0 and opposite-signed) TMP[31:0] := from Table 5-11ELSE IF (Both SRC1, SRC2 are magnitude-equal and opposite-signed and CmpOpCtl[1:0] > 01) TMP[31:0] := from Table 5-12ELSE Case(CmpOpCtl[1:0])00: TMP[31:0] := (SRC1[31:0] SRC2[31:0]) ? SRC1[31:0] : SRC2[31:0];01: TMP[31:0] := (SRC1[31:0] SRC2[31:0]) ? SRC2[31:0] : SRC1[31:0];10: TMP[31:0] := (ABS(SRC1[31:0]) ABS(SRC2[31:0])) ? SRC1[31:0] : SRC2[31:0];11: TMP[31:0] := (ABS(SRC1[31:0]) ABS(SRC2[31:0])) ? SRC2[31:0] : SRC1[31:0];ESAC;FI;Case(SignSelCtl[1:0])00: dest := (SRC1[31] << 31) OR (TMP[30:0]);// Preserve Src1 sign bit01: dest := TMP[31:0];// Preserve sign of compare result10: dest := (0 << 31) OR (TMP[30:0]);// Zero out sign bit11: dest := (1 << 31) OR (TMP[30:0]);// Set the sign bitESAC;RETURN dest[31:0];}CmpOpCtl[1:0]= imm8[1:0];SignSelCtl[1:0]=imm8[3:2];

image/svg+xmlVRANGEPS (KL, VL) = (4, 128), (8, 256), (16, 512)FOR j := 0 TO KL-1i := j * 32IF k1[j] OR *no writemask* THENIF (EVEX.b == 1) AND (SRC2 *is memory*)THEN DEST[i+31:i] := RangeSP (SRC1[i+31:i], SRC2[31:0], CmpOpCtl[1:0], SignSelCtl[1:0]);ELSE DEST[i+31:i] := RangeSP (SRC1[i+31:i], SRC2[i+31:i], CmpOpCtl[1:0], SignSelCtl[1:0]);FI;ELSE IF *merging-masking*; merging-maskingTHEN *DEST[i+31:i] remains unchanged*ELSE ; zeroing-maskingDEST[i+31:i] = 0FI;FI;ENDFOR;DEST[MAXVL-1:VL] := 0The following example describes a common usage of this instruction for checking that the input operand is bound-ed between ±150.VRANGEPS zmm_dst, zmm_src, zmm_150, 02h;Where:zmm_dst is the destination operand.zmm_src is the input operand to compare against ±150.zmm_150 is the reference operand, contains the value of 150.IMM=02(imm8[1:0]=’10) selects the Min Absolute value operation with selection of src1.sign.In case |zmm_src| < 150, then its value will be written into zmm_dst. Otherwise, the value stored in zmm_dstwill get the value of 150 (received on zmm_150).However, the sign control (imm8[3:2]=’00) instructs to select the sign of SRC1 received from zmm_src. So, evenin the case of |zmm_src| 150, the selected sign of SRC1 is kept. Thus, if zmm_src < -150, the result of VRANGEPS will be the minimal value of -150 while if zmm_src > +150,the result of VRANGE will be the maximal value of +150.

image/svg+xmlIntel C/C++ Compiler Intrinsic EquivalentVRANGEPS __m512 _mm512_range_ps ( __m512 a, __m512 b, int imm);VRANGEPS __m512 _mm512_range_round_ps ( __m512 a, __m512 b, int imm, int sae);VRANGEPS __m512 _mm512_mask_range_ps (__m512 s, __mmask16 k, __m512 a, __m512 b, int imm);VRANGEPS __m512 _mm512_mask_range_round_ps (__m512 s, __mmask16 k, __m512 a, __m512 b, int imm, int sae);VRANGEPS __m512 _mm512_maskz_range_ps ( __mmask16 k, __m512 a, __m512 b, int imm);VRANGEPS __m512 _mm512_maskz_range_round_ps ( __mmask16 k, __m512 a, __m512 b, int imm, int sae);VRANGEPS __m256 _mm256_range_ps ( __m256 a, __m256 b, int imm);VRANGEPS __m256 _mm256_mask_range_ps (__m256 s, __mmask8 k, __m256 a, __m256 b, int imm);VRANGEPS __m256 _mm256_maskz_range_ps ( __mmask8 k, __m256 a, __m256 b, int imm);VRANGEPS __m128 _mm_range_ps ( __m128 a, __m128 b, int imm);VRANGEPS __m128 _mm_mask_range_ps (__m128 s, __mmask8 k, __m128 a, __m128 b, int imm);VRANGEPS __m128 _mm_maskz_range_ps ( __mmask8 k, __m128 a, __m128 b, int imm);SIMD Floating-Point ExceptionsInvalid, DenormalOther ExceptionsSee Table2-46, “Type E2 Class Exception Conditions”.

This UNOFFICIAL reference was generated from the official Intel® 64 and IA-32 Architectures Software Developer’s Manual by a dumb script. There is no guarantee that some parts aren't mangled or broken and is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.