26 #include <unordered_map>
43 double intercept(
double tx,
double ty,
double x0_track,
double y0_track)
const;
54 TVectorD
getEndPoint(
int elementID,
int sign = -1)
const;
119 TMatrixD
rotM = TMatrixD(3, 3);
176 void loadAlignment(
const std::string& alignmentFile_chamber,
const std::string& alignmentFile_hodo,
const std::string& alignmentFile_prop);
188 planes[index].
x0 = val;
194 planes[index].
y0 = val;
200 planes[index].
z0 = val;
207 return planes[index].
x0;
211 return planes[index].
y0;
215 return planes[index].
z0;
221 return map_detectorID.find(detectorName)!=map_detectorID.end() ? map_detectorID.at(detectorName) : 0;
225 return map_detectorName.find(detectorID)!=map_detectorName.end() ? map_detectorName.at(detectorID) :
"";
242 double getPlaneScaleX(
int detectorID)
const {
return planes[detectorID].
x2 - planes[detectorID].
x1; }
243 double getPlaneScaleY(
int detectorID)
const {
return planes[detectorID].
y2 - planes[detectorID].
y1; }
244 double getPlaneScaleZ(
int detectorID)
const {
return planes[detectorID].
z2 - planes[detectorID].
z1; }
263 bool isChamber(
const int detectorID)
const;
264 bool isChamber(
const std::string detectorName)
const;
265 bool isHodo(
const int detectorID)
const;
266 bool isHodo(
const std::string detectorName)
const;
268 bool isPropTube(
const std::string detectorName)
const;
269 bool isDPHodo(
const int detectorID)
const;
270 bool isDPHodo(
const std::string detectorName)
const;
271 bool isInh(
const int detectorID)
const;
272 bool isInh(
const std::string detectorName)
const;
277 int getTriggerLv(
int detectorID) {
return map_detid_triggerlv[detectorID]; }
280 double getInterception(
int detectorID,
double tx,
double ty,
double x0,
double y0)
const {
return planes[detectorID].
intercept(tx, ty, x0, y0); }
281 double getInterceptionFast(
int detectorID,
double tx,
double ty,
double x0,
double y0)
const;
282 double getInterceptionFast(
int detectorID,
double x_exp,
double y_exp)
const {
return planes[detectorID].
getW(x_exp, y_exp); }
283 double getDCA(
int detectorID,
int elementID,
double tx,
double ty,
double x0,
double y0);
286 void getMeasurement(
int detectorID,
int elementID,
double& measurement,
double& dmeasurement);
288 void getEndPoints(
int detectorID,
int elementID, TVectorD& ep1, TVectorD& ep2);
289 void getEndPoints(
int detectorID,
int elementID, TVector3& ep1, TVector3& ep2);
290 void get2DBoxSize(
int detectorID,
int elementID,
double& x_min,
double& x_max,
double& y_min,
double& y_max);
291 void getWireEndPoints(
int detectorID,
int elementID,
double& x_min,
double& x_max,
double& y_min,
double& y_max);
297 bool isInTime(
int detectorID,
double tdcTime);
306 bool isInPlane(
int detectorID,
double x,
double y);
307 bool isInElement(
int detectorID,
int elementID,
double x,
double y,
double tolr = 0.);
351 static void UseDbSvc(
const bool val) { use_dbsvc = val; }
360 bool calibration_loaded;
363 double xmin_kmag, xmax_kmag;
364 double ymin_kmag, ymax_kmag;
365 double zmin_kmag, zmax_kmag;
368 std::map<std::string, int> map_detectorID;
369 std::map<int, std::string> map_detectorName;
372 std::map<int, int> map_detid_triggerlv;
387 static bool use_dbsvc;
#define nDarkPhotonPlanes
User interface class about the geometry of detector planes.
int getTriggerLv(int detectorID)
double ELOSS_KFMAG() const
bool findPatternInDetector(int detectorID, std::string pattern)
double Z_DOWNSTREAM() const
double getDriftDistance(int detectorID, double tdcTime)
int getDetectorID(const std::string &detectorName) const
Get the plane position.
double Z_KMAG_BEND() const
Getter/setters for a set of fixed parameters - should not be changed unless absolutely necessary.
bool isInElement(int detectorID, int elementID, double x, double y, double tolr=0.)
void setDetectorZ0(const std::string detectorName, const double val)
double getPlanePosition(int detectorID) const
double ELOSS_ABSORBER() const
void Z_FMAG_BEND(const double v)
bool isPropTube(const int detectorID) const
Return "true" for prop tube planes.
bool isHodo(const int detectorID) const
Return "true" for hodo planes.
double getPlaneWOffset(int detectorID, int moduleID) const
double getDetectorY0(const std::string detectorName) const
void getWireEndPoints(int detectorID, int elementID, double &x_min, double &x_max, double &y_min, double &y_max)
double Z_UPSTREAM() const
void printAlignPar()
Debugging print of the content.
void Z_DOWNSTREAM(const double v)
double getRotationInZ(int detectorID) const
static GeomSvc * instance()
singlton instance
void toLocalDetectorName(std::string &detectorName, int &eID)
Convert the official detectorName to local detectorName.
double getPlaneZOffset(int detectorID) const
double getPlanePhiOffset(int detectorID) const
void Z_ABSORBER(const double v)
double getPlaneCenterY(int detectorID) const
static void UseDbSvc(const bool val)
void Z_ST2(const double v)
double getYinStereoPlane(int detectorID, double x, double u)
Convert the stereo hits to Y value.
void loadMilleAlignment(const std::string &alignmentFile_mille)
Plane * getPlanePtr(int detectorID)
void Z_ST1(const double v)
const Plane & getPlane(int detectorID) const
double Z_FMAG_BEND() const
TSpline3 * getRTCurve(int detectorID)
double getPlaneOverlap(int detectorID) const
void getMeasurement(int detectorID, int elementID, double &measurement, double &dmeasurement)
Convert the detectorID and elementID to the actual hit position.
void Z_KMAG_BEND(const double v)
void loadOnlineAlignment(const std::string &alignmentFile_mille)
Load parameters used in the online-alignment mode.
void getEndPoints(int detectorID, int elementID, TVectorD &ep1, TVectorD &ep2)
void setDetectorY0(const std::string detectorName, const double val)
double getPlaneCenterX(int detectorID) const
bool isInKMAG(double x, double y)
double FMAG_HOLE_LENGTH() const
bool isInh(const int detectorID) const
Return "true" for BeforeInh and AfterInh signals.
double Z_ABSORBER() const
double getPlaneCenterZ(int detectorID) const
int getPlaneType(int detectorID) const
double getDetectorZ0(const std::string detectorName) const
void setDetectorX0(const std::string detectorName, const double val)
TODO temp solution to overwrite the y0 of a plane.
void FMAG_LENGTH(const double v)
double FMAG_LENGTH() const
double getPlaneResolution(int detectorID) const
double Z_KFMAG_BEND() const
double getXinStereoPlane(int detectorID, double u, double y)
int getPlaneNElements(int detectorID) const
void FMAG_HOLE_LENGTH(const double v)
double getPlaneScaleY(int detectorID) const
void Z_TARGET(const double v)
double getPlaneScaleZ(int detectorID) const
void init()
Initialization, either from MySQL or from ascii file.
double getPlaneWOffset(int detectorID) const
double getTantheta(int detectorID) const
double getInterceptionFast(int detectorID, double x_exp, double y_exp) const
void Z_DUMP(const double v)
double getRotationInY(int detectorID) const
int getHodoStation(const int detectorID) const
Return a station number (1-4) for hodo planes or "0" for others.
double getDetectorX0(const std::string detectorName) const
double getPlaneScaleX(int detectorID) const
int getExpElementID(int detectorID, double pos_exp)
double getRotationInX(int detectorID) const
bool isInTime(int detectorID, double tdcTime)
double getInterceptionFast(int detectorID, double tx, double ty, double x0, double y0) const
double getCostheta(int detectorID) const
double getStereoAngle(int detectorID) const
void loadAlignment(const std::string &alignmentFile_chamber, const std::string &alignmentFile_hodo, const std::string &alignmentFile_prop)
void loadCalibration(const std::string &calibrateFile)
std::string getDetectorName(const int &detectorID) const
void Z_REF(const double v)
bool isChamber(const int detectorID) const
Return "true" for chamber planes.
void Z_UPSTREAM(const double v)
double getInterception(int detectorID, double tx, double ty, double x0, double y0) const
Get the interception of a line an a plane.
double getDCA(int detectorID, int elementID, double tx, double ty, double x0, double y0)
double getPlaneSpacing(int detectorID) const
double getUinStereoPlane(int detectorID, double x, double y)
bool isCalibrationLoaded()
Calibration related.
void Z_KFMAG_BEND(const double v)
Plane getPlane(int detectorID)
void FMAG_HOLE_RADIUS(const double v)
void ELOSS_KFMAG(const double v)
void Z_ST3(const double v)
bool isInPlane(int detectorID, double x, double y)
See if a point is in a plane.
void close()
Close the geometry service before exit or starting a new one.
void ELOSS_ABSORBER(const double v)
void get2DBoxSize(int detectorID, int elementID, double &x_min, double &x_max, double &y_min, double &y_max)
double getSintheta(int detectorID) const
bool isDPHodo(const int detectorID) const
Return "true" for DP hodo planes.
double FMAG_HOLE_RADIUS() const
double getCellWidth(int detectorID) const
std::vector< int > getDetectorIDs(std::string pattern)
virtual double get_DoubleFlag(const std::string &name) const
virtual void set_DoubleFlag(const std::string &name, const double flag)
std::vector< double > elementPos
double getWirePosition(int elementID) const
TVectorD getEndPoint(int elementID, int sign=-1) const
double getY(double x, double w) const
double intercept(double tx, double ty, double x0_track, double y0_track) const
double getW(double x, double y) const
double getX(double w, double y) const
friend std::ostream & operator<<(std::ostream &os, const Plane &plane)