1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
/*
[auto_generated]
boost/numeric/odeint/external/vexcl/vexcl_abs.hpp
[begin_description]
abs() specialization for vexcl
[end_description]
Copyright 2009-2013 Karsten Ahnert
Copyright 2009-2013 Mario Mulansky
Distributed under the Boost Software License, Version 1.0.
(See accompanying file LICENSE_1_0.txt or
copy at http://www.boost.org/LICENSE_1_0.txt)
*/
#ifndef BOOST_NUMERIC_ODEINT_EXTERNAL_VEXCL_VEXCL_ABS_HPP_DEFINED
#define BOOST_NUMERIC_ODEINT_EXTERNAL_VEXCL_VEXCL_ABS_HPP_DEFINED
#include <vexcl/vector.hpp>
#include <vexcl/multivector.hpp>
#include <vexcl/operations.hpp>
namespace vex {
template <typename T, size_t N>
typename std::enable_if<
std::is_integral<T>::value,
typename boost::proto::result_of::make_expr<
boost::proto::tag::function,
abs_func,
const vex::multivector<T, N>&
>::type const
>::type
abs(const multivector<T, N> &arg) {
return boost::proto::make_expr<boost::proto::tag::function>(
abs_func(),
boost::ref(arg)
);
}
template <typename T, size_t N>
typename std::enable_if<
!std::is_integral<T>::value,
typename boost::proto::result_of::make_expr<
boost::proto::tag::function,
fabs_func,
const vex::multivector<T, N>&
>::type const
>::type
abs(const multivector<T, N> &arg) {
return boost::proto::make_expr<boost::proto::tag::function>(
fabs_func(),
boost::ref(arg)
);
}
} // namespace vex
#endif // BOOST_NUMERIC_ODEINT_EXTERNAL_VEXCL_VEXCL_ABS_HPP_DEFINED
|