ESyS-Particle  2.3.4
mpivbuf.h
Go to the documentation of this file.
1 // //
3 // Copyright (c) 2003-2017 by The University of Queensland //
4 // Centre for Geoscience Computing //
5 // http://earth.uq.edu.au/centre-geoscience-computing //
6 // //
7 // Primary Business: Brisbane, Queensland, Australia //
8 // Licensed under the Open Software License version 3.0 //
9 // http://www.apache.org/licenses/LICENSE-2.0 //
10 // //
12 
13 #ifndef __MPIVBUF_H
14 #define __MPIVBUF_H
15 
16 #include <mpi.h>
17 #include <string>
18 #include "Parallel/mpibuf.h"
19 
35 {
36  private:
37  char* m_buffer;
39  int m_position;
41  bool m_lock;
42  MPI_Request m_req[2];
43  MPI_Status m_stat[2];
44 
45  protected:
46  void grow();
47  void growTo(int);
48 
49  public:
50  CVarMPIBuffer(MPI_Comm,int size=16);
51  virtual ~CVarMPIBuffer();
52 
53  virtual void clear(){m_position=0;};
54  virtual void sendTo(int,int);
55  virtual void NBsendTo(int,int);
56  virtual void initSendTo(int,int);
57  virtual void wait();
58  virtual void receiveFrom(int src=MPI_ANY_SOURCE,int tag=MPI_ANY_TAG);
59  virtual void append(int);
60  virtual void append(double);
61  virtual void append(const char*);
62  virtual void append(const Vec3 &V) { AMPIBufferPP::append(V); } ;
63  virtual int pop_int();
64  virtual double pop_double();
65  virtual void pop_doubles(double*,int);
66  virtual std::string pop_string();
67  virtual void broadcast(int);
68  virtual void receiveBroadcast(int);
69 };
70 #endif //__MPIVBUF_H
CVarMPIBuffer::pop_int
virtual int pop_int()
Definition: mpivbuf.cpp:196
CVarMPIBuffer::~CVarMPIBuffer
virtual ~CVarMPIBuffer()
Definition: mpivbuf.cpp:39
CVarMPIBuffer
MPI send/recv buffer with automagically adjusted size.
Definition: mpivbuf.h:35
esys::lsm::bpu::len
int len(const boost::python::object &pyOb)
Definition: Util.h:30
CVarMPIBuffer::append
virtual void append(const Vec3 &V)
Definition: mpivbuf.h:62
CVarMPIBuffer::m_req
MPI_Request m_req[2]
Definition: mpivbuf.h:42
CVarMPIBuffer::receiveFrom
virtual void receiveFrom(int src=MPI_ANY_SOURCE, int tag=MPI_ANY_TAG)
Definition: mpivbuf.cpp:112
CVarMPIBuffer::m_dbl_increment
int m_dbl_increment
the "packing size" of int/double
Definition: mpivbuf.h:40
CVarMPIBuffer::sendTo
virtual void sendTo(int, int)
Definition: mpivbuf.cpp:53
AMPIBuffer::m_comm
MPI_Comm m_comm
the MPI Communicator used for the send/recv operations
Definition: mpibuf.h:36
CVarMPIBuffer::m_stat
MPI_Status m_stat[2]
for the ISendTo/Wait stuff
Definition: mpivbuf.h:43
console.h
AMPIBuffer::m_status
MPI_Status m_status
Definition: mpibuf.h:37
CVarMPIBuffer::pop_doubles
virtual void pop_doubles(double *, int)
Definition: mpivbuf.cpp:221
CVarMPIBuffer::append
virtual void append(int)
Definition: mpivbuf.cpp:152
CVarMPIBuffer::growTo
void growTo(int)
Definition: mpivbuf.cpp:128
CVarMPIBuffer::m_buffer
char * m_buffer
Definition: mpivbuf.h:37
CVarMPIBuffer::receiveBroadcast
virtual void receiveBroadcast(int)
Definition: mpivbuf.cpp:262
CVarMPIBuffer::wait
virtual void wait()
Definition: mpivbuf.cpp:99
CVarMPIBuffer::initSendTo
virtual void initSendTo(int, int)
Definition: mpivbuf.cpp:84
CVarMPIBuffer::pop_double
virtual double pop_double()
Definition: mpivbuf.cpp:210
Console::Critical
Console & Critical()
set verbose level of next message to "crt"
Definition: console.cpp:141
mpivbuf.h
CVarMPIBuffer::m_position
int m_position
the current end of the content
Definition: mpivbuf.h:39
mpibuf.h
CVarMPIBuffer::m_lock
bool m_lock
Definition: mpivbuf.h:41
CVarMPIBuffer::CVarMPIBuffer
CVarMPIBuffer(MPI_Comm, int size=16)
Definition: mpivbuf.cpp:27
CVarMPIBuffer::broadcast
virtual void broadcast(int)
Definition: mpivbuf.cpp:251
CVarMPIBuffer::clear
virtual void clear()
Definition: mpivbuf.h:53
Vec3
Definition: vec3.h:47
CVarMPIBuffer::NBsendTo
virtual void NBsendTo(int, int)
Definition: mpivbuf.cpp:68
CVarMPIBuffer::m_buffersize
int m_buffersize
the size of the buffer
Definition: mpivbuf.h:38
CVarMPIBuffer::m_int_increment
int m_int_increment
Definition: mpivbuf.h:40
AMPIBufferPP
Abstarct base class for Point-to-Point communication buffers.
Definition: mpibuf.h:66
console
Console console
Definition: console.cpp:25
CVarMPIBuffer::pop_string
virtual std::string pop_string()
Definition: mpivbuf.cpp:233
AMPIBuffer::append
virtual void append(int)=0
CVarMPIBuffer::grow
void grow()
Definition: mpivbuf.cpp:142