2 #include <TGraphErrors.h>
18 , m_manual_map_selection(false)
33 if (m_cal_xt )
delete m_cal_xt ;
38 if (m_manual_map_selection) {
50 m_vec_hit = findNode::getClass<SQHitVector>(topNode,
"SQHitVector");
55 if (! m_manual_map_selection) {
62 SQParamDeco* param_deco = findNode::getClass<SQParamDeco>(topNode,
"SQParamDeco");
73 if (
Verbosity() > 0) cout <<
"CalibDriftDistMod: Set the plane resolution.\n";
79 if (name.substr(0, 2) ==
"D0" ) reso = m_reso_d0;
80 else if (name.substr(0, 2) ==
"D1" ) reso = m_reso_d1;
81 else if (name.substr(0, 2) ==
"D2" ) reso = m_reso_d2;
82 else if (name.substr(0, 3) ==
"D3p") reso = m_reso_d3p;
83 else if (name.substr(0, 3) ==
"D3m") reso = m_reso_d3m;
86 if (
Verbosity() > 0) cout <<
" " << setw(2) << ii <<
":" << setw(5) << name <<
" = " << reso << endl;
104 cerr <<
" WARNING: Cannot find the in-time parameter for det=" << det <<
" in CalibDriftDistMod.\n";
109 float drift_dist = xt->
t2x.Eval(tdc_time);
110 if (drift_dist < 0) drift_dist = 0;
132 m_reso_d0 = reso_d0 ;
133 m_reso_d1 = reso_d1 ;
134 m_reso_d2 = reso_d2 ;
135 m_reso_d3p = reso_d3p;
136 m_reso_d3m = reso_d3m;
141 m_manual_map_selection =
true;
142 m_fn_xt = fn_xt_curve;
CalibDriftDistMod(const std::string &name="CalibDriftDistMod")
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 End(PHCompositeNode *topNode)
Called at the end of all processing.
int InitRun(PHCompositeNode *topNode)
int process_event(PHCompositeNode *topNode)
int Init(PHCompositeNode *topNode)
void ReadParamFromFile(const char *fn_xt_curve)
virtual ~CalibDriftDistMod()
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 ConstIter end() const =0
virtual ConstIter begin() const =0
std::vector< SQHit * >::iterator Iter
An SQ interface class to hold one detector hit.
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).