Function core::arch::x86::_mm256_cvtps_ph[][src]

pub unsafe fn _mm256_cvtps_ph<const IMM_ROUNDING: i32>(a: __m256) -> __m128i
🔬 This is a nightly-only experimental API. (stdsimd #48556)
This is supported on x86 and target feature f16c only.
Expand description

将 256 位 vector a 中的 8 x 32 位浮点值转换为 8 x 16 位半精度浮点值存储在 128 位宽的 vector 中。

根据 imm_rounding 参数进行舍入,该参数可以是以下之一:

  • _MM_FROUND_TO_NEAREST_INT | _MM_FROUND_NO_EXC: 四舍五入并排除异常,
  • _MM_FROUND_TO_NEG_INF | _MM_FROUND_NO_EXC: 四舍五入并排除异常,
  • _MM_FROUND_TO_POS_INF | _MM_FROUND_NO_EXC: 汇总并排除异常,
  • _MM_FROUND_TO_ZERO | _MM_FROUND_NO_EXC: 截断并抑制异常,
  • _MM_FROUND_CUR_DIRECTION: 使用 MXCSR.RC - 请参见 _MM_SET_ROUNDING_MODE