Documentation of serialization, utils/eoTimer and eoPopEvalFunc.

This commit is contained in:
Benjamin Bouvier 2012-07-12 13:56:54 +02:00
commit 60fff427fe
18 changed files with 853 additions and 415 deletions

View file

@ -33,12 +33,6 @@
#include <vector> #include <vector>
#include <omp.h> #include <omp.h>
# ifdef WITH_MPI
# include <mpi/eoMpi.h>
# include <mpi/eoMultiParallelApply.h>
# include <mpi/eoTerminateJob.h>
# endif // WITH_MPI
/** /**
Applies a unary function to a std::vector of things. Applies a unary function to a std::vector of things.
@ -85,21 +79,6 @@ void apply(eoUF<EOT&, void>& _proc, std::vector<EOT>& _pop)
#endif // !_OPENMP #endif // !_OPENMP
} }
#ifdef WITH_MPI
template<class EOT>
void parallelApply(
std::vector<EOT>& _pop,
eo::mpi::AssignmentAlgorithm& _algo,
int _masterRank,
eo::mpi::ParallelApplyStore<EOT> & _store )
{
_store.data( _pop );
_algo.reinit( _pop.size() );
eo::mpi::ParallelApply<EOT> job( _algo, _masterRank, _store );
job.run();
}
#endif
/** /**
This is a variant of apply<EOT> which is called in parallel This is a variant of apply<EOT> which is called in parallel
thanks to OpenMP. thanks to OpenMP.

View file

@ -37,8 +37,6 @@
#include <eoMergeReduce.h> #include <eoMergeReduce.h>
#include <eoReplacement.h> #include <eoReplacement.h>
template <class EOT> class eoIslandsEasyEA ; template <class EOT> class eoIslandsEasyEA ;
template <class EOT> class eoDistEvalEasyEA ; template <class EOT> class eoDistEvalEasyEA ;
@ -106,7 +104,7 @@ template<class EOT> class eoEasyEA: public eoAlgo<EOT>
* @brief Ctor allowing to specify which pop eval function we're going to use. * @brief Ctor allowing to specify which pop eval function we're going to use.
* *
* Ctor taking a breed and merge, an overload of ctor to define an offspring size, and * Ctor taking a breed and merge, an overload of ctor to define an offspring size, and
* the pop eval function used. This allows to precise if we would like to use the * the pop eval function used. This allows to precise if we would like to use the
* parallel evaluation, for instance. * parallel evaluation, for instance.
*/ */
eoEasyEA( eoEasyEA(
@ -247,57 +245,43 @@ template<class EOT> class eoEasyEA: public eoAlgo<EOT>
virtual void operator()(eoPop<EOT>& _pop) virtual void operator()(eoPop<EOT>& _pop)
{ {
eo::log << "[EasyEA] Call to operator()" << std::endl; if (isFirstCall)
if (isFirstCall)
{
size_t total_capacity = _pop.capacity() + offspring.capacity();
_pop.reserve(total_capacity);
offspring.reserve(total_capacity);
isFirstCall = false;
}
// TODO TODOB delete all log traces
std::cout << "[EasyEA] After is first call." << std::endl;
eoPop<EOT> empty_pop;
std::cout << "[EasyEA] After empty_pop." << std::endl;
popEval(empty_pop, _pop); // A first eval of pop.
std::cout << "[EasyEA] After pop_eval." << std::endl;
do
{ {
try size_t total_capacity = _pop.capacity() + offspring.capacity();
_pop.reserve(total_capacity);
offspring.reserve(total_capacity);
isFirstCall = false;
}
eoPop<EOT> empty_pop;
do
{
try
{ {
std::cout << "[EasyEA] Beginning try." << std::endl; unsigned pSize = _pop.size();
unsigned pSize = _pop.size();
std::cout << "[EasyEA] psize determinated." << std::endl;
offspring.clear(); // new offspring
std::cout << "[EasyEA] offspring cleared." << std::endl;
breed(_pop, offspring); offspring.clear(); // new offspring
std::cout << "[EasyEA] After breed, evaluating pop." << std::endl; breed(_pop, offspring);
popEval(_pop, offspring); // eval of parents + offspring if necessary
std::cout << "[EasyEA] After evaluation, replacing pop." << std::endl; popEval(_pop, offspring); // eval of parents + offspring if necessary
replace(_pop, offspring); // after replace, the new pop. is in _pop
std::cout << "[EasyEA] After replacing, continuator." << std::endl;
if (pSize > _pop.size()) replace(_pop, offspring); // after replace, the new pop. is in _pop
throw std::runtime_error("Population shrinking!");
else if (pSize < _pop.size())
throw std::runtime_error("Population growing!");
if (pSize > _pop.size())
throw std::runtime_error("Population shrinking!");
else if (pSize < _pop.size())
throw std::runtime_error("Population growing!");
} }
catch (std::exception& e) catch (std::exception& e)
{ {
std::string s = e.what(); std::string s = e.what();
s.append( " in eoEasyEA"); s.append( " in eoEasyEA");
throw std::runtime_error( s ); throw std::runtime_error( s );
} }
} }
while ( continuator( _pop ) ); while ( continuator( _pop ) );
} }
protected : protected :

View file

@ -30,6 +30,13 @@
#include <eoEvalFunc.h> #include <eoEvalFunc.h>
#include <apply.h> #include <apply.h>
# ifdef WITH_MPI
#include <mpi/eoMpi.h>
#include <mpi/eoTerminateJob.h>
#include <mpi/eoMpiAssignmentAlgorithm.h>
#include <mpi/eoParallelApply.h>
# endif // WITH_MPI
/** eoPopEvalFunc: This abstract class is for GLOBAL evaluators /** eoPopEvalFunc: This abstract class is for GLOBAL evaluators
* of a population after variation. * of a population after variation.
* It takes 2 populations (typically the parents and the offspring) * It takes 2 populations (typically the parents and the offspring)
@ -78,12 +85,43 @@ private:
}; };
#ifdef WITH_MPI #ifdef WITH_MPI
// TODO TODOB commenter /**
* @brief Evaluator of a population of EOT which uses parallelization to evaluate individuals.
*
* This class implements an instance of eoPopEvalFunc that applies a private eoEvalFunc to
* all offspring, but in a parallel way. The original process becomes the central host from a network ("master"), and
* other machines disponible in the MPI network ("slaves") are used as evaluators. Population to evaluate is splitted in
* little packets of individuals, which are sent to the evaluators, that process the effective call to eval. Once all
* the individuals have been evaluated, they are returned to the master. The whole process is entirely invisible to the
* eyes of the user, who just has to launch a certain number of processes in MPI so as to have a result.
*
* The eoEvalFunc is no more directly given, but it is stored in the eo::mpi::ParallelApplyStore, which can be
* instanciated if no one is given at construction.
*
* The use of this class requires the user to have called the eo::mpi::Node::init function, at the beginning of its
* program.
*
* @ingroup Evaluation Parallel
*
* @author Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
template<class EOT> template<class EOT>
class eoParallelPopLoopEval : public eoPopEvalFunc<EOT> class eoParallelPopLoopEval : public eoPopEvalFunc<EOT>
{ {
public: public:
/** Ctor: set value of embedded eoEvalFunc */ /**
* @brief Constructor which creates the job store for the user.
*
* This constructor is the simplest to use, as it creates the store used by the parallel job, for the user.
* The user just precises the scheduling algorithm, the rank of the master and then gives its eval function and
* the size of a packet (how many individuals should be in a single message to evaluator).
*
* @param _assignAlgo The scheduling algorithm used to give orders to evaluators.
* @param _masterRank The MPI rank of the master.
* @param _eval The evaluation functor used to evaluate each individual in the population.
* @param _packetSize The number of individuals to send in one message to evaluator, and which are evaluated at
* a time.
*/
eoParallelPopLoopEval( eoParallelPopLoopEval(
// Job parameters // Job parameters
eo::mpi::AssignmentAlgorithm& _assignAlgo, eo::mpi::AssignmentAlgorithm& _assignAlgo,
@ -94,12 +132,21 @@ class eoParallelPopLoopEval : public eoPopEvalFunc<EOT>
) : ) :
assignAlgo( _assignAlgo ), assignAlgo( _assignAlgo ),
masterRank( _masterRank ), masterRank( _masterRank ),
needToDeleteStore( true ) needToDeleteStore( true ) // we used new, we'll have to use delete (RAII)
{ {
// FIXME memory leak because of new.
store = new eo::mpi::ParallelApplyStore<EOT>( _eval, _masterRank, _packetSize ); store = new eo::mpi::ParallelApplyStore<EOT>( _eval, _masterRank, _packetSize );
} }
/**
* @brief Constructor which allows the user to customize its job store.
*
* This constructor allows the user to customize the store, for instance by adding wrappers and other
* functionnalities, before using it for the parallelized evaluation.
*
* @param _assignAlgo The scheduling algorithm used to give orders to evaluators.
* @param _masterRank The MPI rank of the master.
* @param _store Pointer to a parallel eval store given by the user.
*/
eoParallelPopLoopEval( eoParallelPopLoopEval(
// Job parameters // Job parameters
eo::mpi::AssignmentAlgorithm& _assignAlgo, eo::mpi::AssignmentAlgorithm& _assignAlgo,
@ -109,37 +156,57 @@ class eoParallelPopLoopEval : public eoPopEvalFunc<EOT>
assignAlgo( _assignAlgo ), assignAlgo( _assignAlgo ),
masterRank( _masterRank ), masterRank( _masterRank ),
store( _store ), store( _store ),
needToDeleteStore( false ) needToDeleteStore( false ) // we haven't used new for creating store, we don't care if we have to delete it (RAII).
{ {
// empty // empty
} }
/**
* @brief Default destructor. Sends a message to all evaluators indicating that the global loop (eoEasyEA, for
* instance) is over.
*/
~eoParallelPopLoopEval() ~eoParallelPopLoopEval()
{ {
// Only the master has to send the termination message
if( eo::mpi::Node::comm().rank() == masterRank ) if( eo::mpi::Node::comm().rank() == masterRank )
{ {
eo::mpi::EmptyJob job( assignAlgo, masterRank ); eo::mpi::EmptyJob job( assignAlgo, masterRank );
job.run(); job.run();
} }
// RAII
if( needToDeleteStore ) if( needToDeleteStore )
{ {
delete store; delete store;
} }
} }
/** Do the job: simple loop over the offspring */ /**
* @brief Parallel implementation of the operator().
*
* @param _parents Population of parents (ignored).
* @param _offspring Population of children, which will be evaluated.
*/
void operator()( eoPop<EOT> & _parents, eoPop<EOT> & _offspring ) void operator()( eoPop<EOT> & _parents, eoPop<EOT> & _offspring )
{ {
(void)_parents; (void)_parents;
parallelApply<EOT>(_offspring, assignAlgo, masterRank, *store); // Reinits the store and the scheduling algorithm
store->data( _offspring );
assignAlgo.reinit( _offspring.size() );
// Effectively launches the job.
eo::mpi::ParallelApply<EOT> job( assignAlgo, masterRank, *store );
job.run();
} }
private: private:
// Scheduling algorithm
eo::mpi::AssignmentAlgorithm & assignAlgo; eo::mpi::AssignmentAlgorithm & assignAlgo;
// Master MPI rank
int masterRank; int masterRank;
// Store
eo::mpi::ParallelApplyStore<EOT>* store; eo::mpi::ParallelApplyStore<EOT>* store;
// Do we have to delete the store by ourselves ?
bool needToDeleteStore; bool needToDeleteStore;
}; };
#endif #endif

View file

@ -1,38 +1,58 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# include "Array.h" # include "Array.h"
namespace eoserial namespace eoserial
{ {
std::ostream& Array::print( std::ostream& out ) const
std::ostream& Array::print( std::ostream& out ) const
{
out << "[";
bool first = true;
for (ArrayChildren::const_iterator it = begin(),
end = this->end();
it != end;
++it)
{ {
if ( first ) out << "[";
bool first = true;
for (ArrayChildren::const_iterator it = begin(),
end = this->end();
it != end;
++it)
{ {
first = false; if ( first )
} else { {
out << ", "; first = false;
} else {
out << ", ";
}
(*it)->print( out );
} }
(*it)->print( out ); out << "]\n";
return out;
} }
out << "]\n";
return out;
}
Array::~Array() Array::~Array()
{
for (ArrayChildren::iterator it = begin(),
end = this->end();
it != end;
++it)
{ {
delete *it; for (ArrayChildren::iterator it = begin(),
end = this->end();
it != end;
++it)
{
delete *it;
}
} }
}
} // namespace eoserial } // namespace eoserial

View file

@ -1,148 +1,169 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_ARRAY_H__ # ifndef __EOSERIAL_ARRAY_H__
# define __EOSERIAL_ARRAY_H__ # define __EOSERIAL_ARRAY_H__
# include <vector> # include <vector>
# include <iostream>
# include "Entity.h" # include "Entity.h"
# include "Serializable.h" # include "Serializable.h"
# include "Object.h" # include "Object.h"
# include "String.h"
namespace eoserial namespace eoserial
{ {
// Forward declaration for below declarations. // Forward declaration for below declarations.
class Array; class Array;
/*
* Declarations of functions present in Utils.h
* These are put here to avoid instead of including the file Utils.h, which would
* cause a circular inclusion.
*/
template< class T >
void unpack( const Array & array, unsigned int index, T & value );
void unpackObject( const Array & array, unsigned int index, Persistent & value );
template< class Container, template<class> class UnpackAlgorithm >
void unpackArray( const Array & array, unsigned int index, Container & container );
/**
* @brief Represents a JSON array.
*
* Wrapper for an array, so as to be used as a JSON object.
*/
class Array : public eoserial::Entity, public std::vector< eoserial::Entity* >
{
protected:
typedef std::vector< eoserial::Entity* > ArrayChildren;
public:
/**
* @brief Adds the serializable object as a JSON object.
* @param obj Object which implemnets JsonSerializable.
*/
void push_back( const eoserial::Printable* obj )
{
ArrayChildren::push_back( obj->pack() );
}
/**
* @brief Proxy for vector::push_back.
*/
void push_back( eoserial::Entity* json )
{
ArrayChildren::push_back( json );
}
/**
* @brief Prints the JSON array into the given stream.
* @param out The stream
*/
virtual std::ostream& print( std::ostream& out ) const;
/**
* @brief Dtor
*/
~Array();
/* /*
* The following parts allows the user to automatically deserialize an eoserial::Array into a * Declarations of functions present in Utils.h
* standard container, by giving the algorithm which will be used to deserialize contained entities. * These are put here to avoid instead of including the file Utils.h, which would
* cause a circular inclusion.
*/ */
template< class T >
void unpack( const Array & array, unsigned int index, T & value );
void unpackObject( const Array & array, unsigned int index, Persistent & value );
template< class Container, template<class> class UnpackAlgorithm >
void unpackArray( const Array & array, unsigned int index, Container & container );
/** /**
* @brief Functor which determines how to retrieve the real value contained in a eoserial::Entity at * @brief Represents a JSON array.
* a given place.
* *
* It will be applied for each contained variable in the array. * Wrapper for an array, so as to be used as a JSON object.
*
* @ingroup Serialization
*/ */
template<class Container> class Array : public eoserial::Entity, public std::vector< eoserial::Entity* >
struct BaseAlgorithm
{ {
/** protected:
* @brief Main operator. typedef std::vector< eoserial::Entity* > ArrayChildren;
*
* @param array The eoserial::Array from which we're reading. public:
* @param i The index of the contained value. /**
* @param container The standard (STL) container in which we'll push back the read value. * @brief Adds the serializable object as a JSON object.
*/ * @param obj Object which implemnets JsonSerializable.
virtual void operator()( const eoserial::Array& array, unsigned int i, Container & container ) const = 0; */
void push_back( const eoserial::Printable* obj )
{
ArrayChildren::push_back( obj->pack() );
}
/**
* @brief Proxy for vector::push_back.
*/
void push_back( eoserial::Entity* json )
{
ArrayChildren::push_back( json );
}
/**
* @brief Prints the JSON array into the given stream.
* @param out The stream
*/
virtual std::ostream& print( std::ostream& out ) const;
/**
* @brief Dtor
*/
~Array();
/*
* The following parts allows the user to automatically deserialize an eoserial::Array into a
* standard container, by giving the algorithm which will be used to deserialize contained entities.
*/
/**
* @brief Functor which determines how to retrieve the real value contained in a eoserial::Entity at
* a given place.
*
* It will be applied for each contained variable in the array.
*/
template<class Container>
struct BaseAlgorithm
{
/**
* @brief Main operator.
*
* @param array The eoserial::Array from which we're reading.
* @param i The index of the contained value.
* @param container The standard (STL) container in which we'll push back the read value.
*/
virtual void operator()( const eoserial::Array& array, unsigned int i, Container & container ) const = 0;
};
/**
* @brief BaseAlgorithm for retrieving primitive variables.
*
* This one should be used to retrieve primitive (and types which implement operator>>) variables, for instance
* int, double, std::string, etc...
*/
template<typename C>
struct UnpackAlgorithm : public BaseAlgorithm<C>
{
void operator()( const eoserial::Array& array, unsigned int i, C & container ) const
{
typename C::value_type t;
unpack( array, i, t );
container.push_back( t );
}
};
/**
* @brief BaseAlgorithm for retrieving eoserial::Persistent objects.
*
* This one should be used to retrieve objects which implement eoserial::Persistent.
*/
template<typename C>
struct UnpackObjectAlgorithm : public BaseAlgorithm<C>
{
void operator()( const eoserial::Array& array, unsigned int i, C & container ) const
{
typename C::value_type t;
unpackObject( array, i, t );
container.push_back( t );
}
};
/**
* @brief General algorithm for array deserialization.
*
* Applies the BaseAlgorithm to each contained variable in the eoserial::Array.
*/
template<class Container, template<class T> class UnpackAlgorithm>
inline void deserialize( Container & array )
{
UnpackAlgorithm< Container > algo;
for( unsigned int i = 0, size = this->size();
i < size;
++i)
{
algo( *this, i, array );
}
}
}; };
/**
* @brief BaseAlgorithm for retrieving primitive variables.
*
* This one should be used to retrieve primitive (and types which implement operator>>) variables, for instance
* int, double, std::string, etc...
*/
template<typename C>
struct UnpackAlgorithm : public BaseAlgorithm<C>
{
void operator()( const eoserial::Array& array, unsigned int i, C & container ) const
{
typename C::value_type t;
unpack( array, i, t );
container.push_back( t );
}
};
/**
* @brief BaseAlgorithm for retrieving eoserial::Persistent objects.
*
* This one should be used to retrieve objects which implement eoserial::Persistent.
*/
template<typename C>
struct UnpackObjectAlgorithm : public BaseAlgorithm<C>
{
void operator()( const eoserial::Array& array, unsigned int i, C & container ) const
{
typename C::value_type t;
unpackObject( array, i, t );
container.push_back( t );
}
};
/**
* @brief General algorithm for array deserialization.
*
* Applies the BaseAlgorithm to each contained variable in the eoserial::Array.
*/
template<class Container, template<class T> class UnpackAlgorithm>
inline void deserialize( Container & array )
{
UnpackAlgorithm< Container > algo;
for( unsigned int i = 0, size = this->size();
i < size;
++i)
{
algo( *this, i, array );
}
}
};
} // namespace eoserial } // namespace eoserial
# endif // __EOSERIAL_ARRAY_H__ # endif // __EOSERIAL_ARRAY_H__

View file

@ -1,9 +1,42 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_ENTITY_H__ # ifndef __EOSERIAL_ENTITY_H__
# define __EOSERIAL_ENTITY_H__ # define __EOSERIAL_ENTITY_H__
# include <iostream> # include <iostream> // ostream
# include <sstream>
/**
* @brief Contains all the necessary entities to serialize eo objects into JSON objects.
*
* Allows serialization from user objects into JSON objects, if they implement the interface
* eoserial::Serializable or eoserial::Persistent. The following user objects can be serialized:
* - primitive types (int, std::string, ...), in particular every type that can be written into a
* std::stringstream.
* - objects which implement eoserial::Serializable.
* - array of serializable things (primitive or serializable objects).
*
* @ingroup Utilities
* @defgroup Serialization Serialization helpers
*/
namespace eoserial namespace eoserial
{ {
@ -12,6 +45,8 @@ namespace eoserial
* *
* This class represents a JSON entity, which can be JSON objects, * This class represents a JSON entity, which can be JSON objects,
* strings or arrays. It is the base class for the JSON hierarchy. * strings or arrays. It is the base class for the JSON hierarchy.
*
* @ingroup Serialization
*/ */
class Entity class Entity
{ {

View file

@ -1,40 +1,60 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# include "Object.h" # include "Object.h"
using namespace eoserial; using namespace eoserial;
namespace eoserial namespace eoserial
{ {
std::ostream& Object::print( std::ostream& out ) const
std::ostream& Object::print( std::ostream& out ) const
{
out << '{';
bool first = true;
for(JsonValues::const_iterator it = begin(), end = this->end();
it != end;
++it)
{ {
if ( first ) out << '{';
bool first = true;
for(JsonValues::const_iterator it = begin(), end = this->end();
it != end;
++it)
{ {
first = false; if ( first )
} else { {
out << ", "; first = false;
} } else {
out << ", ";
}
out << '"' << it->first << "\":"; // key out << '"' << it->first << "\":"; // key
it->second->print( out ); // value it->second->print( out ); // value
}
out << "}\n";
return out;
}
Object::~Object()
{
for(JsonValues::iterator it = begin(), end = this->end();
it != end;
++it)
{
delete it->second;
} }
out << "}\n";
return out;
}
Object::~Object()
{
for(JsonValues::iterator it = begin(), end = this->end();
it != end;
++it)
{
delete it->second;
} }
}
} // namespace eoserial } // namespace eoserial

View file

@ -1,66 +1,87 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_OBJECT_H__ # ifndef __EOSERIAL_OBJECT_H__
# define __EOSERIAL_OBJECT_H__ # define __EOSERIAL_OBJECT_H__
# include <map> # include <map>
# include <string> # include <string>
# include <sstream>
# include "Entity.h" # include "Entity.h"
# include "Serializable.h" # include "Serializable.h"
namespace eoserial namespace eoserial
{ {
/**
* @brief JSON Object
*
* This class represents a JSON object, which is basically a dictionnary
* of keys (strings) and values (JSON entities).
*/
class Object : public eoserial::Entity, public std::map< std::string, eoserial::Entity* >
{
public:
typedef std::map<std::string, eoserial::Entity*> JsonValues;
/** /**
* @brief Adds a pair into the JSON object. * @brief JSON Object
* @param key The key associated with the eoserial object *
* @param eoserial The JSON object as created with framework. * This class represents a JSON object, which is basically a dictionnary
* of keys (strings) and values (JSON entities).
*
* @ingroup Serialization
*/ */
void add( const std::string& key, eoserial::Entity* json ) class Object : public eoserial::Entity, public std::map< std::string, eoserial::Entity* >
{ {
(*this)[ key ] = json; public:
} typedef std::map<std::string, eoserial::Entity*> JsonValues;
/** /**
* @brief Adds a pair into the JSON object. * @brief Adds a pair into the JSON object.
* @param key The key associated with the eoserial object * @param key The key associated with the eoserial object
* @param obj A JSON-serializable object * @param eoserial The JSON object as created with framework.
*/ */
void add( const std::string& key, const eoserial::Printable* obj ) void add( const std::string& key, eoserial::Entity* json )
{ {
(*this)[ key ] = obj->pack(); (*this)[ key ] = json;
} }
/** /**
* @brief Deserializes a Serializable class instance from this JSON object. * @brief Adds a pair into the JSON object.
* @param obj The object we want to rebuild. * @param key The key associated with the eoserial object
*/ * @param obj A JSON-serializable object
void deserialize( eoserial::Persistent & obj ) */
{ void add( const std::string& key, const eoserial::Printable* obj )
obj.unpack( this ); {
} (*this)[ key ] = obj->pack();
}
/** /**
* @brief Dtor * @brief Deserializes a Serializable class instance from this JSON object.
*/ * @param obj The object we want to rebuild.
~Object(); */
void deserialize( eoserial::Persistent & obj )
{
obj.unpack( this );
}
/** /**
* @brief Prints the content of a JSON object into a stream. * @brief Dtor
*/ */
virtual std::ostream& print( std::ostream& out ) const; ~Object();
};
/**
* @brief Prints the content of a JSON object into a stream.
*/
virtual std::ostream& print( std::ostream& out ) const;
};
} // namespace eoserial } // namespace eoserial
# endif // __EOSERIAL_OBJECT_H__ # endif // __EOSERIAL_OBJECT_H__

View file

@ -1,7 +1,25 @@
# include <map> /*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# include <string> # include <string>
# include <sstream>
# include <vector>
# include "Parser.h" # include "Parser.h"

View file

@ -1,3 +1,24 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_PARSER_H__ # ifndef __EOSERIAL_PARSER_H__
# define __EOSERIAL_PARSER_H__ # define __EOSERIAL_PARSER_H__
@ -6,6 +27,8 @@
# include "Object.h" # include "Object.h"
/** /**
* @file Parser.h
*
* This file contains a tiny JSON parser used in DAE. This parser just handles * This file contains a tiny JSON parser used in DAE. This parser just handles
* a subset of JSON grammar, with the following restrictions : * a subset of JSON grammar, with the following restrictions :
* - all strings must be surrounded by double quotes. * - all strings must be surrounded by double quotes.
@ -26,6 +49,8 @@ namespace eoserial
* This parser does just retrieve values and does NOT check the structure of * This parser does just retrieve values and does NOT check the structure of
* the input. This implies that if the input is not correct, the result is undefined * the input. This implies that if the input is not correct, the result is undefined
* and can result to a failure on execution. * and can result to a failure on execution.
*
* @ingroup Serialization
*/ */
class Parser class Parser
{ {

View file

@ -1,43 +1,65 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_SERIALIZABLE_H__ # ifndef __EOSERIAL_SERIALIZABLE_H__
# define __EOSERIAL_SERIALIZABLE_H__ # define __EOSERIAL_SERIALIZABLE_H__
# include <string>
namespace eoserial namespace eoserial
{ {
class Object; // to avoid recursive inclusion with JsonObject
class Object; // to avoid recursive inclusion with JsonObject
/**
* @brief Interface showing that object can be written to a eoserial type
* (currently JSON).
*/
class Printable
{
public:
/** /**
* @brief Serializes the object to JSON format. * @brief Interface showing that object can be written to a eoserial type
* @return A JSON object created with new. * (currently JSON).
*
* @ingroup Serialization
*/ */
virtual eoserial::Object* pack() const = 0; class Printable
}; {
public:
/**
* @brief Serializes the object to JSON format.
* @return A JSON object created with new.
*/
virtual eoserial::Object* pack() const = 0;
};
/**
* @brief Interface showing that object can be eoserialized (written and read
* from an input).
*
* Note : Persistent objects should have a default non-arguments constructor.
*/
class Persistent : public Printable
{
public:
/** /**
* @brief Loads class fields from a JSON object. * @brief Interface showing that object can be eoserialized (written and read
* @param json A JSON object. Programmer doesn't have to delete it, it * from an input).
* is automatically done. *
* Note : Persistent objects should have a default non-arguments constructor.
*
* @ingroup Serialization
*/ */
virtual void unpack(const eoserial::Object* json) = 0; class Persistent : public Printable
}; {
public:
/**
* @brief Loads class fields from a JSON object.
* @param json A JSON object. Programmer doesn't have to delete it, it
* is automatically done.
*/
virtual void unpack(const eoserial::Object* json) = 0;
};
} // namespace eoserial } // namespace eoserial

View file

@ -1,3 +1,24 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# include "String.h" # include "String.h"
namespace eoserial namespace eoserial

View file

@ -1,3 +1,24 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_STRING_H__ # ifndef __EOSERIAL_STRING_H__
# define __EOSERIAL_STRING_H__ # define __EOSERIAL_STRING_H__
@ -9,72 +30,73 @@
namespace eoserial namespace eoserial
{ {
/**
* @brief JSON String
*
* Wrapper for string, so as to be used as a JSON object.
*
* @ingroup Serialization
*/
class String : public eoserial::Entity, public std::string
{
public:
/** /**
* @brief JSON String * @brief Default ctor.
* * @param str The string we want to wrap.
* Wrapper for string, so as to be used as a JSON object. */
*/ String( const std::string& str ) : std::string( str ) {}
class String : public eoserial::Entity, public std::string
{
public:
/** /**
* @brief Default ctor. * @brief Ctor used only when parsing.
* @param str The string we want to wrap. */
*/ String( ) {}
String( const std::string& str ) : std::string( str ) {}
/** /**
* @brief Ctor used only on parsing. * @brief Prints out the string.
*/ */
String( ) {} virtual std::ostream& print( std::ostream& out ) const;
/** /**
* @brief Prints out the string. * @brief Deserializes the current String into a given primitive type value.
*/ * @param value The value in which we're writing.
virtual std::ostream& print( std::ostream& out ) const; */
template<class T>
inline void deserialize( T & value );
/** protected:
* @brief Deserializes the current String into a given primitive type value. // Copy and reaffectation are forbidden
* @param value The value in which we're writing. explicit String( const String& _ );
*/ String& operator=( const String& _ );
template<class T> };
inline void deserialize( T & value );
protected: /**
// Copy and reaffectation are forbidden * @brief Casts a eoserial::String into a primitive value, or in a type which at
explicit String( const String& _ ); * least overload operator>>.
String& operator=( const String& _ ); *
}; * @param value A reference to the variable we're writing into.
*
* It's not necessary to specify the variable type, which can be infered by compiler when
* invoking.
*/
template<class T>
inline void String::deserialize( T & value )
{
std::stringstream ss;
ss.precision(std::numeric_limits<double>::digits10 + 1);
ss << *this;
ss >> value;
}
/** /**
* @brief Casts a eoserial::String into a primitive value, or in a type which at * @brief Specialization for strings, which don't need to be converted through
* least overload operator>>. * a stringstream.
* */
* @param value A reference to the variable we're writing into. template<>
* inline void String::deserialize( std::string & value )
* It's not necessary to specify the variable type, which can be infered by compiler when {
* invoking. value = *this;
*/ }
template<class T>
inline void String::deserialize( T & value )
{
std::stringstream ss;
ss.precision(std::numeric_limits<double>::digits10 + 1);
ss << *this;
ss >> value;
}
/**
* @brief Specialization for strings, which don't need to be converted through
* a stringstream.
*/
template<>
inline void String::deserialize( std::string & value )
{
value = *this;
}
} // namespace eoserial } // namespace eoserial

View file

@ -1,3 +1,24 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_UTILS_H__ # ifndef __EOSERIAL_UTILS_H__
# define __EOSERIAL_UTILS_H__ # define __EOSERIAL_UTILS_H__
@ -7,7 +28,7 @@
namespace eoserial namespace eoserial
{ {
/***************************** /* ***************************
* DESERIALIZATION FUNCTIONS * * DESERIALIZATION FUNCTIONS *
***************************** *****************************
These functions are useful for casting eoserial::objects into simple, primitive These functions are useful for casting eoserial::objects into simple, primitive
@ -54,7 +75,7 @@ namespace eoserial
static_cast<Array*>( array[ index ] )->deserialize< Container, UnpackAlgorithm >( container ); static_cast<Array*>( array[ index ] )->deserialize< Container, UnpackAlgorithm >( container );
} }
/******************************* /* *****************************
*** SERIALIZATION FUNCTIONS *** *** SERIALIZATION FUNCTIONS ***
******************************* *******************************
These functions are useful for casting classic objects and These functions are useful for casting classic objects and

View file

@ -1,3 +1,24 @@
/*
(c) Thales group, 2012
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EOSERIAL_HEADERS__ # ifndef __EOSERIAL_HEADERS__
# define __EOSERIAL_HEADERS__ # define __EOSERIAL_HEADERS__

View file

@ -21,7 +21,7 @@
Contact: http://eodev.sourceforge.net Contact: http://eodev.sourceforge.net
Authors: Authors:
Caner Candan <caner.candan@thalesgroup.com> Caner Candan <caner.candan@thalesgroup.com>
*/ */
@ -37,7 +37,7 @@ eoParallel::eoParallel() :
_nthreads( 0, "parallelize-nthreads", "Define the number of threads you want to use, nthreads = 0 means you want to use all threads available", '\0' ), _nthreads( 0, "parallelize-nthreads", "Define the number of threads you want to use, nthreads = 0 means you want to use all threads available", '\0' ),
_enableResults( false, "parallelize-enable-results", "Enable the generation of results", '\0' ), _enableResults( false, "parallelize-enable-results", "Enable the generation of results", '\0' ),
_doMeasure( false, "parallelize-do-measure", "Do some measures during execution", '\0' ), _doMeasure( false, "parallelize-do-measure", "Do some measures during execution", '\0' ),
_packetSize( 1U, "parallelize-packet-size", "Number of elements which should be sent at a time during a parallel evaluation based on message passing.", '\0'), _packetSize( 1U, "parallelize-packet-size", "Number of elements which should be sent in a single message during a parallel evaluation based on message passing.", '\0'),
_t_start(0) _t_start(0)
{ {
} }

View file

@ -20,8 +20,7 @@
Contact: http://eodev.sourceforge.net Contact: http://eodev.sourceforge.net
Authors: Authors:
Caner Candan <caner.candan@thalesgroup.com> Caner Candan <caner.candan@thalesgroup.com>
*/ */
/** @defgroup Parallel Parallel /** @defgroup Parallel Parallel

View file

@ -1,38 +1,84 @@
# ifndef __TIMER_H__ /*
# define __TIMER_H__ (c) Thales group, 2012
# include <sys/time.h> This library is free software; you can redistribute it and/or
# include <sys/resource.h> modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2 of the License.
# include <vector> This library is distributed in the hope that it will be useful,
# include <map> but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
# include "utils/eoParallel.h" You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Contact: http://eodev.sourceforge.net
Authors:
Benjamin Bouvier <benjamin.bouvier@gmail.com>
*/
# ifndef __EO_TIMER_H__
# define __EO_TIMER_H__
# include <sys/time.h> // time()
# include <sys/resource.h> // rusage()
# include <vector> // std::vector
# include <map> // std::map
# include "utils/eoParallel.h" // eo::parallel
# ifdef WITH_MPI # ifdef WITH_MPI
// For serialization purposes
# include <boost/serialization/access.hpp> # include <boost/serialization/access.hpp>
# include <boost/serialization/vector.hpp> # include <boost/serialization/vector.hpp>
# include <boost/serialization/map.hpp> # include <boost/serialization/map.hpp>
# endif # endif
// TODO TODOB commenter /**
* @brief Timer allowing to measure time between a start point and a stop point.
*
* This timer allows the user to measure user time, system time and wallclock time
* between two points. Basically, user time is time spent in developer code ; system
* time is time spent during the IO wait and system calls ; wallclock is the difference
* of time we could observe by measuring time with a watch.
*
* @ingroup Utilities
*/
class eoTimer class eoTimer
{ {
public: public:
/**
* @brief Default ctor. Begins all the timers.
*/
eoTimer() eoTimer()
{
restart();
}
void restart()
{ {
uuremainder = 0; uuremainder = 0;
usremainder = 0; usremainder = 0;
restart();
}
/**
* @brief Restarts all the timers and launch the measure.
*/
void restart()
{
wc_start = time(NULL); wc_start = time(NULL);
getrusage( RUSAGE_SELF, &_start ); getrusage( RUSAGE_SELF, &_start );
} }
/**
* @brief Measures the user time spent since the last restart().
*
* If the number of elapsed seconds is zero, the spent milliseconds are
* added to a remainder. If the remainder exceeds one second, it is
* added to the number of elapsed seconds.
*
* @return Number of seconds elapsed in user space.
*/
long int usertime() long int usertime()
{ {
struct rusage _now; struct rusage _now;
@ -44,12 +90,21 @@ class eoTimer
if( uuremainder > 1000000) if( uuremainder > 1000000)
{ {
++result; ++result;
uuremainder = 0; uuremainder -= 1000000;
} }
} }
return result; return result;
} }
/**
* @brief Measures the system time spent since the last restart().
*
* If the number of elapsed seconds is zero, the spent milliseconds are
* added to a remainder. If the remainder exceeds one second, it is
* added to the number of elapsed seconds.
*
* @return Number of seconds elapsed in system (kernel) space.
*/
long int systime() long int systime()
{ {
struct rusage _now; struct rusage _now;
@ -61,28 +116,90 @@ class eoTimer
if( usremainder > 1000000) if( usremainder > 1000000)
{ {
++result; ++result;
usremainder = 0; usremainder -= 1000000;
} }
} }
return result; return result;
} }
/**
* @brief Measures the wallclock time spent since the last restart().
*
* @return Number of seconds elapsed, as a double.
*/
double wallclock() double wallclock()
{ {
return std::difftime( std::time(NULL) , wc_start ); return std::difftime( std::time(NULL) , wc_start );
} }
protected: protected:
// Structure used to measure user and system time.
struct rusage _start; struct rusage _start;
// Remainder (in milliseconds) for user time.
long int uuremainder; long int uuremainder;
// Remainder (in milliseconds) for system time.
long int usremainder; long int usremainder;
// Structure used to measure wallclock time.
time_t wc_start; time_t wc_start;
}; };
/**
* @brief Registers a group of statistics, each statistic corresponding to user, system and wallclock times distribution.
*
* This class helps the user to measure time in different parts of an application. A name is associated to a statistic,
* on each call to start() and stop() for this name, a new number is added to the statistic, for each of the three
* measured times.
*
* The statistics are only registered if the option "--parallelized-do-measure" is set to true, which can be checked
* thanks to global object eo::parallel.
*
* This shows how the eoTimerStat can be used :
* @code
* eoTimerStat timerStat;
* timerStat.start("first_point");
* for( int i = 0; i < 1000; ++i )
* {
* timerStat.start("single_computation");
* single_computation( i );
* timerStat.stop("single_computation");
* }
* // After this loop, timerStat contains a statistic of key "single_computation" which contains 1000 measures for
* // each type of time.
* timerStat.stop("first_point");
* // After this line, timerStat contains another statistic of key "first_point" which counted the duration of the
* // whole loop.
*
* int singleComputationUsertimeMean = 0;
* for( int i = 0; i < 1000; ++i )
* {
* singleComputationUsertimeMean += timerStat.stats()["single_computation"].utime[i];
* }
* std::cout << "Mean of user time spent in single computation: " << singleComputationUsertimeMean / 1000. << std::endl;
* @endcode
*
* When using MPI, these statistics can be readily be serialized, so as to be sent over a network, for instance.
*
* Implementation details: this eoTimerStat is in fact a map of strings (key) / Stat (value). Stat is an internal
* structure directly defined in the class, which contains three vectors modeling the distributions of the different
* types of elapsed times. Another map of strings (key) / eoTimer (value) allows to effectively retrieve the different
* times. The struct Stat will be exposed to client, which will use its members ; however,
* the client doesn't have anything to do directly with the timer, that's why the two maps are splitted.
*
* @ingroup Utilities
*/
class eoTimerStat class eoTimerStat
{ {
public: public:
/**
* @brief Statistic related to a key (name).
*
* This structure is the value in the map saved in the eoTimerStat. It contains the statistic bound to a key,
* which are the user time distribution, the system time distribution and the wallclock time distribution, as
* std::vector s.
*
* It can readily be serialized with boost when compiling with mpi.
*/
struct Stat struct Stat
{ {
std::vector<long int> utime; std::vector<long int> utime;
@ -93,25 +210,27 @@ class eoTimerStat
friend class boost::serialization::access; friend class boost::serialization::access;
/** /**
* Serializes the statistique in a boost archive (useful for boost::mpi) * Serializes the single statistic in a boost archive (useful for boost::mpi).
* Just serializes the 3 vectors.
*/ */
template <class Archive> template <class Archive>
void serialize( Archive & ar, const unsigned int version ) void serialize( Archive & ar, const unsigned int version )
{ {
ar & utime & stime & wtime; ar & utime & stime & wtime;
(void) version; // avoid compilation warning (void) version; // avoid compilation warning
} }
# endif # endif
}; };
#ifdef WITH_MPI #ifdef WITH_MPI
// Gives access to boost serialization // Gives access to boost serialization
friend class boost::serialization::access; friend class boost::serialization::access;
/** /**
* Serializes the map of statistics in a boost archive (useful for boost::mpi) * Serializes the timerStat object in a boost archive (useful for boost::mpi).
*/ * Just serializes the map.
template <class Archive> */
template <class Archive>
void serialize( Archive & ar, const unsigned int version ) void serialize( Archive & ar, const unsigned int version )
{ {
ar & _stats; ar & _stats;
@ -119,6 +238,14 @@ class eoTimerStat
} }
# endif # endif
/**
* @brief Starts a new measure for the given key.
*
* This is only performed if parallel.doMeasure() is true, which is equivalent to the fact that
* parser found "--parallel-do-measure=1" in command line args.
*
* @param key The key of the statistic.
*/
void start( const std::string & key ) void start( const std::string & key )
{ {
if( eo::parallel.doMeasure() ) if( eo::parallel.doMeasure() )
@ -127,6 +254,16 @@ class eoTimerStat
} }
} }
/**
* @brief Stops the mesure for the given key and saves the elapsed times.
*
* Must follow a call of start with the same key.
*
* This is only performed if parallel.doMeasure() is true, which is equivalent to the fact that
* parser found "--parallel-do-measure=1" in command line args.
*
* @param key The key of the statistic.
*/
void stop( const std::string& key ) void stop( const std::string& key )
{ {
if( eo::parallel.doMeasure() ) if( eo::parallel.doMeasure() )
@ -139,13 +276,18 @@ class eoTimerStat
} }
} }
std::map< std::string, Stat > stats() /**
* @brief Getter for the statistics map.
*/
std::map< std::string, Stat >& stats()
{ {
return _stats; return _stats;
} }
protected: protected:
// Statistics map: links a key (string) to a statistic.
std::map< std::string, Stat > _stats; std::map< std::string, Stat > _stats;
// Timers map: links a key to its timer.
std::map< std::string, eoTimer > _timers; std::map< std::string, eoTimer > _timers;
}; };