28 , m_road_map_pos_top(0)
29 , m_road_map_pos_bot(0)
30 , m_road_map_neg_top(0)
31 , m_road_map_neg_bot(0)
45 cout <<
"AnaBG::Init(): ERROR No road given. Abort." << endl;
55 m_file_out =
new TFile(oss.str().c_str(),
"RECREATE");
59 m_h1_inte =
new TH1D(
"h1_inte" ,
"", 1200, 0, 1300e3);
74 TFile* file =
new TFile(fname);
75 if (! file->IsOpen()) {
76 cout <<
"Cannot open the file, '" << fname <<
"'. Abort." << endl;
79 TTree* tree = (TTree*)file->Get(
m_tree_name.c_str());
81 cout <<
"Cannot get the tree, '" <<
m_tree_name.c_str() <<
"'. Abort." << endl;
88 for (
int i_ent = 0; i_ent < tree->GetEntries(); i_ent++) {
89 tree->GetEntry(i_ent);
114 if (inte_max == 0)
return;
123 if (h1t->size() == 0 || h1b->size() == 0 ||
124 h2t->size() == 0 || h2b->size() == 0 ||
125 h3t->size() == 0 || h3b->size() == 0 ||
126 h4t->size() == 0 || h4b->size() == 0 )
return;
161 cout <<
"AnaBG::Analyze():" << endl;
163 m_ofs <<
"Event Counts:\n"
164 <<
"N of analyzed events:\n"
168 <<
"Expected counts per spill:\n"
184 if (it->second->GetWeightBG() == 0) it->second->AddBG(1);
187 if (it->second->GetWeightBG() == 0) it->second->AddBG(1);
190 if (it->second->GetWeightBG() == 0) it->second->AddBG(1);
193 if (it->second->GetWeightBG() == 0) it->second->AddBG(1);
219 if (abs(tb) != 1)
return;
220 for (EleList::const_iterator it1 = h1->begin(); it1 != h1->end(); it1++) {
221 for (EleList::const_iterator it2 = h2->begin(); it2 != h2->end(); it2++) {
222 for (EleList::const_iterator it3 = h3->begin(); it3 != h3->end(); it3++) {
223 for (EleList::const_iterator it4 = h4->begin(); it4 != h4->end(); it4++) {
225 road_map->
AddBG(road, 1.0);
240 m_ofs <<
"NIM3 event fraction = " << frac_acc <<
" @ inte_rfp00 < " <<
m_inte_cut<<
" m_h1_inte_max->Integral(0, bin_cut): "<<
m_h1_inte_max->Integral(0, bin_cut)<<
" m_h1_inte_max->Integral(): "<<
m_h1_inte_max->Integral() << endl;
242 TCanvas* c1 =
new TCanvas(
"c1",
"");
245 gStyle->SetOptStat(0000);
253 c1->SaveAs(oss.str().c_str());
259 oss <<
m_dir_out <<
"/h1_inte_max_all.png";
260 c1->SaveAs(oss.str().c_str());
virtual void ProcessOneEvent()
void SetRoads(AnaSignal *ana_signal)
RoadMap * m_road_map_pos_bot
std::vector< int > EleList
RoadMap * m_road_map_neg_bot
RoadMap * m_road_map_neg_top
static constexpr double N_RF_PER_SPILL
N of RFs per spill.
AnaBG(const std::string label="ana_bg")
virtual void ReadEvents(const char *fname)
RoadMap * m_road_map_pos_top
void FindAllRoads(const EleList *h1, const EleList *h2, const EleList *h3, const EleList *h4, const int tb, RoadMap *road_map)
std::string m_branch_name
RoadMap * GetRoadMapPosTop()
RoadMap * GetRoadMapNegBot()
RoadMap * GetRoadMapNegTop()
RoadMap * GetRoadMapPosBot()
Class to hold a non-ordered set (i.e. map) of roads.
bool Contain(const RoadMap *map) const
RoadInfo * Find(const int road) const
void AddBG(const int road, const double weight, const int count=1)
void ScaleBG(const double val)
void ListOfRfValues(int &n_value, int *&list_values)
Make a list of QIE RF+nn values.
int Hodo2Road(const int h1, const int h2, const int h3, const int h4, const int tb)
Convert a set of hodo IDs to a roadset ID.
int inte_rfp00
In unit of QIE count.