Project
Loading...
Searching...
No Matches
MisAligner.h
Go to the documentation of this file.
1// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3// All rights not expressly granted are reserved.
4//
5// This software is distributed under the terms of the GNU General Public
6// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7//
8// In applying this license CERN does not waive the privileges and immunities
9// granted to it by virtue of its status as an Intergovernmental Organization
10// or submit itself to any jurisdiction.
11
17#ifndef O2_MCH_GEOMETRY_MIS_ALIGNER
18#define O2_MCH_GEOMETRY_MIS_ALIGNER
19
20#include "TObject.h"
22#include <vector>
23
24class TGeoCombiTrans;
25class TClonesArray;
26
27namespace o2
28{
29namespace mch
30{
31namespace geo
32{
33
34class MisAligner : public TObject
35{
36 public:
37 MisAligner(double cartXMisAligM, double cartXMisAligW, double cartYMisAligM, double cartYMisAligW, double angMisAligM, double angMisAligW);
38
39 MisAligner(double cartMisAligM, double cartMisAligW, double angMisAligM, double angMisAligW);
40
41 MisAligner(double cartMisAligW, double angMisAligW);
42
43 MisAligner();
44
45 ~MisAligner() final = default;
46
47 //_________________________________________________________________
48 // methods
49
50 // misaligns the geometry and fills an array of misalignment paramaters.
51 void misAlign(std::vector<o2::detectors::AlignParam>& arr, bool verbose = false) const;
52
54 void setCartMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean = 0., double zwidth = 0.)
55 {
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;
62 }
63
65 void setCartMisAlig(double mean, double width)
66 {
67 mDetElemMisAlig[0][0] = mean;
68 mDetElemMisAlig[0][1] = width;
69 mDetElemMisAlig[1][0] = mean;
70 mDetElemMisAlig[1][1] = width;
71 }
72
74 void setAngMisAlig(double zmean, double zwidth, double xmean = 0., double xwidth = 0., double ymean = 0., double ywidth = 0.)
75 {
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;
82 }
83
84 void setXYAngMisAligFactor(double factor);
85
86 void setZCartMisAligFactor(double factor);
87
89 void setUseGaus(bool usegaus)
90 {
91 mUseGaus = usegaus;
92 mUseUni = !usegaus;
93 }
94
96 void setUseUni(bool useuni)
97 {
98 mUseGaus = !useuni;
99 mUseUni = useuni;
100 }
101
103 void setModuleCartMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean, double zwidth)
104 {
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;
111 }
112
114 void setModuleAngMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean, double zwidth)
115 {
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;
122 }
123
125 void setAlignmentResolution(const TClonesArray* misAlignArray, int chId = -1, double chResX = -1., double chResY = -1., double deResX = -1., double deResY = -1.);
126
127 protected:
132
133 private:
134 bool isMatrixConvertedToAngles(const double* rot, double& psi, double& theta, double& phi) const;
135 // return a misaligned transformation
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;
140
141 bool mUseUni;
142 bool mUseGaus;
143 double mDetElemMisAlig[6][2];
144 double mModuleMisAlig[6][2];
145
146 double mXYAngMisAligFactor;
147 double mZCartMisAligFactor;
148
149 ClassDef(MisAligner, 1);
150};
151
152} // namespace geo
153} // namespace mch
154} // namespace o2
155#endif // GEOMETRY_MIS_ALIGNER_H
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.
Definition MisAligner.h:54
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.
Definition MisAligner.h:114
void setModuleCartMisAlig(double xmean, double xwidth, double ymean, double ywidth, double zmean, double zwidth)
Set module (half chambers) cartesian displacement parameters.
Definition MisAligner.h:103
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.
Definition MisAligner.h:65
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.
Definition MisAligner.h:74
~MisAligner() final=default
void setXYAngMisAligFactor(double factor)
void setUseGaus(bool usegaus)
Set option for gaussian distribution.
Definition MisAligner.h:89
void setUseUni(bool useuni)
Set option for uniform distribution.
Definition MisAligner.h:96
GLdouble GLdouble right
Definition glcorearb.h:4077
GLint GLsizei width
Definition glcorearb.h:270
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
Defining DataPointCompositeObject explicitly as copiable.