85 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			85 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | // Copyright 2004 The Trustees of Indiana University. | ||
|  | 
 | ||
|  | // Use, modification and distribution is subject to 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) | ||
|  | 
 | ||
|  | //  Authors: Douglas Gregor | ||
|  | //           Andrew Lumsdaine | ||
|  | #ifndef BOOST_PARALLEL_ALGORITHM_HPP | ||
|  | #define BOOST_PARALLEL_ALGORITHM_HPP | ||
|  | 
 | ||
|  | #ifndef BOOST_GRAPH_USE_MPI | ||
|  | #error "Parallel BGL files should not be included unless <boost/graph/use_mpi.hpp> has been included" | ||
|  | #endif | ||
|  | 
 | ||
|  | #include <boost/optional.hpp> | ||
|  | #include <boost/config.hpp> // for BOOST_STATIC_CONSTANT | ||
|  | #include <vector> | ||
|  | #include <functional> | ||
|  | 
 | ||
|  | namespace boost { namespace parallel { | ||
|  |   template<typename BinaryOp> | ||
|  |   struct is_commutative | ||
|  |   { | ||
|  |     BOOST_STATIC_CONSTANT(bool, value = false); | ||
|  |   }; | ||
|  | 
 | ||
|  |   template<typename T> | ||
|  |   struct minimum : std::binary_function<T, T, T> | ||
|  |   { | ||
|  |     const T& operator()(const T& x, const T& y) const { return x < y? x : y; } | ||
|  |   }; | ||
|  | 
 | ||
|  |   template<typename T> | ||
|  |   struct maximum : std::binary_function<T, T, T> | ||
|  |   { | ||
|  |     const T& operator()(const T& x, const T& y) const { return x < y? y : x; } | ||
|  |   }; | ||
|  | 
 | ||
|  |   template<typename T> | ||
|  |   struct sum : std::binary_function<T, T, T> | ||
|  |   { | ||
|  |     const T operator()(const T& x, const T& y) const { return x + y; } | ||
|  |   }; | ||
|  | 
 | ||
|  |   template<typename ProcessGroup, typename InputIterator, | ||
|  |            typename OutputIterator, typename BinaryOperation> | ||
|  |   OutputIterator | ||
|  |   reduce(ProcessGroup pg, typename ProcessGroup::process_id_type root, | ||
|  |          InputIterator first, InputIterator last, OutputIterator out, | ||
|  |          BinaryOperation bin_op); | ||
|  | 
 | ||
|  |   template<typename ProcessGroup, typename T, typename BinaryOperation> | ||
|  |   inline T | ||
|  |   all_reduce(ProcessGroup pg, const T& value, BinaryOperation bin_op) | ||
|  |   { | ||
|  |     T result; | ||
|  |     all_reduce(pg, | ||
|  |                const_cast<T*>(&value), const_cast<T*>(&value+1), | ||
|  |                &result, bin_op); | ||
|  |     return result; | ||
|  |   } | ||
|  | 
 | ||
|  |   template<typename ProcessGroup, typename T, typename BinaryOperation> | ||
|  |   inline T | ||
|  |   scan(ProcessGroup pg, const T& value, BinaryOperation bin_op) | ||
|  |   { | ||
|  |     T result; | ||
|  |     scan(pg, | ||
|  |          const_cast<T*>(&value), const_cast<T*>(&value+1), | ||
|  |          &result, bin_op); | ||
|  |     return result; | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  |   template<typename ProcessGroup, typename InputIterator, typename T> | ||
|  |   void | ||
|  |   all_gather(ProcessGroup pg, InputIterator first, InputIterator last, | ||
|  |              std::vector<T>& out); | ||
|  | } } // end namespace boost::parallel | ||
|  | 
 | ||
|  | #include <boost/graph/parallel/detail/inplace_all_to_all.hpp> | ||
|  | 
 | ||
|  | #endif // BOOST_PARALLEL_ALGORITHM_HPP |