00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00092
00093
00094
00096
00097 #include <Stiostream.h>
00098 #include <TBrowser.h>
00099 #include "StEpcMaker.h"
00100 #include "StPointCollection.h"
00101 #include "StEvent.h"
00102 #include "StEventTypes.h"
00103
00104 ClassImp(StEpcMaker)
00105
00106
00107 StEpcMaker::StEpcMaker(const char *name):StMaker(name)
00108 {
00109 mPoint = 0;
00110 for(int i=0;i<4;i++)
00111 {
00112 m_point_energy[i] = 0;
00113 m_point_eta[i] = 0;
00114 m_point_phi[i] = 0;
00115 m_point_sigeta[i] = 0;
00116 m_point_sigphi[i] = 0;
00117 m_point_trmom[i] = 0;
00118 m_emc_points[i] = 0;
00119 }
00120 m_point_flag = 0;
00121 mFillHisto = kTRUE;
00122 }
00123
00124 StEpcMaker::~StEpcMaker()
00125 {}
00126
00127 Int_t StEpcMaker::Init()
00128 {
00129
00130 m_point_flag= new TH1F(" Point_Flag "," Point Flag ",5,0.5,5.5);
00131 m_point_quality= new TH1F(" Point_Quality "," Point Quality distribution ",32,-0.5,31.5);
00132
00133 const TString catname[] =
00134 { "Cat1", "Cat2", "Cat3", "Cat4"
00135 };
00136
00137 for (Int_t i=0; i<4; i++)
00138 {
00139 TString name_e = catname[i] + "_Point_Energy";
00140 TString tit_e = catname[i] + " Point Energy";
00141 m_point_energy[i]= new TH1F(name_e,tit_e,150,0.,15.);
00142
00143 TString name_eta = catname[i] + "_Point_Eta";
00144 TString tit_eta = catname[i] + " Point Eta";
00145 m_point_eta[i]= new TH1F(name_eta,tit_eta,100,-1.,1.);
00146
00147 TString name_phi = catname[i] + "_Point_Phi";
00148 TString tit_phi = catname[i] + " Point Phi";
00149 m_point_phi[i]= new TH1F(name_phi,tit_phi,100,-3.14,3.14);
00150 if (mFillHisto)
00151 {
00152 TString name_sigeta = catname[i] + "_Sigma_Eta";
00153 TString tit_sigeta = catname[i] + " Sigma Eta";
00154 m_point_sigeta[i]= new TH1F(name_sigeta,tit_sigeta,100,0.,.2);
00155
00156 TString name_sigphi = catname[i] + "_Sigma_Phi";
00157 TString tit_sigphi = catname[i] + " Sigma Phi";
00158 m_point_sigphi[i]= new TH1F(name_sigphi,tit_sigphi,100,0.,.2);
00159
00160 TString name_points = catname[i] + "_Points_Multiplicity";
00161 TString tit_points = catname[i] + " Points Multiplicity";
00162 m_emc_points[i]= new TH1F(name_points,tit_points,200,0.,200.);
00163
00164 TString name_mom = catname[i] + "_Track_Momenta";
00165 TString tit_mom = catname[i] + " Track Momenta ";
00166 m_point_trmom[i]= new TH1F(name_mom,tit_mom,150,0.,15.);
00167 }
00168 }
00169 return StMaker::Init();
00170 }
00171
00172 Int_t StEpcMaker::Make()
00173 {
00174 mEvent = (StEvent *) GetInputDS("StEvent");
00175
00176 if (!mEvent)
00177 {
00178 LOG_ERROR << "No StEvent! Can not continue. " << endm;
00179 return kStOK;
00180 }
00181 mTheEmcCollection = mEvent->emcCollection();
00182 if(!mTheEmcCollection)
00183 {
00184 LOG_ERROR <<" EPC:: No EmcCollection, Cannot continue**"<<endm;
00185 return kStOK;
00186 }
00187
00188
00189 mPoint = new StPointCollection("point");
00190 m_DataSet->Add(mPoint);
00191
00192 if(mPoint->makeEmcPoints(mEvent) != 1)
00193 {
00194 return kStOk;
00195 }
00196 else {
00197 LOG_DEBUG << "findEmcPoint == kStOK" << endm;
00198 }
00199
00200 MakeHistograms();
00201 LOG_DEBUG << "Epc: *** Filling StEvent ***" << endm;
00202 if(fillStEvent() != kStOK)
00203 {
00204 LOG_WARN << "StEvent filling is not OK"<<endm;
00205 }
00206 return kStOK;
00207 }
00208
00209
00210 void StEpcMaker::MakeHistograms()
00211 {
00212 Int_t mult[4]={0,0,0,0};
00213 if(mPoint)
00214 {
00215 Int_t nR = mPoint->NPointsReal();
00216
00217 if(nR>0)
00218 {
00219 LOG_DEBUG << "Number of Emc points " << nR << endm;
00220 TIter next(mPoint->PointsReal());
00221 StEmcPoint *cl;
00222
00223 for(Int_t i=0; i<nR; i++)
00224 {
00225 cl = (StEmcPoint*)next();
00226 if(cl)
00227 {
00228 Int_t C = 0;
00229 Int_t Q = cl->quality();
00230 if( (Q&1) )
00231 C = 1;
00232 if( (Q&1) && (Q&4))
00233 C = 2;
00234 if( (Q&1) && (Q&8))
00235 C = 3;
00236 if( (Q&1) && (Q&4) && (Q&8))
00237 C = 4;
00238 m_point_flag->Fill(C);
00239 m_point_quality->Fill(Q);
00240 if(C>0)
00241 {
00242 mult[C-1]++;
00243 if(m_point_energy[C-1])
00244 m_point_energy[C-1]->Fill(cl->energy());
00245 if(m_point_eta[C-1])
00246 m_point_eta[C-1]->Fill(cl->position().pseudoRapidity());
00247 if(m_point_phi[C-1])
00248 m_point_phi[C-1]->Fill(cl->position().phi());
00249 if(m_point_sigeta[C-1])
00250 m_point_sigeta[C-1]->Fill(cl->size().x());
00251 if(m_point_sigphi[C-1])
00252 m_point_sigphi[C-1]->Fill(cl->size().y());
00253 StPtrVecTrack& tr = cl->track();
00254 for(UInt_t j = 0;j<tr.size();j++)
00255 {
00256 StTrack* t = tr[j];
00257 if(t)
00258 {
00259 StTrackGeometry *g = t->geometry();
00260 if(m_point_trmom[C-1])
00261 m_point_trmom[C-1]->Fill(g->momentum().mag());
00262 }
00263 }
00264 }
00265 }
00266 }
00267 }
00268 }
00269 for(Int_t i = 0;i<4;i++)
00270 if(m_emc_points[i])
00271 m_emc_points[i]->Fill(mult[i]);
00272 }
00273
00274 Int_t
00275 StEpcMaker::fillStEvent()
00276 {
00277 LOG_DEBUG <<"Epc::fillStEvent() ***"<<endm;
00278
00279 if(mPoint)
00280 {
00281 Int_t nR = mPoint->NPointsReal();
00282
00283 if(nR>0)
00284 {
00285 LOG_DEBUG << "Number of Emc points " << nR << endm;
00286 TIter next(mPoint->PointsReal());
00287 StEmcPoint *cl;
00288
00289 for(Int_t i=0; i<nR; i++)
00290 {
00291 cl = (StEmcPoint*)next();
00292 mTheEmcCollection->addBarrelPoint(cl);
00293 }
00294 }
00295 }
00296 else {
00297 LOG_DEBUG << "There is no BEMC points in this event" <<endm;
00298 }
00299 return kStOK;
00300 }
00301
00302 Int_t StEpcMaker::Finish()
00303 {
00304 return kStOK;
00305 }
00306 void
00307 StEpcMaker::Browse(TBrowser* b)
00308 {
00309
00310 if(mTheEmcCollection)
00311 b->Add((TObject*)mTheEmcCollection);
00312 TDataSet::Browse(b);
00313 }