update build process to include paradiseo tutorial,

fix paradiseo headers for sstream
This commit is contained in:
kuepper 2004-09-22 12:38:28 +00:00
commit 3cb80bc73b
14 changed files with 139 additions and 68 deletions

View file

@ -25,9 +25,10 @@
#ifndef _EOPOP_H
#define _EOPOP_H
#include <vector>
#include <algorithm>
#include <iostream>
#include <iterator> // needed for GCC 3.2
#include <vector>
// EO includes
#include <eoOp.h> // for eoInit

View file

@ -24,11 +24,12 @@
#ifndef eoListener_h
#define eoListener_h
#include <mpi.h>
#include <vector>
#include <paradisEO/comm/eoLocalListener.h>
#include <paradisEO/comm/messages/to/eoPublishMessTo.h>
#include <paradisEO/comm/messages/to/eoKillMessTo.h>
#include <mpi.h>
/**
Necessary for any use of a distributed model.

View file

@ -24,16 +24,17 @@
#ifndef eoLocalListener_h
#define eoLocalListener_h
#include <mpi.h>
#include <queue>
#include <string>
#include <unistd.h>
#include <paradisEO/comm/messages/from/eoHeaderMessFrom.h>
#include <paradisEO/comm/messages/from/eoEOReceiveMessFrom.h>
#include <paradisEO/comm/messages/from/eoEOSendMessFrom.h>
#include <paradisEO/comm/messages/from/eoPublishMessFrom.h>
#include <paradisEO/comm/messages/from/eoKillMessFrom.h>
#include <eoPop.h>
#include <mpi.h>
#include <unistd.h>
/**
A local listener to pack any coming message or, on contrary, to

View file

@ -28,6 +28,7 @@
#include <config.h>
#endif
#include <mpi.h>
#include <iostream>
#include <string>
#ifdef HAVE_SSTREAM
@ -35,49 +36,47 @@
#else
#include <strstream.h>
#endif
#include <mpi.h>
#include <paradisEO/comm/messages/eoMessFrom.h>
using namespace std;
/**
A message embeding a set of immigrants ...
*/
template <class EOT> class eoEOSendMessFrom : public eoMessFrom <EOT> {
template <class EOT> class eoEOSendMessFrom : public eoMessFrom <EOT>
{
public:
public :
/**
Constructor
*/
eoEOSendMessFrom (eoLocalListener <EOT> & _loc_listen)
: eoMessFrom <EOT> (_loc_listen) {
MPI :: Status stat ;
comm.Probe (loc_listen.number (), 0, stat) ;
int len = stat.Get_count (MPI :: CHAR) ;
char buff [len] ;
comm.Recv(buff, len, MPI::CHAR, loc_listen.number (), 0) ;
#ifdef HAVE_SSTREAM
std::istringstream f(buff);
#else
istrstream f(buff);
#endif
_pop.readFrom(f);
}
/**
Constructor
*/
void operator() () {
loc_listen.push (_pop) ;
// std::cout << "Reception de " << pop.size () << "individus " << std::endl ;
}
eoEOSendMessFrom (eoLocalListener <EOT> & _loc_listen) :
eoMessFrom <EOT> (_loc_listen) {
MPI :: Status stat ;
comm.Probe (loc_listen.number (), 0, stat) ;
int len = stat.Get_count (MPI :: CHAR) ;
char buff [len] ;
comm.Recv (buff, len, MPI :: CHAR, loc_listen.number (), 0) ;
istrstream f (buff) ;
pop.readFrom (f) ;
}
void operator () () {
loc_listen.push (pop) ;
// std::cout << "Reception de " << pop.size () << "individus " << std::endl ;
}
protected:
private :
eoPop <EOT> pop ; // New immigrants !
} ;
eoPop <EOT> _pop ; // New immigrants !
};
#endif

View file

@ -21,49 +21,59 @@
Contact: cahon@lifl.fr
*/
/**
A message embeding immigrants to send to ...
*/
#ifndef eoEOSendMessTo_h
#define eoEOSendMessTo_h
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <mpi.h>
#ifdef HAVE_SSTREAM
#include <sstream>
#else
#include <strstream.h>
#endif
#include <eoPop.h>
#include <paradisEO/comm/messages/eoMessTo.h>
/** A message embeding immigrants to send to ... */
template <class EOT> class eoEOSendMessTo : public eoMessTo <EOT> {
public :
/**
Constructor ...
*/
/**
Constructor ...
*/
eoEOSendMessTo (eoPop <EOT> & _pop )
: eoMessTo <EOT> ("eoEOSendMessTo"),
pop (_pop)
{}
eoEOSendMessTo (eoPop <EOT> & _pop )
: eoMessTo <EOT> ("eoEOSendMessTo"),
pop (_pop)
{}
/**
To send the given population ...
*/
void operator () (eoLocalListener <EOT> & loc_listen) {
eoMessTo <EOT> :: operator () (loc_listen) ;
#ifdef HAVE_SSTREAM
std::ostringstream f;
pop.printOn(f);
comm.Send(f.str().c_str(), f.str().size(), MPI::CHAR, loc_listen.number(), 0);
#else
std::ostrstream f;
pop.printOn (f);
comm.Send (f.str(), f.pcount(), MPI::CHAR, loc_listen.number(), 0);
#endif
loc_listen.need_immigration () = false;
}
/**
To send the given population ...
*/
void operator () (eoLocalListener <EOT> & loc_listen) {
eoMessTo <EOT> :: operator () (loc_listen) ;
std::ostrstream f ;
pop.printOn (f) ;
comm.Send (f.str (), f.pcount (), MPI :: CHAR, loc_listen.number (), 0) ;
loc_listen.need_immigration () = false ;
}
private :
eoPop <EOT> & pop ; // The set of EO to send.
protected:
eoPop <EOT> & pop ; // The set of EO to send.
} ;
#endif