// $Id$ // // File: DBeamPhoton_factory_TRUTH.cc // Created: Thu Dec 3 17:27:55 EST 2009 // Creator: staylor (on Linux ifarml6 2.6.18-128.el5 x86_64) // #include #include using namespace std; #include "DBeamPhoton_factory_TRUTH.h" using namespace jana; //------------------ // init //------------------ jerror_t DBeamPhoton_factory_TRUTH::init(void) { return NOERROR; } //------------------ // brun //------------------ jerror_t DBeamPhoton_factory_TRUTH::brun(jana::JEventLoop *locEventLoop, int runnumber) { DApplication* dapp = dynamic_cast(locEventLoop->GetJApplication()); DGeometry* locGeometry = dapp->GetDGeometry(locEventLoop->GetJEvent().GetRunNumber()); dTargetCenterZ = 0.0; locGeometry->GetTargetZ(dTargetCenterZ); return NOERROR; } //------------------ // evnt //------------------ jerror_t DBeamPhoton_factory_TRUTH::evnt(jana::JEventLoop *locEventLoop, int eventnumber) { DVector3 pos(0.0, 0.0, dTargetCenterZ); vector tagm_hits; locEventLoop->Get(tagm_hits, "TRUTH"); for (unsigned int ih=0; ih < tagm_hits.size(); ++ih) { DVector3 mom(0.0, 0.0, tagm_hits[ih]->E); DBeamPhoton *gamma = new DBeamPhoton; gamma->setMomentum(mom); gamma->setPosition(pos); gamma->setCharge(0); gamma->setMass(0); gamma->setTime(tagm_hits[ih]->t); gamma->setT0(tagm_hits[ih]->t, 0.200, SYS_TAGM); gamma->setT1(0.0, 0.0, SYS_NULL); gamma->AddAssociatedObject(tagm_hits[ih]); _data.push_back(gamma); } vector tagh_hits; locEventLoop->Get(tagh_hits, "TRUTH"); for (unsigned int ih=0; ih < tagh_hits.size(); ++ih) { DVector3 mom(0.0, 0.0, tagh_hits[ih]->E); DBeamPhoton *gamma = new DBeamPhoton; gamma->setMomentum(mom); gamma->setPosition(pos); gamma->setCharge(0); gamma->setMass(0); gamma->setTime(tagh_hits[ih]->t); gamma->setT0(tagh_hits[ih]->t, 0.350, SYS_TAGH); gamma->setT1(0.0, 0.0, SYS_NULL); gamma->AddAssociatedObject(tagh_hits[ih]); _data.push_back(gamma); } return NOERROR; } //------------------ // erun //------------------ jerror_t DBeamPhoton_factory_TRUTH::erun(void) { return NOERROR; } //------------------ // fini //------------------ jerror_t DBeamPhoton_factory_TRUTH::fini(void) { return NOERROR; }