152 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /*
 | |
|   [auto_generated]
 | |
|   boost/numeric/odeint/util/unit_helper.hpp
 | |
| 
 | |
|   [begin_description]
 | |
|   Get and set the value of a unit.
 | |
|   [end_description]
 | |
| 
 | |
|   Copyright 2012-2013 Karsten Ahnert
 | |
|   Copyright 2012-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_UTIL_UNIT_HELPER_HPP_INCLUDED
 | |
| #define BOOST_NUMERIC_ODEINT_UTIL_UNIT_HELPER_HPP_INCLUDED
 | |
| 
 | |
| 
 | |
| #ifndef __CUDACC__
 | |
| #include <boost/units/quantity.hpp>
 | |
| #include <boost/units/get_dimension.hpp>
 | |
| #include <boost/units/get_system.hpp>
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| namespace boost {
 | |
| namespace numeric {
 | |
| namespace odeint {
 | |
| 
 | |
| 
 | |
| namespace detail {
 | |
| 
 | |
|     template<class T , class Enabler = void >
 | |
|     struct get_unit_value_impl
 | |
|     {
 | |
|         static T value(const T &t)
 | |
|         {
 | |
|             return t;
 | |
|         }
 | |
|         typedef T result_type;
 | |
|     };
 | |
|     
 | |
| #ifndef __CUDACC__
 | |
|     template<class Unit , class T>
 | |
|     struct get_unit_value_impl< boost::units::quantity< Unit , T> >
 | |
|     {
 | |
|         static T value( const boost::units::quantity< Unit , T> &t )
 | |
|         {
 | |
|             return t.value();
 | |
|         }
 | |
|         typedef T result_type;
 | |
|     };
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     template<class T , class V , class Enabler = void >
 | |
|     struct set_unit_value_impl
 | |
|     {
 | |
|         static void set_value(T &t , const V &v)
 | |
|         {
 | |
|             t = v;
 | |
|         }
 | |
|     };
 | |
| 
 | |
| #ifndef __CUDACC__
 | |
|     template<class Unit , class T , class V>
 | |
|     struct set_unit_value_impl<boost::units::quantity<Unit , T> , V>
 | |
|     {
 | |
|         static void set_value(boost::units::quantity<Unit , T> &t , const V &v)
 | |
|         {
 | |
|             t = boost::units::quantity<Unit , T>::from_value(v);
 | |
|         }
 | |
|     };
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| } // namespace detail
 | |
| 
 | |
| 
 | |
|     template<class T>
 | |
|     typename detail::get_unit_value_impl<T>::result_type get_unit_value(const T &t)
 | |
|     {
 | |
|         return detail::get_unit_value_impl<T>::value(t);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     template<class T , class V>
 | |
|     void set_unit_value(T &t , const V &v)
 | |
|     {
 | |
|         return detail::set_unit_value_impl<T , V>::set_value(t , v);
 | |
|     }
 | |
| 
 | |
| 
 | |
| 
 | |
|     template< class T >
 | |
|     struct unit_value_type
 | |
|     {
 | |
|         typedef T type;
 | |
|     };
 | |
| 
 | |
| #ifndef __CUDACC__
 | |
|     template< class Unit , class Y >
 | |
|     struct unit_value_type< boost::units::quantity< Unit , Y > >
 | |
|     {
 | |
|         typedef Y type;
 | |
|     };
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
|     template< typename Time >
 | |
|     struct inverse_time
 | |
|     {
 | |
|         typedef Time type;
 | |
|     };
 | |
| 
 | |
| #ifndef __CUDACC__
 | |
|     template< typename Unit , typename Value >
 | |
|     struct inverse_time< boost::units::quantity< Unit , Value > >
 | |
|     {
 | |
|         typedef boost::units::quantity< Unit , Value > time_type;
 | |
|         typedef typename boost::units::get_dimension< time_type >::type dimension;
 | |
|         typedef typename boost::units::get_system< time_type >::type system;
 | |
|         typedef typename boost::mpl::divides< boost::units::dimensionless_type , dimension >::type inv_dimension;
 | |
|         typedef boost::units::unit< inv_dimension , system > inv_unit;
 | |
|         typedef boost::units::quantity< inv_unit , Value > type;
 | |
|     };
 | |
| #endif
 | |
| 
 | |
| 
 | |
| } // namespace odeint
 | |
| } // namespace numeric
 | |
| } // namespace boost
 | |
| 
 | |
| 
 | |
| #endif // BOOST_NUMERIC_ODEINT_UTIL_UNIT_HELPER_HPP_INCLUDED
 | 
