Skip to content
Snippets Groups Projects
MpiBodyComm.hpp 1.12 KiB
Newer Older
#ifndef COMM_BUFFER_HPP
#define COMM_BUFFER_HPP

#include <mpi.h>
#include <vector>
#include "../datastructures/Body.hpp"

namespace nbody {
	using namespace std;

	class MpiBodyComm {
	protected:
		MPI::Datatype* datatype;
Paul Heinzlreiter's avatar
Paul Heinzlreiter committed
		MPI::Request request;
		vector<Body> buffer;
	public:
		MpiBodyComm(MPI::Datatype* bodyDatatype);
		virtual ~MpiBodyComm();
		virtual void testing(vector<Body>& data, int myRank);
Paul Heinzlreiter's avatar
Paul Heinzlreiter committed
		virtual void sendBlocking(int target, vector<Body> bodies);
		virtual void recvBlocking(int source, vector<Body>& bodies);
		//virtual bool sendUnblocking(int target, vector<Body> bodies);
Paul Heinzlreiter's avatar
Paul Heinzlreiter committed
		virtual bool sendBlocking(int target, vector<Body> bodies);
		virtual bool sendUnblocking(int target, vector<Body> bodies);
Paul Heinzlreiter's avatar
Paul Heinzlreiter committed
		virtual void recvBlocking(int source, vector<Body>& bodies);
		virtual bool recvUnblocking(int source, vector<Body>& bodies);
		virtual void recvBlockingAnySource(int& source, vector<Body>& bodies);
		virtual bool recvUnblockingAnySource(int& source, vector<Body>& bodies);
		virtual bool sendReady();
		virtual bool recvReady(int source);
		virtual void testing(vector<Body>& data, int myRank);