103 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			103 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | //  Boost common_factor_ct.hpp header file  ----------------------------------// | ||
|  | 
 | ||
|  | //  (C) Copyright Daryle Walker and Stephen Cleary 2001-2002. | ||
|  | //  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) | ||
|  | 
 | ||
|  | //  See http://www.boost.org for updates, documentation, and revision history.  | ||
|  | 
 | ||
|  | #ifndef BOOST_INTEGER_COMMON_FACTOR_CT_HPP | ||
|  | #define BOOST_INTEGER_COMMON_FACTOR_CT_HPP | ||
|  | 
 | ||
|  | #include <boost/integer_fwd.hpp>  // self include | ||
|  | #include <boost/config.hpp>  // for BOOST_STATIC_CONSTANT, etc. | ||
|  | 
 | ||
|  | namespace boost | ||
|  | { | ||
|  | namespace integer | ||
|  | { | ||
|  | 
 | ||
|  | //  Implementation details  --------------------------------------------------// | ||
|  | 
 | ||
|  | namespace detail | ||
|  | { | ||
|  |     // Build GCD with Euclid's recursive algorithm | ||
|  |     template < static_gcd_type Value1, static_gcd_type Value2 > | ||
|  |     struct static_gcd_helper_t | ||
|  |     { | ||
|  |     private: | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, new_value1 = Value2 ); | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, new_value2 = Value1 % Value2 ); | ||
|  | 
 | ||
|  |         #ifndef __BORLANDC__ | ||
|  |         #define BOOST_DETAIL_GCD_HELPER_VAL(Value) static_cast<static_gcd_type>(Value) | ||
|  |         #else | ||
|  |         typedef static_gcd_helper_t  self_type; | ||
|  |         #define BOOST_DETAIL_GCD_HELPER_VAL(Value)  (self_type:: Value ) | ||
|  |         #endif | ||
|  | 
 | ||
|  |         typedef static_gcd_helper_t< BOOST_DETAIL_GCD_HELPER_VAL(new_value1), | ||
|  |          BOOST_DETAIL_GCD_HELPER_VAL(new_value2) >  next_step_type; | ||
|  | 
 | ||
|  |         #undef BOOST_DETAIL_GCD_HELPER_VAL | ||
|  | 
 | ||
|  |     public: | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, value = next_step_type::value ); | ||
|  |     }; | ||
|  | 
 | ||
|  |     // Non-recursive case | ||
|  |     template < static_gcd_type Value1 > | ||
|  |     struct static_gcd_helper_t< Value1, 0UL > | ||
|  |     { | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, value = Value1 ); | ||
|  |     }; | ||
|  | 
 | ||
|  |     // Build the LCM from the GCD | ||
|  |     template < static_gcd_type Value1, static_gcd_type Value2 > | ||
|  |     struct static_lcm_helper_t | ||
|  |     { | ||
|  |         typedef static_gcd_helper_t<Value1, Value2>  gcd_type; | ||
|  | 
 | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, value = Value1 / gcd_type::value | ||
|  |          * Value2 ); | ||
|  |     }; | ||
|  | 
 | ||
|  |     // Special case for zero-GCD values | ||
|  |     template < > | ||
|  |     struct static_lcm_helper_t< 0UL, 0UL > | ||
|  |     { | ||
|  |         BOOST_STATIC_CONSTANT( static_gcd_type, value = 0UL ); | ||
|  |     }; | ||
|  | 
 | ||
|  | }  // namespace detail | ||
|  | 
 | ||
|  | 
 | ||
|  | //  Compile-time greatest common divisor evaluator class declaration  --------// | ||
|  | 
 | ||
|  | template < static_gcd_type Value1, static_gcd_type Value2 > struct static_gcd | ||
|  | { | ||
|  |     BOOST_STATIC_CONSTANT( static_gcd_type, value = (detail::static_gcd_helper_t<Value1, Value2>::value) ); | ||
|  | };  // boost::integer::static_gcd | ||
|  | 
 | ||
|  | #if !defined(BOOST_NO_INCLASS_MEMBER_INITIALIZATION) | ||
|  | template< static_gcd_type Value1, static_gcd_type Value2 > static_gcd_type const static_gcd< Value1, Value2 >::value; | ||
|  | #endif | ||
|  | 
 | ||
|  | //  Compile-time least common multiple evaluator class declaration  ----------// | ||
|  | 
 | ||
|  | template < static_gcd_type Value1, static_gcd_type Value2 > struct static_lcm | ||
|  | { | ||
|  |     BOOST_STATIC_CONSTANT( static_gcd_type, value = (detail::static_lcm_helper_t<Value1, Value2>::value) ); | ||
|  | };  // boost::integer::static_lcm | ||
|  | 
 | ||
|  | #if !defined(BOOST_NO_INCLASS_MEMBER_INITIALIZATION) | ||
|  | template< static_gcd_type Value1, static_gcd_type Value2 > static_gcd_type const static_lcm< Value1, Value2 >::value; | ||
|  | #endif | ||
|  | 
 | ||
|  | }  // namespace integer | ||
|  | }  // namespace boost | ||
|  | 
 | ||
|  | 
 | ||
|  | #endif  // BOOST_INTEGER_COMMON_FACTOR_CT_HPP |