本文整理汇总了C++中Messenger::start方法的典型用法代码示例。如果您正苦于以下问题:C++ Messenger::start方法的具体用法?C++ Messenger::start怎么用?C++ Messenger::start使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Messenger
的用法示例。
在下文中一共展示了Messenger::start方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: histo
DetectorDriver::DetectorDriver() : histo(OFFSET, RANGE, "DetectorDriver") {
Messenger m;
try {
m.start("Loading Processors");
LoadProcessors(m);
} catch (GeneralException &e) {
/// Any exception in registering plots in Processors
/// and possible other exceptions in creating Processors
/// will be intercepted here
m.fail();
cout << "Exception caught at DetectorDriver::DetectorDriver" << endl;
cout << "\t" << e.what() << endl;
exit(EXIT_FAILURE);
} catch (GeneralWarning &w) {
cout << "Warning found at DetectorDriver::DetectorDriver" << endl;
cout << "\t" << w.what() << endl;
}
m.done();
}
示例2: buildTree
void TreeCorrelator::buildTree() {
pugi::xml_document doc;
Messenger m;
m.start("Creating TreeCorrelator");
pugi::xml_parse_result result = doc.load_file("Config.xml");
if (!result) {
stringstream ss;
ss << "DetectorDriver: error parsing file Config.xml";
ss << " : " << result.description();
m.fail();
throw IOException(ss.str());
}
pugi::xml_node tree = doc.child("Configuration").child("TreeCorrelator");
bool verbose = tree.attribute("verbose").as_bool(false);
Walker walker;
walker.traverseTree(tree, string(tree.attribute("name").value()), verbose);
m.done();
}
示例3: ReadWalkXml
void DetectorDriver::ReadWalkXml() {
pugi::xml_document doc;
pugi::xml_parse_result result = doc.load_file("Config.xml");
if (!result) {
stringstream ss;
ss << "DetectorDriver: error parsing file Config.xml";
ss << " : " << result.description();
throw GeneralException(ss.str());
}
Messenger m;
m.start("Loading Walk Corrections");
pugi::xml_node map = doc.child("Configuration").child("Map");
/** See comment in the similiar place at ReadCalXml() */
bool verbose = map.attribute("verbose_walk").as_bool();
for (pugi::xml_node module = map.child("Module"); module;
module = module.next_sibling("Module")) {
int module_number = module.attribute("number").as_int(-1);
for (pugi::xml_node channel = module.child("Channel"); channel;
channel = channel.next_sibling("Channel")) {
int ch_number = channel.attribute("number").as_int(-1);
Identifier chanID = DetectorLibrary::get()->at(module_number,
ch_number);
bool corrected = false;
for (pugi::xml_node walkcorr = channel.child("WalkCorrection");
walkcorr; walkcorr = walkcorr.next_sibling("WalkCorrection")) {
string model = walkcorr.attribute("model").as_string("None");
double min = walkcorr.attribute("min").as_double(0);
double max =
walkcorr.attribute("max").as_double(
numeric_limits<double>::max());
stringstream pars(walkcorr.text().as_string());
vector<double> parameters;
while (true) {
double p;
pars >> p;
if (pars)
parameters.push_back(p);
else
break;
}
if (verbose) {
stringstream ss;
ss << "Module " << module_number
<< ", channel " << ch_number << ": ";
ss << " model: " << model;
for (vector<double>::iterator it = parameters.begin();
it != parameters.end(); ++it)
ss << " " << (*it);
m.detail(ss.str(), 1);
}
walk.AddChannel(chanID, model, min, max, parameters);
corrected = true;
}
if (!corrected && verbose) {
stringstream ss;
ss << "Module " << module_number << ", channel "
<< ch_number << ": ";
ss << " not corrected for walk";
m.detail(ss.str(), 1);
}
}
}
m.done();
}
示例4: ReadCalXml
void DetectorDriver::ReadCalXml() {
pugi::xml_document doc;
pugi::xml_parse_result result = doc.load_file("Config.xml");
if (!result) {
stringstream ss;
ss << "DetectorDriver: error parsing file Config.xml";
ss << " : " << result.description();
throw GeneralException(ss.str());
}
Messenger m;
m.start("Loading Calibration");
pugi::xml_node map = doc.child("Configuration").child("Map");
/** Note that before this reading in of the xml file, it was already
* processed for the purpose of creating the channels map.
* Some sanity checks (module and channel number) were done there
* so they are not repeated here/
*/
bool verbose = map.attribute("verbose_calibration").as_bool();
for (pugi::xml_node module = map.child("Module"); module;
module = module.next_sibling("Module")) {
int module_number = module.attribute("number").as_int(-1);
for (pugi::xml_node channel = module.child("Channel"); channel;
channel = channel.next_sibling("Channel")) {
int ch_number = channel.attribute("number").as_int(-1);
Identifier chanID = DetectorLibrary::get()->at(module_number,
ch_number);
bool calibrated = false;
for (pugi::xml_node cal = channel.child("Calibration");
cal; cal = cal.next_sibling("Calibration")) {
string model = cal.attribute("model").as_string("None");
double min = cal.attribute("min").as_double(0);
double max =
cal.attribute("max").as_double(numeric_limits<double>::max());
stringstream pars(cal.text().as_string());
vector<double> parameters;
while (true) {
double p;
pars >> p;
if (pars)
parameters.push_back(p);
else
break;
}
if (verbose) {
stringstream ss;
ss << "Module " << module_number << ", channel "
<< ch_number << ": ";
ss << " model-" << model;
for (vector<double>::iterator it = parameters.begin();
it != parameters.end(); ++it)
ss << " " << (*it);
m.detail(ss.str(), 1);
}
cali.AddChannel(chanID, model, min, max, parameters);
calibrated = true;
}
if (!calibrated && verbose) {
stringstream ss;
ss << "Module " << module_number << ", channel "
<< ch_number << ": ";
ss << " non-calibrated";
m.detail(ss.str(), 1);
}
}
}
m.done();
}
示例5: GeneralException
Globals::Globals() {
clockInSeconds_ = -1;
adcClockInSeconds_ = -1;
filterClockInSeconds_ = -1;
eventInSeconds_ = -1;
energyContraction_ = 1.0;
hasReject_ = false;
revision_ = "None";
numTraces_ = 16;
try {
pugi::xml_document doc;
pugi::xml_parse_result result = doc.load_file("Config.xml");
std::stringstream ss;
if (!result) {
ss << "Globals : error parsing file " << "Config.xml";
ss << " : " << result.description();
throw GeneralException(ss.str());
}
Messenger m;
pugi::xml_node description =
doc.child("Configuration").child("Description");
std::string desc_text = description.text().get();
m.detail("Experiment: " + desc_text);
m.start("Loading global parameters");
pugi::xml_node global = doc.child("Configuration").child("Global");
for (pugi::xml_node_iterator it = global.begin();
it != global.end(); ++it) {
if (std::string(it->name()).compare("Revision") == 0) {
revision_ = it->attribute("version").as_string();
ss << "Revision: " << revision_;
m.detail(ss.str());
ss.str("");
if (revision_ == "A") {
clockInSeconds_ = 10e-9;
adcClockInSeconds_ = 10e-9;
filterClockInSeconds_ = 10e-9;
maxWords_ = IO_BUFFER_LENGTH;
} else if (revision_ == "D") {
clockInSeconds_ = 10e-9;
adcClockInSeconds_ = 10e-9;
filterClockInSeconds_ = 10e-9;
maxWords_ = EXTERNAL_FIFO_LENGTH;
} else if (revision_ == "F" || revision_ == "DF") {
clockInSeconds_ = 8e-9;
adcClockInSeconds_ = 4e-9;
filterClockInSeconds_ = 8e-9;
maxWords_ = EXTERNAL_FIFO_LENGTH;
} else {
throw GeneralException("Globals: unknown revision version "
+ revision_);
}
} else if (std::string(it->name()).compare("EventWidth") == 0) {
std::string units = it->attribute("unit").as_string("None");
double value = it->attribute("value").as_double(-1);
if (units == "ns")
value *= 1e-9;
else if (units == "us")
value *= 1e-6;
else if (units == "ms")
value *= 1e-3;
else if (units == "s")
value *= 1.0;
else
throw GeneralException("Globals: unknown units " + units);
eventInSeconds_ = value;
eventWidth_ = (int)(eventInSeconds_ / clockInSeconds_);
ss << "Event width: " << eventInSeconds_ * 1e6
<< " us" << ", i.e. " << eventWidth_
<< " pixie16 clock tics.";
m.detail(ss.str());
ss.str("");
} else if (std::string(it->name()).compare("EnergyContraction") == 0) {
energyContraction_ = it->attribute("value").as_double(1);
} else if (std::string(it->name()).compare("Path") == 0) {
configPath_ = it->text().get();
m.detail("Path to other configuration files: " + configPath_);
} else if (std::string(it->name()).compare("NumOfTraces") == 0) {
numTraces_ = it->attribute("value").as_uint();
} else
WarnOfUnknownParameter(m, it);
}
unsigned int power2 = 1;
unsigned int maxDammSize = 16384;
while (power2 < numTraces_ && power2 < maxDammSize) {
power2 *= 2;
}
ss << "Number of traces set to " << power2 << " ("
<< numTraces_ << ")";
m.detail(ss.str());
ss.str("");
//.........这里部分代码省略.........
示例6: if
extern "C" void hissub_(unsigned short *ibuf[],unsigned short *nhw)
#endif
{
static float hz = sysconf(_SC_CLK_TCK); // get the number of clock ticks per second
static clock_t clockBegin; // initialization time
static struct tms tmsBegin;
vector<ChanEvent*> eventList; // vector to hold the events
/* Pointer to singleton DetectorLibrary class */
DetectorLibrary* modChan = DetectorLibrary::get();
/* Pointer to singleton DetectorDriver class */
DetectorDriver* driver = DetectorDriver::get();
/* Screen messenger */
Messenger messenger;
stringstream ss;
// local version of ibuf pointer
word_t *lbuf;
int retval = 0; // return value from various functions
unsigned long bufLen;
/*
Various event counters
*/
unsigned long numEvents = 0;
static int counter = 0; // the number of times this function is called
static int evCount; // the number of times data is passed to ScanList
static unsigned int lastVsn; // the last vsn read from the data
time_t theTime = 0;
/*
Assign the local variable lbuf to the variable ibuf which is passed into
the routine. The difference between the new and old pixie16 readouts is
the type of the variable and source of the variable ibuf.
In the new readout ibuf is from a C++ function and is of type unsigned int*
In the old readout ibuf is from a Fortran function and is of type
unsigned short*
This results in two different assignment statements depending on
the readout.
*/
#ifdef newreadout
lbuf=(word_t *)ibuf[0];
#else
lbuf=(word_t *)ibuf; //old readout
#endif
/* Initialize the scan program before the first event */
if (counter==0) {
/* Retrieve the current time for use later to determine the total
* running time of the analysis.
*/
messenger.start("Initializing scan");
string revision = Globals::get()->revision();
// Initialize function pointer to point to
// correct version of ReadBuffData
if (revision == "D" || revision == "F")
ReadBuffData = ReadBuffDataDF;
else if (revision == "A")
ReadBuffData = ReadBuffDataA;
clockBegin = times(&tmsBegin);
ss << "First buffer at " << clockBegin << " sys time";
messenger.detail(ss.str());
ss.str("");
/* After completion the descriptions of all channels are in the modChan
* vector, the DetectorDriver and rawevent have been initialized with the
* detectors that will be used in this analysis.
*/
modChan->PrintUsedDetectors(rawev);
driver->Init(rawev);
/* Make a last check to see that everything is in order for the driver
* before processing data. SanityCheck function throws exception if
* something went wrong.
*/
try {
driver->SanityCheck();
} catch (GeneralException &e) {
messenger.fail();
cout << "Exception caught while checking DetectorDriver"
<< " sanity in PixieStd" << endl;
cout << "\t" << e.what() << endl;
exit(EXIT_FAILURE);
} catch (GeneralWarning &w) {
cout << "Warning caught during checking DetectorDriver"
<< " at PixieStd" << endl;
cout << "\t" << w.what() << endl;
}
lastVsn=-1; // set last vsn to -1 so we expect vsn 0 first
ss << "Init at " << times(&tmsBegin) << " sys time.";
//.........这里部分代码省略.........