summaryrefslogtreecommitdiffstats
path: root/vec_pseudo.h
diff options
context:
space:
mode:
authorErik Schnetter <schnetter@gmail.com>2013-11-25 14:52:26 -0500
committerErik Schnetter <schnetter@gmail.com>2013-11-25 14:52:26 -0500
commitec33e3b30b4324cad3f5c26186cc2d2620708a0f (patch)
treec8f74527bcc52e2f219e6f8a953dd86d5597a75d /vec_pseudo.h
parent89edeef77f22823a1f2cebd46699a29df9d43d95 (diff)
downloadvecmathlib-ec33e3b30b4324cad3f5c26186cc2d2620708a0f.zip
vecmathlib-ec33e3b30b4324cad3f5c26186cc2d2620708a0f.tar.gz
Provide lrint
Diffstat (limited to 'vec_pseudo.h')
-rw-r--r--vec_pseudo.h18
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)
OpenPOWER on IntegriCloud