//------------------------------------------------------------ Engine::~Engine()
//------------------------------------------------------------------------------
Engine::~Engine() {
- for (_accumulator_vector_it it = a_accumulators.begin(); it != a_accumulators.end(); it++)
- delete (*it);
+ for (_accumulator_map_it it = a_accumulators.begin(); it != a_accumulators.end(); it++)
+ delete (it->second);
}
// For all concepts:
_concept_identification_map_nc_iter it_min(a_concept_identification_map.begin());
_concept_identification_map_nc_iter it_max(a_concept_identification_map.end());
-
for(it = it_min; it != it_max; it++) {
realName = "";
-
if(providedName != "") realName = anna::functions::asString("%s.%d.csv", providedName.c_str(), (*it).first);
-
SampleFile_ptr = &((*it).second.SampleFile);
*SampleFile_ptr = realName;
}
//--------------------------------------------------- Engine::disableSampleLog()
//------------------------------------------------------------------------------
bool Engine::disableSampleLog(const int & id) throw() {
- _concept_identification_map_nc_iter it = a_concept_identification_map.find(id);
- if(it == a_concept_identification_map.end()) return false;
+ if(id != -1) {
+ _concept_identification_map_nc_iter it = a_concept_identification_map.find(id);
- // Access to map
- std::string *SampleFile_ptr = &((*it).second.SampleFile);
- *SampleFile_ptr = "";
- return true;
+ if(it == a_concept_identification_map.end()) return false;
+
+ // Access to map
+ std::string *SampleFile_ptr = &((*it).second.SampleFile);
+ *SampleFile_ptr = "";
+ return true;
+ }
+
+ // For all concepts:
+ return enableSampleLog(id /* -1 */, "");
}
//------------------------------------------------------------------------------
-//----------------------------------------------------------- Engine::asString()
+//-------------------------------------------------- Engine::createAccumulator()
//------------------------------------------------------------------------------
-Accumulator *Engine::createAccumulator() throw() {
- Accumulator *result;
+Accumulator *Engine::createAccumulator(const std::string &name) throw(anna::RuntimeException) {
+ Accumulator *result = getAccumulator(name);
+
+ if (result)
+ throw anna::RuntimeException(anna::functions::asString("Cannot register another accumulator with the same name: %s", name.c_str()), ANNA_FILE_LOCATION);
+
+ result = new Accumulator(name);
+ a_accumulators[name] = result;
+ return result;
+}
+
+Accumulator* Engine::getAccumulator(const std::string &name) throw() {
+ Accumulator *result = NULL;
+
+ _accumulator_map_nc_it it = a_accumulators.find(name);
+ if (it != a_accumulators.end())
+ result = it->second;
- result = new Accumulator();
- a_accumulators.push_back(result);
return result;
}
}
trace += "\n";
+
+ // Accumulators:
+ trace += "\nNumber of accumulators= "; trace += anna::functions::asString(a_accumulators.size());
+ for (_accumulator_map_it it = a_accumulators.begin(); it != a_accumulators.end(); it++) {
+ trace += "\n";
+ trace += it->second->asString();
+ }
+
return (trace);
}
}
// Accumulators:
- for (_accumulator_vector_it it = a_accumulators.begin(); it != a_accumulators.end(); it++) {
- anna::xml::Node* accumulators = result->createChild("anna.statistics.Accumulators");
- (*it)->asXML(accumulators);
- }
+ anna::xml::Node* accumulators = result->createChild("anna.statistics.Accumulators");
+ accumulators->createAttribute("RegisteredAccumulators", a_accumulators.size());
+ for (_accumulator_map_it it = a_accumulators.begin(); it != a_accumulators.end(); it++)
+ it->second->asXML(accumulators);
return result;
}