// -*-C++-*- #ifndef VEC_PSEUDO_H #define VEC_PSEUDO_H #include "floatprops.h" #include "mathfuncs.h" #include "vec_base.h" #include #include #include #include #include namespace vecmathlib { template struct boolpseudovec; template struct intpseudovec; template struct realpseudovec; template struct boolpseudovec: floatprops { typedef typename floatprops::int_t int_t; typedef typename floatprops::uint_t uint_t; typedef typename floatprops::real_t real_t; static int const size = N; typedef bool scalar_t; typedef bool bvector_t[size]; static int const alignment = sizeof(bool); typedef boolpseudovec boolvec_t; typedef intpseudovec intvec_t; typedef realpseudovec realvec_t; // Short names for type casts typedef real_t R; typedef int_t I; typedef uint_t U; typedef realvec_t RV; typedef intvec_t IV; typedef boolvec_t BV; typedef floatprops FP; typedef mathfuncs MF; bvector_t v; boolpseudovec() {} // Can't have a non-trivial copy constructor; if so, objects won't // be passed in registers // boolpseudovec(boolpseudovec const& x): v(x.v) {} // boolpseudovec& operator=(boolpseudovec const& x) { return v=x.v, *this; } boolpseudovec(bool a) { for (int d=0; d struct intpseudovec: floatprops { typedef typename floatprops::int_t int_t; typedef typename floatprops::uint_t uint_t; typedef typename floatprops::real_t real_t; static int const size = N; typedef int_t scalar_t; typedef int_t ivector_t[size]; static int const alignment = sizeof(int_t); typedef boolpseudovec boolvec_t; typedef intpseudovec intvec_t; typedef realpseudovec realvec_t; // Short names for type casts typedef real_t R; typedef int_t I; typedef uint_t U; typedef realvec_t RV; typedef intvec_t IV; typedef boolvec_t BV; typedef floatprops FP; typedef mathfuncs MF; ivector_t v; intpseudovec() {} // Can't have a non-trivial copy constructor; if so, objects won't // be passed in registers // intpseudovec(intpseudovec const& x): v(x.v) {} // intpseudovec& operator=(intpseudovec const& x) { return v=x.v, *this; } intpseudovec(int_t a) { for (int d=0; d> U(n)); return res; } intpseudovec& operator>>=(int_t n) { for (int d=0; d>= n; return *this; } intpseudovec& operator<<=(int_t n) { for (int d=0; d>(int_t n) const { intpseudovec res = *this; return res >>= n; } intpseudovec operator<<(int_t n) const { intpseudovec res = *this; return res <<= n; } intpseudovec lsr(intpseudovec n) const { intpseudovec res; for (int d=0; d> U(n.v[d])); return res; } intpseudovec& operator>>=(intpseudovec n) { for (int d=0; d>= n.v[d]; return *this; } intpseudovec& operator<<=(intpseudovec n) { for (int d=0; d>(intpseudovec n) const { intpseudovec res = *this; return res >>= n; } intpseudovec operator<<(intpseudovec n) const { intpseudovec res = *this; return res <<= n; } boolvec_t signbit() const { boolvec_t res; for (int d=0; d(intpseudovec const& x) const { boolvec_t res; for (int d=0; d x.v[d]); return res; } boolvec_t operator>=(intpseudovec const& x) const { boolvec_t res; for (int d=0; d= x.v[d]); return res; } }; template struct realpseudovec: floatprops { typedef typename floatprops::int_t int_t; typedef typename floatprops::uint_t uint_t; typedef typename floatprops::real_t real_t; static int const size = N; typedef real_t scalar_t; typedef real_t vector_t[size]; static int const alignment = sizeof(real_t); static char const* name() { static std::string name_; if (name_.empty()) { std::stringstream buf; buf << ""; name_ = buf.str(); } return name_.c_str(); } void barrier() { #if defined __GNUC__ && !defined __clang__ && !defined __ICC // GCC crashes when +X is used as constraint # if defined __SSE2__ for (int d=0; d boolvec_t; typedef intpseudovec intvec_t; typedef realpseudovec realvec_t; private: boolvec_t mapb(bool f(real_t)) const { boolvec_t res; for (int d=0; d FP; typedef mathfuncs MF; vector_t v; realpseudovec() {} // Can't have a non-trivial copy constructor; if so, objects won't // be passed in registers // realpseudovec(realpseudovec const& x): v(x.v) {} // realpseudovec& operator=(realpseudovec const& x) { return v=x.v, *this; } realpseudovec(real_t a) { for (int d=0; d mask_t; static realvec_t loada(real_t const* p) { VML_ASSERT(intptr_t(p) % alignment == 0); return loadu(p); } static realvec_t loadu(real_t const* p) { realvec_t res; for (int d=0; d(realpseudovec const& x) const { boolvec_t res; for (int d=0; d x.v[d]); return res; } boolvec_t operator>=(realpseudovec const& x) const { boolvec_t res; for (int d=0; d= x.v[d]); return res; } realpseudovec acos() const { return map(std::acos); } realpseudovec acosh() const { return map(std::acosh); } realpseudovec asin() const { return map(std::asin); } realpseudovec asinh() const { return map(std::asinh); } realpseudovec atan() const { return map(std::atan); } realpseudovec atan2(realpseudovec y) const { return MF::vml_atan2(*this, y); } realpseudovec atanh() const { return map(std::atanh); } realpseudovec cbrt() const { return map(std::cbrt); } realpseudovec ceil() const { return map(std::ceil); } realpseudovec copysign(realpseudovec y) const { return map(std::copysign, y); } realpseudovec cos() const { return map(std::cos); } realpseudovec cosh() const { return map(std::cosh); } realpseudovec exp() const { return map(std::exp); } realpseudovec exp10() const { realvec_t res; for (int d=0; d::max(); #endif #if defined VML_HAVE_NAN if (std::isnan(v[d])) ir = std::numeric_limits::min(); #endif res.v[d] = r; ires.v[d] = ir; } return res; } realpseudovec hypot(realpseudovec y) const { return map(std::hypot, y); } intvec_t ilogb() const { intvec_t res; for (int d=0; d NL; if (FP_ILOGB0 != NL::min() and v[d] == R(0.0)) { r = NL::min(); #if defined VML_HAVE_INF } else if (INT_MAX != NL::max() and std::isinf(v[d])) { r = NL::max(); #endif #if defined VML_HAVE_NAN } else if (FP_ILOGBNAN != NL::min() and std::isnan(v[d])) { r = NL::min(); #endif } res.v[d] = r; } return res; } boolvec_t isfinite() const { return mapb(std::isfinite); } boolvec_t isinf() const { return mapb(std::isinf); } boolvec_t isnan() const { return mapb(std::isnan); } boolvec_t isnormal() const { return mapb(std::isnormal); } realpseudovec ldexp(int_t n) const { realvec_t res; for (int d=0; d inline typename boolpseudovec::intvec_t boolpseudovec::as_int() const { return convert_int(); } template inline typename boolpseudovec::intvec_t boolpseudovec::convert_int() const { intvec_t res; for (int d=0; d inline typename boolpseudovec::boolvec_t boolpseudovec::ifthen(boolvec_t x, boolvec_t y) const { boolvec_t res; for (int d=0; d inline typename boolpseudovec::intvec_t boolpseudovec::ifthen(intvec_t x, intvec_t y) const { intvec_t res; for (int d=0; d inline typename boolpseudovec::realvec_t boolpseudovec::ifthen(realvec_t x, realvec_t y) const { realvec_t res; for (int d=0; d inline typename intpseudovec::realvec_t intpseudovec::as_float() const { realvec_t res; for (int d=0; d inline typename intpseudovec::realvec_t intpseudovec::convert_float() const { realvec_t res; for (int d=0; d inline intpseudovec as_int(boolpseudovec x) { return x.as_int(); } template inline intpseudovec convert_int(boolpseudovec x) { return x.convert_int(); } template inline bool all(boolpseudovec x) { return x.all(); } template inline bool any(boolpseudovec x) { return x.any(); } template inline boolpseudovec ifthen(boolpseudovec c, boolpseudovec x, boolpseudovec y) { return c.ifthen(x, y); } template inline intpseudovec ifthen(boolpseudovec c, intpseudovec x, intpseudovec y) { return c.ifthen(x, y); } template inline realpseudovec ifthen(boolpseudovec c, realpseudovec x, realpseudovec y) { return c.ifthen(x, y); } // intpseudovec wrappers template inline boolpseudovec as_bool(intpseudovec x) { return x.as_bool(); } template inline boolpseudovec convert_bool(intpseudovec x) { return x.convert_bool(); } template inline realpseudovec as_float(intpseudovec x) { return x.as_float(); } template inline realpseudovec convert_float(intpseudovec x) { return x.convert_float(); } template inline intpseudovec lsr(intpseudovec x, typename intpseudovec::int_t n) { return x.lsr(n); } template inline intpseudovec lsr(intpseudovec x, intpseudovec n) { return x.lsr(n); } template inline boolpseudovec signbit(intpseudovec x) { return x.signbit(); } // realpseudovec wrappers template inline realpseudovec loada(real_t const* p, realpseudovec x, typename realpseudovec::mask_t const& m) { return x.loada(p, m); } template inline realpseudovec loadu(real_t const* p, realpseudovec x, typename realpseudovec::mask_t const& m) { return x.loadu(p, m); } template inline realpseudovec loadu(real_t const* p, size_t ioff, realpseudovec x, typename realpseudovec::mask_t const& m) { return x.loadu(p, ioff, m); } template inline void storea(realpseudovec x, real_t* p) { return x.storea(p); } template inline void storeu(realpseudovec x, real_t* p) { return x.storeu(p); } template inline void storeu(realpseudovec x, real_t* p, size_t ioff) { return x.storeu(p, ioff); } template inline void storea(realpseudovec x, real_t* p, typename realpseudovec::mask_t const& m) { return x.storea(p, m); } template inline void storeu(realpseudovec x, real_t* p, typename realpseudovec::mask_t const& m) { return x.storeu(p, m); } template inline void storeu(realpseudovec x, real_t* p, size_t ioff, typename realpseudovec::mask_t const& m) { return x.storeu(p, ioff, m); } template inline intpseudovec as_int(realpseudovec x) { return x.as_int(); } template inline intpseudovec convert_int(realpseudovec x) { return x.convert_int(); } template inline real_t maxval(realpseudovec x) { return x.maxval(); } template inline real_t minval(realpseudovec x) { return x.minval(); } template inline real_t prod(realpseudovec x) { return x.prod(); } template inline real_t sum(realpseudovec x) { return x.sum(); } template inline realpseudovec acos(realpseudovec x) { return x.acos(); } template inline realpseudovec acosh(realpseudovec x) { return x.acosh(); } template inline realpseudovec asin(realpseudovec x) { return x.asin(); } template inline realpseudovec asinh(realpseudovec x) { return x.asinh(); } template inline realpseudovec atan(realpseudovec x) { return x.atan(); } template inline realpseudovec atan2(realpseudovec x, realpseudovec y) { return x.atan2(y); } template inline realpseudovec atanh(realpseudovec x) { return x.atanh(); } template inline realpseudovec cbrt(realpseudovec x) { return x.cbrt(); } template inline realpseudovec ceil(realpseudovec x) { return x.ceil(); } template inline realpseudovec copysign(realpseudovec x, realpseudovec y) { return x.copysign(y); } template inline realpseudovec cos(realpseudovec x) { return x.cos(); } template inline realpseudovec cosh(realpseudovec x) { return x.cosh(); } template inline realpseudovec exp(realpseudovec x) { return x.exp(); } template inline realpseudovec exp10(realpseudovec x) { return x.exp10(); } template inline realpseudovec exp2(realpseudovec x) { return x.exp2(); } template inline realpseudovec expm1(realpseudovec x) { return x.expm1(); } template inline realpseudovec fabs(realpseudovec x) { return x.fabs(); } template inline realpseudovec floor(realpseudovec x) { return x.floor(); } template inline realpseudovec fdim(realpseudovec x, realpseudovec y) { return x.fdim(y); } template inline realpseudovec fma(realpseudovec x, realpseudovec y, realpseudovec z) { return x.fma(y, z); } template inline realpseudovec fmax(realpseudovec x, realpseudovec y) { return x.fmax(y); } template inline realpseudovec fmin(realpseudovec x, realpseudovec y) { return x.fmin(y); } template inline realpseudovec fmod(realpseudovec x, realpseudovec y) { return x.fmod(y); } template inline realpseudovec frexp(realpseudovec x, intpseudovec& r) { return x.frexp(r); } template inline realpseudovec hypot(realpseudovec x, realpseudovec y) { return x.hypot(y); } template inline intpseudovec ilogb(realpseudovec x) { return x.ilogb(); } template inline boolpseudovec isfinite(realpseudovec x) { return x.isfinite(); } template inline boolpseudovec isinf(realpseudovec x) { return x.isinf(); } template inline boolpseudovec isnan(realpseudovec x) { return x.isnan(); } template inline boolpseudovec isnormal(realpseudovec x) { return x.isnormal(); } template inline realpseudovec ldexp(realpseudovec x, typename intpseudovec::int_t n) { return x.ldexp(n); } template inline realpseudovec ldexp(realpseudovec x, intpseudovec n) { return x.ldexp(n); } template inline realpseudovec log(realpseudovec x) { return x.log(); } template inline realpseudovec log10(realpseudovec x) { return x.log10(); } template inline realpseudovec log1p(realpseudovec x) { return x.log1p(); } template inline realpseudovec log2(realpseudovec x) { return x.log2(); } template inline realpseudovec nextafter(realpseudovec x, realpseudovec y) { return x.nextafter(y); } template inline realpseudovec pow(realpseudovec x, realpseudovec y) { return x.pow(y); } template inline realpseudovec rcp(realpseudovec x) { return x.rcp(); } template inline realpseudovec remainder(realpseudovec x, realpseudovec y) { return x.remainder(y); } template inline realpseudovec rint(realpseudovec x) { return x.rint(); } template inline realpseudovec round(realpseudovec x) { return x.round(); } template inline realpseudovec rsqrt(realpseudovec x) { return x.rsqrt(); } template inline boolpseudovec signbit(realpseudovec x) { return x.signbit(); } template inline realpseudovec sin(realpseudovec x) { return x.sin(); } template inline realpseudovec sinh(realpseudovec x) { return x.sinh(); } template inline realpseudovec sqrt(realpseudovec x) { return x.sqrt(); } template inline realpseudovec tan(realpseudovec x) { return x.tan(); } template inline realpseudovec tanh(realpseudovec x) { return x.tanh(); } template inline realpseudovec trunc(realpseudovec x) { return x.trunc(); } template std::ostream& operator<<(std::ostream& os, boolpseudovec const& x) { os << "["; for (int i=0; i std::ostream& operator<<(std::ostream& os, intpseudovec const& x) { os << "["; for (int i=0; i std::ostream& operator<<(std::ostream& os, realpseudovec const& x) { os << "["; for (int i=0; i