mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 01:50:30 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			259 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			259 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| 
 | |
| [mathpart gcd_lcm Integer Utilities (Greatest Common Divisor and Least Common Multiple)]
 | |
| 
 | |
| [section Introduction]
 | |
| 
 | |
| The class and function templates in `<boost/math/common_factor.hpp>`
 | |
| provide both run-time and compile-time evaluation of the greatest common divisor
 | |
| (GCD) or least common multiple (LCM) of two integers.
 | |
| These facilities are useful for many numeric-oriented generic
 | |
| programming problems.
 | |
| 
 | |
| [endsect] [/section Introduction]
 | |
| 
 | |
| [section Synopsis]
 | |
| 
 | |
|    namespace boost
 | |
|    {
 | |
|    namespace math
 | |
|    {
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|       class gcd_evaluator;
 | |
|    template < typename IntegerType >
 | |
|       class lcm_evaluator;
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|       IntegerType  gcd( IntegerType const &a, IntegerType const &b );
 | |
|    template < typename ForwardIterator >
 | |
|       std::pair<typename std::iterator_traits<I>::value_type, I> gcd_range(I first, I last);
 | |
|    template < typename IntegerType >
 | |
|       IntegerType  lcm( IntegerType const &a, IntegerType const &b );
 | |
| 
 | |
|    typedef ``['see-below]`` static_gcd_type;
 | |
| 
 | |
|    template < static_gcd_type Value1, static_gcd_type Value2 >
 | |
|       struct static_gcd;
 | |
|    template < static_gcd_type Value1, static_gcd_type Value2 >
 | |
|       struct static_lcm;
 | |
| 
 | |
|    }
 | |
|    }
 | |
| 
 | |
| [endsect] [/section Introduction]
 | |
| 
 | |
| [section GCD Function Object]
 | |
| 
 | |
| [*Header: ] [@../../../../boost/math/common_factor_rt.hpp <boost/math/common_factor_rt.hpp>]
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|    class boost::math::gcd_evaluator
 | |
|    {
 | |
|    public:
 | |
|       // Types
 | |
|       typedef IntegerType  result_type;
 | |
|       typedef IntegerType  first_argument_type;
 | |
|       typedef IntegerType  second_argument_type;
 | |
| 
 | |
|       // Function object interface
 | |
|       result_type  operator ()( first_argument_type const &a,
 | |
|       second_argument_type const &b ) const;
 | |
|    };
 | |
| 
 | |
| The `boost::math::gcd`_evaluator class template defines a function object
 | |
| class to return the greatest common divisor of two integers.
 | |
| The template is parameterized by a single type, called `IntegerType` here.
 | |
| This type should be a numeric type that represents integers.
 | |
| The result of the function object is always nonnegative, even if either of
 | |
| the operator arguments is negative.
 | |
| 
 | |
| This function object class template is used in the corresponding version of
 | |
| the GCD function template. If a numeric type wants to customize evaluations
 | |
| of its greatest common divisors, then the type should specialize on the
 | |
| `gcd_evaluator` class template.
 | |
| 
 | |
| [endsect] [/section GCD Function Object]
 | |
| 
 | |
| [section LCM Function Object]
 | |
| 
 | |
| [*Header: ] [@../../../../boost/math/common_factor_rt.hpp <boost/math/common_factor_rt.hpp>]
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|    class boost::math::lcm_evaluator
 | |
|    {
 | |
|    public:
 | |
|       // Types
 | |
|       typedef IntegerType  result_type;
 | |
|       typedef IntegerType  first_argument_type;
 | |
|       typedef IntegerType  second_argument_type;
 | |
| 
 | |
|       // Function object interface
 | |
|       result_type  operator ()( first_argument_type const &a,
 | |
|       second_argument_type const &b ) const;
 | |
|    };
 | |
| 
 | |
| The `boost::math::lcm_evaluator` class template defines a function object
 | |
| class to return the least common multiple of two integers. The template
 | |
| is parameterized by a single type, called `IntegerType `here. This type
 | |
| should be a numeric type that represents integers. The result of the
 | |
| function object is always nonnegative, even if either of the operator
 | |
| arguments is negative. If the least common multiple is beyond the range
 | |
| of the integer type, the results are undefined.
 | |
| 
 | |
| This function object class template is used in the corresponding version
 | |
| of the LCM function template. If a numeric type wants to customize
 | |
| evaluations of its least common multiples, then the type should
 | |
| specialize on the `lcm_evaluator` class template.
 | |
| 
 | |
| [endsect] [/section LCM Function Object]
 | |
| 
 | |
| [section:run_time Run-time GCD & LCM Determination]
 | |
| 
 | |
| [*Header: ] [@../../../../boost/math/common_factor_rt.hpp <boost/math/common_factor_rt.hpp>]
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|    IntegerType  boost::math::gcd( IntegerType const &a, IntegerType const &b );
 | |
| 
 | |
|    template < typename ForwardIterator >
 | |
|    std::pair<typename std::iterator_traits<I>::value_type, I> gcd_range(I first, I last);
 | |
| 
 | |
|    template < typename IntegerType >
 | |
|    IntegerType  boost::math::lcm( IntegerType const &a, IntegerType const &b );
 | |
| 
 | |
| The `boost::math::gcd` function template returns the greatest common
 | |
| (nonnegative) divisor of the two integers passed to it.
 | |
| `boost::math::gcd_range` is the iteration of the above gcd algorithm over a 
 | |
| range, returning the greatest common divisor of all the elements. The algorithm 
 | |
| terminates when the gcd reaches unity or the end of the range. Thus it also 
 | |
| returns the iterator after the last element inspected because this may not be 
 | |
| equal to the end of the range.
 | |
| The boost::math::lcm function template returns the least common
 | |
| (nonnegative) multiple of the two integers passed to it.
 | |
| The function templates are parameterized on the function arguments'
 | |
| IntegerType, which is also the return type. Internally, these function
 | |
| templates use an object of the corresponding version of the
 | |
| `gcd_evaluator` and `lcm_evaluator` class templates, respectively.
 | |
| 
 | |
| [endsect] [/section:run_time Run-time GCD & LCM Determination]
 | |
| 
 | |
| [section:compile_time Compile-time GCD and LCM determination]
 | |
| 
 | |
| [*Header: ] [@../../../../boost/math/common_factor_ct.hpp <boost/math/common_factor_ct.hpp>]
 | |
| 
 | |
|    typedef ``['unspecified]`` static_gcd_type;
 | |
| 
 | |
|    template < static_gcd_type Value1, static_gcd_type Value2 >
 | |
|    struct boost::math::static_gcd : public mpl::integral_c<static_gcd_type, implementation_defined>
 | |
|    {
 | |
|    };
 | |
| 
 | |
|    template < static_gcd_type Value1, static_gcd_type Value2 >
 | |
|    struct boost::math::static_lcm : public mpl::integral_c<static_gcd_type, implementation_defined>
 | |
|    {
 | |
|    };
 | |
| 
 | |
| The type `static_gcd_type` is the widest unsigned-integer-type that is supported
 | |
| for use in integral-constant-expressions by the compiler.  Usually this
 | |
| the same type as `boost::uintmax_t`, but may fall back to being `unsigned long`
 | |
| for some older compilers.
 | |
| 
 | |
| The boost::math::static_gcd and boost::math::static_lcm class templates
 | |
| take two value-based template parameters of the ['static_gcd_type] type
 | |
| and inherit from the type `boost::mpl::integral_c`.
 | |
| Inherited from the base class, they have a member /value/
 | |
| that is the greatest common factor or least
 | |
| common multiple, respectively, of the template arguments.
 | |
| A compile-time error will occur if the least common multiple
 | |
| is beyond the range of `static_gcd_type`.
 | |
| 
 | |
| [h3 Example]
 | |
| 
 | |
|    #include <boost/math/common_factor.hpp>
 | |
|    #include <algorithm>
 | |
|    #include <iterator>
 | |
|    #include <iostream>
 | |
| 
 | |
|    int main()
 | |
|    {
 | |
|       using std::cout;
 | |
|       using std::endl;
 | |
| 
 | |
|       cout << "The GCD and LCM of 6 and 15 are "
 | |
|       << boost::math::gcd(6, 15) << " and "
 | |
|       << boost::math::lcm(6, 15) << ", respectively."
 | |
|       << endl;
 | |
| 
 | |
|       cout << "The GCD and LCM of 8 and 9 are "
 | |
|       << boost::math::static_gcd<8, 9>::value
 | |
|       << " and "
 | |
|       << boost::math::static_lcm<8, 9>::value
 | |
|       << ", respectively." << endl;
 | |
| 
 | |
|       int  a[] = { 4, 5, 6 }, b[] = { 7, 8, 9 }, c[3];
 | |
|       std::transform( a, a + 3, b, c, boost::math::gcd_evaluator<int>() );
 | |
|       std::copy( c, c + 3, std::ostream_iterator<int>(cout, " ") );
 | |
|    }
 | |
| 
 | |
| [endsect] [/section:compile_time Compile time GCD and LCM determination]
 | |
| 
 | |
| [section:gcd_header Header <boost/math/common_factor.hpp>]
 | |
| 
 | |
| This header simply includes the headers
 | |
| [@../../../../boost/math/common_factor_ct.hpp <boost/math/common_factor_ct.hpp>]
 | |
| and [@../../../../boost/math/common_factor_rt.hpp <boost/math/common_factor_rt.hpp>].
 | |
| 
 | |
| [note This is a legacy header: it used to contain the actual implementation,
 | |
| but the compile-time and run-time facilities
 | |
| were moved to separate headers (since they were independent of each other).]
 | |
| 
 | |
| [endsect] [/section:gcd_header Header <boost/math/common_factor.hpp>]
 | |
| 
 | |
| [section:demo Demonstration Program]
 | |
| 
 | |
| The program [@../../../../libs/math/test/common_factor_test.cpp common_factor_test.cpp]
 | |
| is a demonstration of the results from
 | |
| instantiating various examples of the run-time GCD and LCM function
 | |
| templates and the compile-time GCD and LCM class templates.
 | |
| (The run-time GCD and LCM class templates are tested indirectly through
 | |
| the run-time function templates.)
 | |
| 
 | |
| [endsect] [/section:demo Demonstration Program]
 | |
| 
 | |
| [section Rationale]
 | |
| 
 | |
| The greatest common divisor and least common multiple functions are
 | |
| greatly used in some numeric contexts, including some of the other
 | |
| Boost libraries. Centralizing these functions to one header improves
 | |
| code factoring and eases maintainence.
 | |
| 
 | |
| [endsect] [/section Rationale]
 | |
| 
 | |
| [section:gcd_history History]
 | |
| 
 | |
| * 13 May 2013 Moved into main Boost.Math Quickbook documentation.
 | |
| * 17 Dec 2005: Converted documentation to Quickbook Format.
 | |
| * 2 Jul 2002: Compile-time and run-time items separated to new headers.
 | |
| * 7 Nov 2001: Initial version
 | |
| 
 | |
| [endsect] [/section:gcd_history History]
 | |
| 
 | |
| [section:gcd_credits Credits]
 | |
| 
 | |
| The author of the Boost compilation of GCD and LCM computations is
 | |
| Daryle Walker. The code was prompted by existing code hiding in the
 | |
| implementations of Paul Moore's rational library and Steve Cleary's
 | |
| pool library. The code had updates by Helmut Zeisel.
 | |
| 
 | |
| [endsect] [/section:gcd_credits Credits]
 | |
| 
 | |
| [endmathpart] [/mathpart gcd_lcm Integer Utilities (Greatest Common Divisor and Least Common Multiple)]
 | |
| 
 | |
| [/
 | |
| Copyright 2005, 2013 Daryle Walker.
 | |
| 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).
 | |
| ]
 | |
| 
 | |
| 
 |