29 #ifndef STATSERVICES_H
30 #define STATSERVICES_H
93 typedef list< StatHandlerBase* >::const_iterator
stat_it;
95 typedef list< StatRecBase* >::const_iterator
rec_it;
97 StatServices ( ) : _popPtr(0), _occurrence(0), _currentStatValues(0),
98 _numRecorders(0), _width(12), _precision(6), _separator(
'\t'), _printAverages(1)
103 virtual bool init ( );
109 void set (
string& str,
unsigned int occ)
110 {_statArg = str; _occurrence = occ;}
123 void setOccurrences (map<unsigned int, unsigned int> timeTable);
132 return _statValues[replicate-1].size();
140 void printStatHeaders (ofstream& FH);
148 void printStatValue (ofstream& FH,
unsigned int repl_idx);
150 void printStatAverage (ofstream& FH);
163 list<StatRecBase*> getAllStats ( );
173 return &_statValues[ replicate-1 ];
178 assert(occurence < _occurrences.size());
179 return _statValues[ replicate-1 ][ occurence ];
184 assert( _statValues[ replicate-1 ].size() < _occurrences.size() );
186 assert( size == _numRecorders+2);
188 double* new_record =
new double[size];
190 memcpy(new_record, values, size*
sizeof(
double));
192 _statValues[ replicate-1 ].push_back(new_record);
197 void recordStats (
unsigned int gen);
199 virtual void notify ();
209 virtual void attach (
Handler* H);
213 virtual void reset ( );
216 void reset_stat_table();
Service handler (an observer).
Definition: handler.h:35
Interface for the simulation services (files and stats).
Definition: service.h:42
Interface to all basic components of a simulation (traits, life cycle events, pop,...
Definition: simcomponent.h:44
Base class of the StatHandler class, implements the Handler interface.
Definition: stathandler.h:47
The Service class used to manage the StatHandler objects.
Definition: statservices.h:49
void setFieldPrecision(unsigned int val)
Definition: statservices.h:156
void setDefaultOutputFormat()
Definition: statservices.h:160
void setOcccurrence(unsigned int value)
Definition: statservices.h:119
Metapop * _popPtr
Definition: statservices.h:53
void cancelPrintAverages()
Definition: statservices.h:142
double * getGenerationStatValues(unsigned int replicate, unsigned int occurence) const
Definition: statservices.h:176
unsigned int getNumOccurrences()
Returns the maximum number of generation records per replicate.
Definition: statservices.h:125
Metapop * get_pop_ptr()
Definition: statservices.h:105
void resetCurrentOccurrence()
Resets the occurrence iterator to the beginning of the list of generation occurrences.
Definition: statservices.h:137
unsigned char _separator
Definition: statservices.h:87
void set(string &str, unsigned int occ)
Definition: statservices.h:109
unsigned int getNumOccurrences(unsigned int replicate)
Returns the number of generation records present in the stat table for a replicate.
Definition: statservices.h:130
unsigned int _occurrence
Deprecated.
Definition: statservices.h:74
list< unsigned int > _occurrences
List of all generations to record.
Definition: statservices.h:77
vector< vector< double * > > _statValues
Table containing all recorded stats, replicate x generation x (num recorders + 2) .
Definition: statservices.h:65
StatServices()
Definition: statservices.h:97
string _statArg
The string argument of the 'stat' input option.
Definition: statservices.h:71
void copyGenerationStatValues(unsigned int replicate, unsigned int occurence, double *values, unsigned int size)
Definition: statservices.h:182
void doPrintAverages()
Definition: statservices.h:141
void set_pop_ptr(Metapop *pop)
Definition: statservices.h:107
unsigned int getCurrentOccurrence()
Returns the last generation recorded for current replicate.
Definition: statservices.h:135
void setStatOptions(string &str)
Definition: statservices.h:112
unsigned int _precision
Definition: statservices.h:85
unsigned int _numRecorders
Number of stats to record.
Definition: statservices.h:62
string & getStatArg()
Definition: statservices.h:114
void setFieldSeparator(unsigned char c)
Definition: statservices.h:158
list< StatRecBase * > _statRecorders
List of stat recorders.
Definition: statservices.h:59
void setFieldWidth(unsigned int val)
Definition: statservices.h:154
stat_it getFirst()
Definition: statservices.h:167
list< StatHandlerBase * >::const_iterator stat_it
Definition: statservices.h:93
unsigned int getOccurrence()
Definition: statservices.h:117
vector< double * > * getReplicateStatRecords(unsigned int replicate)
Definition: statservices.h:171
bool getPrintAveragesOpt()
Definition: statservices.h:143
list< StatRecBase * >::const_iterator rec_it
Definition: statservices.h:95
list< unsigned int >::const_iterator _current_occurrence
Iterator pointing to the current generation to record.
Definition: statservices.h:82
virtual ~StatServices()
Definition: statservices.h:101
list< StatHandlerBase * > _statHandlers
List of stat handlers declared by currently active simulation components.
Definition: statservices.h:56
void setCompactOutputFormat()
Definition: statservices.h:152
unsigned int getNumStats()
Definition: statservices.h:165
bool _printAverages
Definition: statservices.h:89
stat_it getLast()
Definition: statservices.h:169
double * _currentStatValues
Pointer to the last recorded stats.
Definition: statservices.h:68