#ifndef _DTPOLHit_factory_ #define _DTPOLHit_factory_ #include #include "TTAB/DTranslationTable.h" #include "DTPOLHit.h" class DTPOLHit_factory:public jana::JFactory{ public: DTPOLHit_factory(){}; ~DTPOLHit_factory(){}; // overall scale factors double a_scale; double t_scale; double t_base; // calibration constants stored by channel vector a_gains; vector a_pedestals; vector adc_time_offsets; double HIT_TIME_WINDOW; double ADC_THRESHOLD; // detector geometry (mm, degrees) // "JUNCTION" refers to ring side, "OHMIC" refers to sector side static const int NSECTORS = 32; static const int NRINGS = 24; static const int INNER_RADIUS = 22 / 2; // From "ACTIVE INNER DIAMETER" in catalog static const int OUTER_RADIUS = 70 / 2; // From "ACTIVE OUTER DIAMETER" in catalog static const double SECTOR_DIVISION = 360. / NSECTORS; static const double RING_DIVISION = (OUTER_RADIUS - INNER_RADIUS) / DTPOLRingDigiHit::NRINGS; // 1mm, agrees with "JUNCTION ELEMENT SEPARATION" in catalog DTPOLHit* FindMatch(int sector, double T); const double GetConstant(const vector &the_table, const int in_sector) const; const double GetConstant(const vector &the_table, const DSCDigiHit *the_digihit) const; const double GetConstant(const vector &the_table, const DTPOLHit *the_hit) const; private: jerror_t init(void); // Called once at program start. jerror_t brun(jana::JEventLoop *eventLoop, int runnumber); // Called everytime a new run number is detected. jerror_t evnt(jana::JEventLoop *eventLoop, int eventnumber); // Called every event. jerror_t erun(void); // Called everytime run number changes, provided brun has been called. jerror_t fini(void); // Called after last event of last event source has been processed. }; #endif // _DTPOLHit_factory_