// $Id$ // // File: DCDCHit_factory.h // Created: Tue Aug 6 11:29:56 EDT 2013 // Creator: davidl (on Darwin harriet.jlab.org 11.4.2 i386) // #ifndef _DCDCHit_factory_ #define _DCDCHit_factory_ #include using namespace std; #include #include "HDGEOMETRY/DGeometry.h" #include "TTab/DTranslationTable.h" #include "DCDCHit.h" // store constants indexed by ring/straw number typedef vector< vector > cdc_digi_constants_t; class DCDCHit_factory:public jana::JFactory{ public: DCDCHit_factory(){}; ~DCDCHit_factory(){}; // overall scale factors. double a_scale; double t_scale; double t_min; // calibration constant tables cdc_digi_constants_t gains; cdc_digi_constants_t pedestals; cdc_digi_constants_t time_offsets; const double GetConstant(const cdc_digi_constants_t &the_table, const int in_ring, const int in_straw) const; const double GetConstant(const cdc_digi_constants_t &the_table, const DCDCDigiHit *the_digihit) const; const double GetConstant(const cdc_digi_constants_t &the_table, const DCDCHit *the_hit) const; //const double GetConstant(const cdc_digi_constants_t &the_table, // const DTranslationTable *ttab, // const int in_rocid, const int in_slot, const int in_channel) 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. void CalcNstraws(jana::JEventLoop *eventLoop, int runnumber, vector &Nstraws); void FillCalibTable(vector< vector > &table, vector &raw_table, vector &Nstraws); // Geometry information unsigned int maxChannels; unsigned int Nrings; // number of rings (layers) vector Nstraws; // number of straws for each ring }; #endif // _DCDCHit_factory_