17#ifndef O2_MCH_GEOMETRY_MIS_ALIGNER
18#define O2_MCH_GEOMETRY_MIS_ALIGNER
37 MisAligner(
double cartXMisAligM,
double cartXMisAligW,
double cartYMisAligM,
double cartYMisAligW,
double angMisAligM,
double angMisAligW);
39 MisAligner(
double cartMisAligM,
double cartMisAligW,
double angMisAligM,
double angMisAligW);
41 MisAligner(
double cartMisAligW,
double angMisAligW);
51 void misAlign(
std::vector<
o2::detectors::AlignParam>& arr,
bool verbose = false) const;
54 void setCartMisAlig(
double xmean,
double xwidth,
double ymean,
double ywidth,
double zmean = 0.,
double zwidth = 0.)
56 mDetElemMisAlig[0][0] = xmean;
57 mDetElemMisAlig[0][1] = xwidth;
58 mDetElemMisAlig[1][0] = ymean;
59 mDetElemMisAlig[1][1] = ywidth;
60 mDetElemMisAlig[2][0] = zmean;
61 mDetElemMisAlig[2][1] = zwidth;
67 mDetElemMisAlig[0][0] = mean;
68 mDetElemMisAlig[0][1] =
width;
69 mDetElemMisAlig[1][0] = mean;
70 mDetElemMisAlig[1][1] =
width;
74 void setAngMisAlig(
double zmean,
double zwidth,
double xmean = 0.,
double xwidth = 0.,
double ymean = 0.,
double ywidth = 0.)
76 mDetElemMisAlig[3][0] = xmean;
77 mDetElemMisAlig[3][1] = xwidth;
78 mDetElemMisAlig[4][0] = ymean;
79 mDetElemMisAlig[4][1] = ywidth;
80 mDetElemMisAlig[5][0] = zmean;
81 mDetElemMisAlig[5][1] = zwidth;
103 void setModuleCartMisAlig(
double xmean,
double xwidth,
double ymean,
double ywidth,
double zmean,
double zwidth)
105 mModuleMisAlig[0][0] = xmean;
106 mModuleMisAlig[0][1] = xwidth;
107 mModuleMisAlig[1][0] = ymean;
108 mModuleMisAlig[1][1] = ywidth;
109 mModuleMisAlig[2][0] = zmean;
110 mModuleMisAlig[2][1] = zwidth;
114 void setModuleAngMisAlig(
double xmean,
double xwidth,
double ymean,
double ywidth,
double zmean,
double zwidth)
116 mModuleMisAlig[3][0] = xmean;
117 mModuleMisAlig[3][1] = xwidth;
118 mModuleMisAlig[4][0] = ymean;
119 mModuleMisAlig[4][1] = ywidth;
120 mModuleMisAlig[5][0] = zmean;
121 mModuleMisAlig[5][1] = zwidth;
125 void setAlignmentResolution(
const TClonesArray* misAlignArray,
int chId = -1,
double chResX = -1.,
double chResY = -1.,
double deResX = -1.,
double deResY = -1.);
134 bool isMatrixConvertedToAngles(
const double* rot,
double& psi,
double& theta,
double& phi)
const;
136 TGeoCombiTrans misAlignDetElem()
const;
137 TGeoCombiTrans misAlignModule()
const;
138 void getUniMisAlign(
double cartMisAlig[3],
double angMisAlig[3],
const double lParMisAlig[6][2])
const;
139 void getGausMisAlign(
double cartMisAlig[3],
double angMisAlig[3],
const double lParMisAlig[6][2])
const;
143 double mDetElemMisAlig[6][2];
144 double mModuleMisAlig[6][2];
146 double mXYAngMisAligFactor;
147 double mZCartMisAligFactor;
Definition of the base alignment parameters class.
void setCartMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean=0., double zwidth=0.)
Set cartesian displacement parameters different along x, y.
void setAlignmentResolution(const TClonesArray *misAlignArray, int chId=-1, double chResX=-1., double chResY=-1., double deResX=-1., double deResY=-1.)
Set alignment resolution to misalign objects to be stored in CDB.
void setModuleAngMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean, double zwidth)
Set module (half chambers) cartesian displacement parameters.
void setModuleCartMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean, double zwidth)
Set module (half chambers) cartesian displacement parameters.
void misAlign(std::vector< o2::detectors::AlignParam > &arr, bool verbose=false) const
void setCartMisAlig(double mean, double width)
Set cartesian displacement parameters, the same along x, y.
MisAligner & operator=(const MisAligner &right)
Not implemented.
MisAligner(const MisAligner &right)
Not implemented.
void setZCartMisAligFactor(double factor)
void setAngMisAlig(double zmean, double zwidth, double xmean=0., double xwidth=0., double ymean=0., double ywidth=0.)
Set angular displacement.
~MisAligner() final=default
void setXYAngMisAligFactor(double factor)
void setUseGaus(bool usegaus)
Set option for gaussian distribution.
void setUseUni(bool useuni)
Set option for uniform distribution.
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
Defining DataPointCompositeObject explicitly as copiable.