// File: DTOFHit_factory_MC.cc // Created: Thu Aug 9 11:56:15 EDT 2007 // Creator: B. Zihlmann // comment: DTOFHit_factory_MC.cc replaces DTOFMCHit_factory.cc using the TAG "MC" // the DTOFHit.h data structure will be the same for real data and MC data // #include "DTOFHit_factory_MC.h" #include "DTOFMCResponse.h" #include //------------------ // evnt //------------------ jerror_t DTOFHit_factory_MC::evnt(JEventLoop *eventLoop, int eventnumber) { vector mcresponses; eventLoop->Get(mcresponses); for (unsigned int i = 0; i < mcresponses.size(); i++){ const DTOFMCResponse *mcresponse = mcresponses[i]; DTOFHit *hit = new DTOFHit; // calculate meantime and time difference of MC data if (mcresponse->TDC_north>0 && mcresponse->TDC_south>0){ hit->id = mcresponse->id; hit->orientation = mcresponse->orientation; hit->bar = mcresponse->bar; float tn = float(mcresponse->TDC_north)*TDC_RES_MC; float ts = float(mcresponse->TDC_south)*TDC_RES_MC; float en = float(mcresponse->ADC_north); float es = float(mcresponse->ADC_south); // mean time float tm = (tn+ts)/2.; // time difference south-north so positive values are hits closer to north float td = (ts-tn); // position float pos = C_EFFECTIVE*td/2.; hit->t_north = tn; hit->t_south = ts; hit->meantime = tm; hit->timediff = td; hit->pos = pos; hit->dpos = TOF_POS_RES; // see above only true if hit seen o both sides // mean energy deposition at the location of the hit position // devide by two to be comparable with single PMT hits en *= exp((HALFPADDLE-pos)/ATTEN_LENGTH) ; es *= exp((HALFPADDLE+pos)/ATTEN_LENGTH) ; hit->E_north = en; hit->E_south = es; float emean = (en+es)/2.; if (emean>2048) emean = 2048; // overflow emean = emean*TOF_ADC_TO_E; hit->dE = emean; } else { float tn = float(mcresponse->TDC_north)*TDC_RES_MC; float ts = float(mcresponse->TDC_south)*TDC_RES_MC; float en = float(mcresponse->ADC_north); float es = float(mcresponse->ADC_south); hit->id = mcresponse->id; hit->orientation = mcresponse->orientation; hit->bar = mcresponse->bar; hit->t_north = tn; hit->E_north = en; hit->t_south = ts; hit->E_south = es; hit->meantime = -999.; hit->timediff = -999.; hit->pos = -999.; hit->dpos = -999.; hit->dE = -999.; } _data.push_back(hit); } return NOERROR; } //------------------ // toString //------------------ const string DTOFHit_factory_MC::toString(void) { // Ensure our Get method has been called so _data is up to date Get(); if(_data.size()<=0)return string(); // don't print anything if we have no data! printheader( "id: orientation: pos[cm]: epos[cm]: dE [MeV]: meantime [ns]: timediff [ns]:" ); for(unsigned int i=0; i<_data.size(); i++){ DTOFHit *tofhit = _data[i]; printnewrow(); printcol("%d", tofhit->id ); printcol("%d", tofhit->orientation ); printcol("%2.3f", tofhit->t_north ); printcol("%2.3f", tofhit->E_north ); printcol("%2.3f", tofhit->t_south ); printcol("%2.3f", tofhit->E_south ); printcol("%2.3f", tofhit->pos ); printcol("%2.3f", tofhit->dpos ); printcol("%1.3f", tofhit->dE ); printcol("%1.3f", tofhit->meantime ); printcol("%1.3f", tofhit->timediff ); printrow(); } return _table; } //------------------ // brun //------------------ jerror_t DTOFHit_factory_MC::brun(JEventLoop *loop, int eventnumber) { map tofparms; if ( !loop->GetCalib("TOF/tof_parms", tofparms)){ cout<<"DTOFHit_factory_MC: loading values from TOF data base"<