3 boost/numeric/odeint/external/compute/compute_algebra.hpp
6 An algebra for Boost.Compute vectors.
9 Copyright 2009-2011 Karsten Ahnert
10 Copyright 2009-2011 Mario Mulansky
12 Distributed under the Boost Software License, Version 1.0.
13 (See accompanying file LICENSE_1_0.txt or
14 copy at http://www.boost.org/LICENSE_1_0.txt)
18 #ifndef BOOST_NUMERIC_ODEINT_EXTERNAL_COMPUTE_COMPUTE_ALGEBRA_HPP_DEFINED
19 #define BOOST_NUMERIC_ODEINT_EXTERNAL_COMPUTE_COMPUTE_ALGEBRA_HPP_DEFINED
21 #include <boost/preprocessor/repetition.hpp>
22 #include <boost/compute.hpp>
28 struct compute_algebra
31 #define BOOST_ODEINT_COMPUTE_STATE_PARAM(z, n, unused) \
32 StateType ## n &s ## n,
34 #define BOOST_ODEINT_COMPUTE_ALGEBRA(z, n, unused) \
35 template< BOOST_PP_ENUM_PARAMS(n, class StateType), class Operation > \
36 static void for_each ## n( \
37 BOOST_PP_REPEAT(n, BOOST_ODEINT_COMPUTE_STATE_PARAM, ~) \
41 op( BOOST_PP_ENUM_PARAMS(n, s) ); \
44 BOOST_PP_REPEAT_FROM_TO(3, 9, BOOST_ODEINT_COMPUTE_ALGEBRA, ~)
46 #undef BOOST_ODEINT_COMPUTE_ALGEBRA
47 #undef BOOST_ODEINT_COMPUTE_STATE_PARAM
50 static typename S::value_type norm_inf( const S &s ) {
51 typedef typename S::value_type value_type;
53 BOOST_COMPUTE_FUNCTION(value_type, max_abs, (value_type, value_type),
55 return max(_1, fabs(_2));
58 return boost::compute::accumulate(s.begin(), s.end(), value_type(), max_abs);