diff options
author | Erik Schnetter <schnetter@gmail.com> | 2013-11-25 14:52:26 -0500 |
---|---|---|
committer | Erik Schnetter <schnetter@gmail.com> | 2013-11-25 14:52:26 -0500 |
commit | ec33e3b30b4324cad3f5c26186cc2d2620708a0f (patch) | |
tree | c8f74527bcc52e2f219e6f8a953dd86d5597a75d /vec_pseudo.h | |
parent | 89edeef77f22823a1f2cebd46699a29df9d43d95 (diff) | |
download | vecmathlib-ec33e3b30b4324cad3f5c26186cc2d2620708a0f.zip vecmathlib-ec33e3b30b4324cad3f5c26186cc2d2620708a0f.tar.gz |
Provide lrint
Diffstat (limited to 'vec_pseudo.h')
-rw-r--r-- | vec_pseudo.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/vec_pseudo.h b/vec_pseudo.h index 5f84d3c..8fa80dc 100644 --- a/vec_pseudo.h +++ b/vec_pseudo.h @@ -887,6 +887,18 @@ namespace vecmathlib { realvec_t log10() const { return map(vml_std::log10); } realvec_t log1p() const { return map(vml_std::log1p); } realvec_t log2() const { return map(vml_std::log2); } + intvec_t lrint() const + { + realvec_t res; + if (sizeof(int_t) <= sizeof(long)) { + for (int d=0; d<size; ++d) res.v[d] = vml_std::lrint(v[d]); + } else if (sizeof(int_t) <= sizeof(long long)) { + for (int d=0; d<size; ++d) res.v[d] = vml_std::llrint(v[d]); + } else { + __builtin_unreachable(); + } + return res; + } realvec_t mad(realvec_t y, realvec_t z) const { return MF::vml_mad(*this, y, z); @@ -1507,6 +1519,12 @@ namespace vecmathlib { } template<typename real_t, int size> + inline intpseudovec<real_t, size> lrint(realpseudovec<real_t, size> x) + { + return x.lrint(); + } + + template<typename real_t, int size> inline realpseudovec<real_t, size> mad(realpseudovec<real_t, size> x, realpseudovec<real_t, size> y, realpseudovec<real_t, size> z) |