92 lines
2.3 KiB
C
92 lines
2.3 KiB
C
#if !defined(SIMDE_X86_AVX512_FLUSHSUBNORMAL_H)
|
|
#define SIMDE_X86_AVX512_FLUSHSUBNORMAL_H
|
|
|
|
#include "types.h"
|
|
|
|
HEDLEY_DIAGNOSTIC_PUSH
|
|
SIMDE_DISABLE_UNWANTED_DIAGNOSTICS
|
|
SIMDE_BEGIN_DECLS_
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m128
|
|
simde_x_mm_flushsubnormal_ps (simde__m128 a) {
|
|
simde__m128_private a_ = simde__m128_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f32) / sizeof(a_.f32[0])) ; i++) {
|
|
a_.f32[i] = simde_math_issubnormalf(a_.f32[i]) ? 0 : a_.f32[i];
|
|
}
|
|
|
|
return simde__m128_from_private(a_);
|
|
}
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m256
|
|
simde_x_mm256_flushsubnormal_ps (simde__m256 a) {
|
|
simde__m256_private a_ = simde__m256_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f32) / sizeof(a_.f32[0])) ; i++) {
|
|
a_.f32[i] = simde_math_issubnormalf(a_.f32[i]) ? 0 : a_.f32[i];
|
|
}
|
|
|
|
return simde__m256_from_private(a_);
|
|
}
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m512
|
|
simde_x_mm512_flushsubnormal_ps (simde__m512 a) {
|
|
simde__m512_private a_ = simde__m512_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f32) / sizeof(a_.f32[0])) ; i++) {
|
|
a_.f32[i] = simde_math_issubnormalf(a_.f32[i]) ? 0 : a_.f32[i];
|
|
}
|
|
|
|
return simde__m512_from_private(a_);
|
|
}
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m128d
|
|
simde_x_mm_flushsubnormal_pd (simde__m128d a) {
|
|
simde__m128d_private a_ = simde__m128d_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f64) / sizeof(a_.f64[0])) ; i++) {
|
|
a_.f64[i] = simde_math_issubnormal(a_.f64[i]) ? 0 : a_.f64[i];
|
|
}
|
|
|
|
return simde__m128d_from_private(a_);
|
|
}
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m256d
|
|
simde_x_mm256_flushsubnormal_pd (simde__m256d a) {
|
|
simde__m256d_private a_ = simde__m256d_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f64) / sizeof(a_.f64[0])) ; i++) {
|
|
a_.f64[i] = simde_math_issubnormal(a_.f64[i]) ? 0 : a_.f64[i];
|
|
}
|
|
|
|
return simde__m256d_from_private(a_);
|
|
}
|
|
|
|
SIMDE_FUNCTION_ATTRIBUTES
|
|
simde__m512d
|
|
simde_x_mm512_flushsubnormal_pd (simde__m512d a) {
|
|
simde__m512d_private a_ = simde__m512d_to_private(a);
|
|
|
|
SIMDE_VECTORIZE
|
|
for (size_t i = 0 ; i < (sizeof(a_.f64) / sizeof(a_.f64[0])) ; i++) {
|
|
a_.f64[i] = simde_math_issubnormal(a_.f64[i]) ? 0 : a_.f64[i];
|
|
}
|
|
|
|
return simde__m512d_from_private(a_);
|
|
}
|
|
|
|
SIMDE_END_DECLS_
|
|
HEDLEY_DIAGNOSTIC_POP
|
|
|
|
#endif /* !defined(SIMDE_X86_AVX512_FLUSHSUBNORMAL_H) */
|