Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/tools/impi

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  1 // Copyright (C) 2010, Guy Barrand. All rights reserved.
  2 // See the file tools.license for terms.
  3 
  4 #ifndef tools_impi
  5 #define tools_impi
  6 
  7 #include <string>
  8 #include <vector>
  9 
 10 #include "typedefs"
 11 
 12 namespace tools {
 13 
 14 class impi {
 15 public:
 16   virtual ~impi(){}
 17 public:
 18   virtual bool pack(char) = 0;
 19   virtual bool pack(short) = 0;
 20   virtual bool pack(int) = 0;
 21   virtual bool pack(unsigned int) = 0;
 22   virtual bool pack(uint64) = 0;
 23   virtual bool pack(int64) = 0;
 24   virtual bool pack(float) = 0;
 25   virtual bool pack(double)  = 0;
 26   virtual bool bpack(bool) = 0;
 27   virtual bool spack(const std::string&) = 0;
 28   virtual bool vpack(const std::vector<unsigned int>&) = 0;
 29   virtual bool vpack(const std::vector<int>&) = 0;
 30   virtual bool vpack(const std::vector<double>&) = 0;
 31   virtual bool pack(uint32,const char*) = 0;
 32   virtual bool pack(uint32,const int*) = 0;
 33 
 34   virtual bool unpack(char&) = 0;
 35   virtual bool unpack(short&) = 0;
 36   virtual bool unpack(int&) = 0;
 37   virtual bool unpack(unsigned int&) = 0;
 38   virtual bool unpack(uint64&) = 0;
 39   virtual bool unpack(int64&) = 0;
 40   virtual bool unpack(float&) = 0;
 41   virtual bool unpack(double&)  = 0;
 42   virtual bool bunpack(bool&) = 0;
 43   virtual bool sunpack(std::string&) = 0;
 44   virtual bool vunpack(std::vector<unsigned int>&) = 0;
 45   virtual bool vunpack(std::vector<int>&) = 0;
 46   virtual bool vunpack(std::vector<double>&) = 0;
 47   virtual bool unpack(uint32&,char*&) = 0;
 48   virtual bool unpack(uint32&,int*&) = 0;
 49 
 50   virtual void pack_reset() = 0;
 51   virtual bool send_buffer(int,int) = 0;
 52 
 53   virtual bool wait_buffer(int rank,int src,int tag,int& probe_src,bool verbose = false) = 0;
 54   virtual bool wait_buffer(int rank,int tag,int& probe_src,bool verbose = false) = 0; //MPI_ANY_SOURCE.
 55 };
 56 
 57 }
 58 
 59 #endif