2 #include <TGraphErrors.h>
19 , m_delete_out_time_hit(false)
20 , m_manual_map_selection(false)
35 if (m_cal_xt )
delete m_cal_xt ;
40 if (! m_skip_calib && m_manual_map_selection) {
52 m_vec_hit = findNode::getClass<SQHitVector>(topNode,
"SQHitVector");
56 if (
Verbosity() > 0) cout <<
Name() <<
": Skip the calibration." << endl;
60 if (! m_manual_map_selection) {
67 SQParamDeco* param_deco = findNode::getClass<SQParamDeco>(topNode,
"SQParamDeco");
78 if (
Verbosity() > 0) cout <<
Name() <<
": Set the plane resolution.\n";
84 if (name.substr(0, 2) ==
"D0" ) reso = m_reso_d0;
85 else if (name.substr(0, 2) ==
"D1" ) reso = m_reso_d1;
86 else if (name.substr(0, 2) ==
"D2" ) reso = m_reso_d2;
87 else if (name.substr(0, 3) ==
"D3p") reso = m_reso_d3p;
88 else if (name.substr(0, 3) ==
"D3m") reso = m_reso_d3m;
91 if (
Verbosity() > 0) cout <<
" " << setw(2) << ii <<
":" << setw(5) << name <<
" = " << reso << endl;
102 map<int, int> list_n_hit_in;
103 map<int, int> list_n_hit_out;
114 if (! m_skip_calib) {
117 cerr <<
" WARNING: Cannot find the in-time parameter for det=" << det <<
" in CalibDriftDist.\n";
122 float drift_dist = xt->
t2x.Eval(tdc_time);
123 if (drift_dist < 0) drift_dist = 0;
125 hit->
set_in_time( xt->
T1 <= tdc_time && tdc_time <= xt->T0 );
131 if (m_delete_out_time_hit) {
133 it = m_vec_hit->
erase(it);
136 if (
Verbosity() > 1) list_n_hit_out[det]++;
138 if (
Verbosity() > 1) list_n_hit_in[det]++;
143 if (
Verbosity() > 1 && m_delete_out_time_hit) {
144 cout <<
Name() <<
": ";
145 for (
auto it = list_n_hit_in.begin(); it != list_n_hit_in.end(); it++) {
146 cout <<
" " << it->first <<
":" << it->second <<
"->" << list_n_hit_out[it->first];
164 m_reso_d0 = reso_d0 ;
165 m_reso_d1 = reso_d1 ;
166 m_reso_d2 = reso_d2 ;
167 m_reso_d3p = reso_d3p;
168 m_reso_d3m = reso_d3m;
173 m_manual_map_selection =
true;
174 m_fn_xt = fn_xt_curve;
int End(PHCompositeNode *topNode)
Called at the end of all processing.
virtual ~CalibDriftDist()
CalibDriftDist(const std::string &name="CalibDriftDist")
void SetResolution(const double reso_d0, const double reso_d1, const double reso_d2, const double reso_d3p, const double reso_d3m)
Set the plane resolutions in cm.
int InitRun(PHCompositeNode *topNode)
int process_event(PHCompositeNode *topNode)
int Init(PHCompositeNode *topNode)
void ReadParamFromFile(const char *fn_xt_curve)
Calibration parameter for chamber X-T relation.
Set * GetParam(const short det)
Return a set of parameters for det. Return 0 if det is invalid.
virtual const std::string Name() const
Returns the name of this module.
virtual int Verbosity() const
Gets the verbosity of this module.
User interface class about the geometry of detector planes.
bool isPropTube(const int detectorID) const
Return "true" for prop tube planes.
static GeomSvc * instance()
singlton instance
Plane * getPlanePtr(int detectorID)
void getMeasurement(int detectorID, int elementID, double &measurement, double &dmeasurement)
Convert the detectorID and elementID to the actual hit position.
bool isChamber(const int detectorID) const
Return "true" for chamber planes.
virtual int get_IntFlag(const std::string &name) const
void SetMapID(const std::string map_id)
void SetMapIDbyDB(const std::string map_id)
void ReadFromLocalFile(const std::string fn_tsv)
virtual size_t erase(const size_t idkey)=0
virtual ConstIter end() const =0
virtual ConstIter begin() const =0
std::vector< SQHit * >::iterator Iter
An SQ interface class to hold one detector hit.
virtual bool is_in_time() const
Return 'true' if this hit is in the time window.
virtual void set_pos(const float a)
virtual short get_element_id() const
Return the element ID of this hit.
virtual float get_tdc_time() const
Return the TDC time (nsec) of this hit.
virtual void set_drift_distance(const float a)
virtual short get_detector_id() const
Return the detector ID of this hit.
virtual void set_in_time(const bool a)
virtual void set_variable(const std::string name, const std::string value)=0
static recoConsts * instance()
virtual void set_CharFlag(const std::string &name, const std::string &flag)
overide the virtual function to expand the environmental variables
A set of parameters for one detector (plane).