#ifdefined(SIMDE_X86_AVX512F_NATIVE) #define simde_mm512_maskz_fixupimm_round_ps(k, a, b, c, imm8, sae) _mm512_maskz_fixupimm_round_ps(k, a, b, c, imm8, sae) #elifdefined(SIMDE_FAST_EXCEPTIONS) #define simde_mm512_maskz_fixupimm_round_ps(k, a, b, c, imm8, sae) simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8) #elifdefined(SIMDE_STATEMENT_EXPR_) #ifdefined(SIMDE_HAVE_FENV_H) #define simde_mm512_maskz_fixupimm_round_ps(k, a, b, c, imm8, sae) SIMDE_STATEMENT_EXPR_(({ \
simde__m512 simde_mm512_maskz_fixupimm_round_ps_r; \
\ if (sae & SIMDE_MM_FROUND_NO_EXC) { \
fenv_t simde_mm512_maskz_fixupimm_round_ps_envp; \ int simde_mm512_maskz_fixupimm_round_ps_x = feholdexcept(&simde_mm512_maskz_fixupimm_round_ps_envp); \
simde_mm512_maskz_fixupimm_round_ps_r = simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8); \ if (HEDLEY_LIKELY(simde_mm512_maskz_fixupimm_round_ps_x == 0)) \
fesetenv(&simde_mm512_maskz_fixupimm_round_ps_envp); \
} \ else { \
simde_mm512_maskz_fixupimm_round_ps_r = simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8); \
} \
\
simde_mm512_maskz_fixupimm_round_ps_r; \
})) #else #define simde_mm512_maskz_fixupimm_round_ps(k, a, b, c, imm8, sae) simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8) #endif #else
SIMDE_FUNCTION_ATTRIBUTES
simde__m512
simde_mm512_maskz_fixupimm_round_ps (simde__mmask16 k, simde__m512 a, simde__m512 b, simde__m512i c, int imm8, int sae)
SIMDE_REQUIRE_CONSTANT_RANGE(imm8, 0, 255)
SIMDE_REQUIRE_CONSTANT(sae) {
simde__m512 r;
if (sae & SIMDE_MM_FROUND_NO_EXC) { #ifdefined(SIMDE_HAVE_FENV_H)
fenv_t envp; int x = feholdexcept(&envp);
r = simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8); if (HEDLEY_LIKELY(x == 0))
fesetenv(&envp); #else
r = simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8); #endif
} else {
r = simde_mm512_maskz_fixupimm_ps(k, a, b, c, imm8);
}
#ifdefined(SIMDE_X86_AVX512F_NATIVE) #define simde_mm512_maskz_fixupimm_round_pd(k, a, b, c, imm8, sae) _mm512_maskz_fixupimm_round_pd(k, a, b, c, imm8, sae) #elifdefined(SIMDE_FAST_EXCEPTIONS) #define simde_mm512_maskz_fixupimm_round_pd(k, a, b, c, imm8, sae) simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8) #elifdefined(SIMDE_STATEMENT_EXPR_) #ifdefined(SIMDE_HAVE_FENV_H) #define simde_mm512_maskz_fixupimm_round_pd(k, a, b, c, imm8, sae) SIMDE_STATEMENT_EXPR_(({ \
simde__m512d simde_mm512_maskz_fixupimm_round_pd_r; \
\ if (sae & SIMDE_MM_FROUND_NO_EXC) { \
fenv_t simde_mm512_maskz_fixupimm_round_pd_envp; \ int simde_mm512_maskz_fixupimm_round_pd_x = feholdexcept(&simde_mm512_maskz_fixupimm_round_pd_envp); \
simde_mm512_maskz_fixupimm_round_pd_r = simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8); \ if (HEDLEY_LIKELY(simde_mm512_maskz_fixupimm_round_pd_x == 0)) \
fesetenv(&simde_mm512_maskz_fixupimm_round_pd_envp); \
} \ else { \
simde_mm512_maskz_fixupimm_round_pd_r = simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8); \
} \
\
simde_mm512_maskz_fixupimm_round_pd_r; \
})) #else #define simde_mm512_maskz_fixupimm_round_pd(k, a, b, c, imm8, sae) simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8) #endif #else
SIMDE_FUNCTION_ATTRIBUTES
simde__m512d
simde_mm512_maskz_fixupimm_round_pd (simde__mmask8 k, simde__m512d a, simde__m512d b, simde__m512i c, int imm8, int sae)
SIMDE_REQUIRE_CONSTANT_RANGE(imm8, 0, 255)
SIMDE_REQUIRE_CONSTANT(sae) {
simde__m512d r;
if (sae & SIMDE_MM_FROUND_NO_EXC) { #ifdefined(SIMDE_HAVE_FENV_H)
fenv_t envp; int x = feholdexcept(&envp);
r = simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8); if (HEDLEY_LIKELY(x == 0))
fesetenv(&envp); #else
r = simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8); #endif
} else {
r = simde_mm512_maskz_fixupimm_pd(k, a, b, c, imm8);
}
#ifdefined(SIMDE_X86_AVX512F_NATIVE) #define simde_mm_maskz_fixupimm_round_ss(k, a, b, c, imm8, sae) _mm_maskz_fixupimm_round_ss(k, a, b, c, imm8, sae) #elifdefined(SIMDE_FAST_EXCEPTIONS) #define simde_mm_maskz_fixupimm_round_ss(k, a, b, c, imm8, sae) simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8) #elifdefined(SIMDE_STATEMENT_EXPR_) #ifdefined(SIMDE_HAVE_FENV_H) #define simde_mm_maskz_fixupimm_round_ss(k, a, b, c, imm8, sae) SIMDE_STATEMENT_EXPR_(({ \
simde__m128 simde_mm_maskz_fixupimm_round_ss_r; \
\ if (sae & SIMDE_MM_FROUND_NO_EXC) { \
fenv_t simde_mm_maskz_fixupimm_round_ss_envp; \ int simde_mm_maskz_fixupimm_round_ss_x = feholdexcept(&simde_mm_maskz_fixupimm_round_ss_envp); \
simde_mm_maskz_fixupimm_round_ss_r = simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8); \ if (HEDLEY_LIKELY(simde_mm_maskz_fixupimm_round_ss_x == 0)) \
fesetenv(&simde_mm_maskz_fixupimm_round_ss_envp); \
} \ else { \
simde_mm_maskz_fixupimm_round_ss_r = simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8); \
} \
\
simde_mm_maskz_fixupimm_round_ss_r; \
})) #else #define simde_mm_maskz_fixupimm_round_ss(k, a, b, c, imm8, sae) simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8) #endif #else
SIMDE_FUNCTION_ATTRIBUTES
simde__m128
simde_mm_maskz_fixupimm_round_ss (simde__mmask8 k, simde__m128 a, simde__m128 b, simde__m128i c, int imm8, int sae)
SIMDE_REQUIRE_CONSTANT_RANGE(imm8, 0, 15)
SIMDE_REQUIRE_CONSTANT(sae) {
simde__m128 r;
if (sae & SIMDE_MM_FROUND_NO_EXC) { #ifdefined(SIMDE_HAVE_FENV_H)
fenv_t envp; int x = feholdexcept(&envp);
r = simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8); if (HEDLEY_LIKELY(x == 0))
fesetenv(&envp); #else
r = simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8); #endif
} else {
r = simde_mm_maskz_fixupimm_ss(k, a, b, c, imm8);
}
#ifdefined(SIMDE_X86_AVX512F_NATIVE) #define simde_mm_maskz_fixupimm_round_sd(k, a, b, c, imm8, sae) _mm_maskz_fixupimm_round_sd(k, a, b, c, imm8, sae) #elifdefined(SIMDE_FAST_EXCEPTIONS) #define simde_mm_maskz_fixupimm_round_sd(k, a, b, c, imm8, sae) simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8) #elifdefined(SIMDE_STATEMENT_EXPR_) #ifdefined(SIMDE_HAVE_FENV_H) #define simde_mm_maskz_fixupimm_round_sd(k, a, b, c, imm8, sae) SIMDE_STATEMENT_EXPR_(({ \
simde__m128d simde_mm_maskz_fixupimm_round_sd_r; \
\ if (sae & SIMDE_MM_FROUND_NO_EXC) { \
fenv_t simde_mm_maskz_fixupimm_round_sd_envp; \ int simde_mm_maskz_fixupimm_round_sd_x = feholdexcept(&simde_mm_maskz_fixupimm_round_sd_envp); \
simde_mm_maskz_fixupimm_round_sd_r = simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8); \ if (HEDLEY_LIKELY(simde_mm_maskz_fixupimm_round_sd_x == 0)) \
fesetenv(&simde_mm_maskz_fixupimm_round_sd_envp); \
} \ else { \
simde_mm_maskz_fixupimm_round_sd_r = simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8); \
} \
\
simde_mm_maskz_fixupimm_round_sd_r; \
})) #else #define simde_mm_maskz_fixupimm_round_sd(k, a, b, c, imm8, sae) simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8) #endif #else
SIMDE_FUNCTION_ATTRIBUTES
simde__m128d
simde_mm_maskz_fixupimm_round_sd (simde__mmask8 k, simde__m128d a, simde__m128d b, simde__m128i c, int imm8, int sae)
SIMDE_REQUIRE_CONSTANT_RANGE(imm8, 0, 15)
SIMDE_REQUIRE_CONSTANT(sae) {
simde__m128d r;
if (sae & SIMDE_MM_FROUND_NO_EXC) { #ifdefined(SIMDE_HAVE_FENV_H)
fenv_t envp; int x = feholdexcept(&envp);
r = simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8); if (HEDLEY_LIKELY(x == 0))
fesetenv(&envp); #else
r = simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8); #endif
} else {
r = simde_mm_maskz_fixupimm_sd(k, a, b, c, imm8);
}
¤ Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.0.14Bemerkung:
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.