2004-07-14 18:11:03 +04:00
|
|
|
// -*- c++ -*-
|
|
|
|
//
|
2004-11-22 04:38:40 +03:00
|
|
|
// Copyright (c) 2004-2005 The Trustees of Indiana University.
|
|
|
|
// All rights reserved.
|
|
|
|
// Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
|
|
|
// All rights reserved.
|
2004-11-28 23:09:25 +03:00
|
|
|
// Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
// University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
// Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
// All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
// $COPYRIGHT$
|
|
|
|
//
|
|
|
|
// Additional copyrights may follow
|
|
|
|
//
|
2004-07-14 18:11:03 +04:00
|
|
|
// $HEADER$
|
|
|
|
//
|
|
|
|
|
|
|
|
class Op {
|
|
|
|
public:
|
|
|
|
|
|
|
|
// construction
|
|
|
|
Op();
|
|
|
|
Op(const MPI_Op &i);
|
|
|
|
Op(const Op& op);
|
|
|
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
|
|
|
Op(const PMPI::Op& op) : pmpi_op(op) { }
|
|
|
|
#endif
|
|
|
|
// destruction
|
|
|
|
virtual ~Op();
|
|
|
|
// assignment
|
|
|
|
Op& operator=(const Op& op);
|
|
|
|
Op& operator= (const MPI_Op &i);
|
|
|
|
// comparison
|
|
|
|
inline bool operator== (const Op &a);
|
|
|
|
inline bool operator!= (const Op &a);
|
|
|
|
// conversion functions for inter-language operability
|
|
|
|
inline operator MPI_Op () const;
|
|
|
|
// inline operator MPI_Op* (); //JGS const
|
|
|
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
|
|
|
inline operator const PMPI::Op&() const { return pmpi_op; }
|
|
|
|
#endif
|
|
|
|
// Collective Communication
|
|
|
|
//JGS took const out
|
|
|
|
virtual void Init(User_function *func, bool commute);
|
|
|
|
virtual void Free();
|
|
|
|
|
|
|
|
#if ! 0 /* OMPI_ENABLE_MPI_PROFILING */
|
|
|
|
User_function *op_user_function; //JGS move to private
|
|
|
|
protected:
|
|
|
|
MPI_Op mpi_op;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
|
|
|
private:
|
|
|
|
PMPI::Op pmpi_op;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
};
|
|
|
|
|