Project
Loading...
Searching...
No Matches
CalibdEdxContainer.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
15
16#ifndef ALICEO2_TPC_CALIBDEDXCONTAINER_H_
17#define ALICEO2_TPC_CALIBDEDXCONTAINER_H_
18
19#include "GPUCommonRtypes.h"
20#include "GPUCommonDef.h"
21#include "GPUCommonMath.h"
25#include "FlatObject.h"
26#include "TPCPadGainCalib.h"
27#include "TPCPadBitMap.h"
28
29#ifndef GPUCA_ALIGPUCODE
30#include <string_view>
31#endif
32
33namespace o2::tpc
34{
35
37enum class CalibsdEdx : uint16_t {
38 CalTopologySpline = 1 << 0,
39 CalTopologyPol = 1 << 1,
40 CalThresholdMap = 1 << 2,
41 CalGainMap = 1 << 3,
42 CalResidualGainMap = 1 << 4,
43 CalTimeGain = 1 << 5,
44};
45
46inline CalibsdEdx operator|(CalibsdEdx a, CalibsdEdx b) { return static_cast<CalibsdEdx>(static_cast<int32_t>(a) | static_cast<int32_t>(b)); }
47
48inline CalibsdEdx operator&(CalibsdEdx a, CalibsdEdx b) { return static_cast<CalibsdEdx>(static_cast<int32_t>(a) & static_cast<int32_t>(b)); }
49
50inline CalibsdEdx operator~(CalibsdEdx a) { return static_cast<CalibsdEdx>(~static_cast<int32_t>(a)); }
51
60{
61 public:
63#ifndef GPUCA_GPUCODE
64 CalibdEdxContainer() = default;
65#endif
66
69
72
75
86 GPUd() float getTopologyCorrection(const int32_t region, const ChargeType chargeT, const float tanTheta, const float sinPhi, const float z, const float relPad, const float relTime, const float threshold, const float charge) const
87 {
88 return mCalibTrackTopologyPol ? mCalibTrackTopologyPol->getCorrection(region, chargeT, tanTheta, sinPhi, z, relPad, relTime, threshold, charge) : (mCalibTrackTopologySpline ? mCalibTrackTopologySpline->getCorrection(region, chargeT, tanTheta, sinPhi, z) : getDefaultTopologyCorrection(tanTheta, sinPhi));
89 }
90
95 GPUd() float getTopologyCorrection(const int32_t region, const ChargeType chargeT, float x[]) const
96 {
97 return mCalibTrackTopologyPol ? mCalibTrackTopologyPol->getCorrection(region, chargeT, x) : (mCalibTrackTopologySpline ? mCalibTrackTopologySpline->getCorrection(region, chargeT, x) : getDefaultTopologyCorrection(x[0], x[1]));
98 }
99
102 GPUd() float getDefaultTopologyCorrection(const float tanTheta, const float sinPhi) const { return gpu::CAMath::Sqrt(tanTheta * tanTheta + 1 / (1 - sinPhi * sinPhi)); }
103
104#if !defined(GPUCA_GPUCODE)
106 float getMinZeroSupresssionThreshold() const;
107
109 float getMaxZeroSupresssionThreshold() const;
110#endif
111
115 GPUd() float getZeroSupressionThreshold(const int32_t sector, const gpu::tpccf::Row row, const gpu::tpccf::Pad pad) const { return mThresholdMap.getGainCorrection(sector, row, pad); }
116
120 GPUd() float getGain(const int32_t sector, const gpu::tpccf::Row row, const gpu::tpccf::Pad pad) const { return mGainMap.getGainCorrection(sector, row, pad); }
121
125 GPUd() float getResidualGain(const int32_t sector, const gpu::tpccf::Row row, const gpu::tpccf::Pad pad) const { return mGainMapResidual.getGainCorrection(sector, row, pad); }
126
130 GPUd() bool isDead(const int32_t sector, const gpu::tpccf::Row row, const gpu::tpccf::Pad pad) const { return mDeadChannelMap.isSet(sector, row, pad); }
131
137 GPUd() float getResidualCorrection(const StackID& stack, const ChargeType charge, const float tgl = 0, const float snp = 0) const { return mCalibResidualdEdx.getCorrection(stack, charge, tgl, snp); }
138
140 GPUd() bool isUsageOfFullGainMap() const { return mApplyFullGainMap; }
141
143#if !defined(GPUCA_GPUCODE)
145 void cloneFromObject(const CalibdEdxContainer& obj, char* newFlatBufferPtr);
146
149 void moveBufferTo(char* newBufferPtr);
150#endif
151
153 void destroy();
154
156 void setActualBufferAddress(char* actualFlatBufferPtr);
157
159 void setFutureBufferAddress(char* futureFlatBufferPtr);
161
162#if !defined(GPUCA_GPUCODE) && !defined(GPUCA_STANDALONE)
163 // loading the polynomial track topology correction from a file
165 void loadPolTopologyCorrectionFromFile(std::string_view fileName);
166
167 // loading the spline track topology correction from a file
169 void loadSplineTopologyCorrectionFromFile(std::string_view fileName);
170
173 void setPolTopologyCorrection(const CalibdEdxTrackTopologyPol& calibTrackTopology);
174
177
180 void setSplineTopologyCorrection(const CalibdEdxTrackTopologySpline& calibTrackTopology);
181
182 // loading the residual dE/dx correction from a file
184 void loadResidualCorrectionFromFile(std::string_view fileName) { mCalibResidualdEdx.loadFromFile(fileName); }
185
188 void setResidualCorrection(const CalibdEdxCorrection& residualCorr) { mCalibResidualdEdx = residualCorr; }
189
190 // loading the zero supression threshold map from a file
192 void loadZeroSupresssionThresholdFromFile(std::string_view fileName, std::string_view objName, const float minCorrectionFactor, const float maxCorrectionFactor);
193
197
200 void setZeroSupresssionThreshold(const CalDet<float>& thresholdMap, const float minCorrectionFactor, const float maxCorrectionFactor);
201
203 void setDeadChannelMap(const CalDet<bool>& deadMap);
204
206 void setGainMap(const CalDet<float>& gainMap, const float minGain, const float maxGain);
207
209 void setGainMapResidual(const CalDet<float>& gainMapResidual, const float minResidualGain = 0.7f, const float maxResidualGain = 1.3f);
210
214
216 bool isTopologyCorrectionSplinesSet() const { return mCalibTrackTopologySpline ? true : false; }
217
219 bool isTopologyCorrectionPolynomialsSet() const { return mCalibTrackTopologyPol ? true : false; }
220
223 void setCorrectionCCDB(const CalibsdEdx calib) { mCalibsLoad = calib | mCalibsLoad; }
224
227 void disableCorrectionCCDB(const CalibsdEdx calib) { mCalibsLoad = ~calib & mCalibsLoad; }
228
231 bool isCorrectionCCDB(const CalibsdEdx calib) const { return ((mCalibsLoad & calib) == calib) ? true : false; }
232
234 void setUsageOfFullGainMap(const bool applyFullGainMap) { mApplyFullGainMap = applyFullGainMap; }
235#endif // !GPUCA_GPUCODE
236
237 private:
238 CalibdEdxTrackTopologySpline* mCalibTrackTopologySpline{nullptr};
239 CalibdEdxTrackTopologyPol* mCalibTrackTopologyPol{nullptr};
240 o2::gpu::TPCPadGainCalib mThresholdMap{};
241 o2::gpu::TPCPadGainCalib mGainMap{};
242 o2::gpu::TPCPadGainCalib mGainMapResidual{};
243 o2::gpu::TPCPadBitMap mDeadChannelMap{};
244 CalibdEdxCorrection mCalibResidualdEdx{};
245 bool mApplyFullGainMap{false};
246
249
250#if !defined(GPUCA_GPUCODE)
251 template <class Type>
252 std::size_t sizeOfCalibdEdxTrackTopologyObj() const
253 {
254 return alignSize(sizeof(Type), FlatObject::getClassAlignmentBytes());
255 }
256
257 template <class Type>
258 void loadTopologyCorrectionFromFile(std::string_view fileName, Type*& obj);
259
260 template <class Type>
261 void setTopologyCorrection(const Type& calibTrackTopologyTmp, Type*& obj);
262#endif
263
264 template <class Type>
265 void setActualBufferAddress(Type*& obj);
266
267 template <class Type>
268 void setFutureBufferAddress(Type*& obj, char* futureFlatBufferPtr);
269
270#if !defined(GPUCA_GPUCODE)
271 template <class Type>
272 void subobjectCloneFromObject(Type*& obj, const Type* objOld);
273
280 CalDet<float> processThresholdMap(const CalDet<float>& thresholdMap, const float maxThreshold, const int32_t nPadsInRowCl = 2, const int32_t nPadsInPadCl = 2) const;
281#endif
282
283 ClassDefNV(CalibdEdxContainer, 2);
284};
285
286} // namespace o2::tpc
287
288#endif
Definition of FlatObject class.
uint32_t stack
Definition RawData.h:1
GPUCA_GPUCODE.
Definition FlatObject.h:176
static size_t alignSize(size_t sizeBytes, size_t alignmentBytes)
_______________ Generic utilities _______________________________________________
Definition FlatObject.h:277
void cloneFromObject(const FlatObject &obj, char *newFlatBufferPtr)
Definition FlatObject.h:373
static constexpr size_t getClassAlignmentBytes()
_____________ Memory alignment __________________________
Definition FlatObject.h:194
CalibdEdxContainer(const CalibdEdxContainer &)=delete
Copy constructor: disabled to avoid ambiguity. Use cloneFromObject() instead.
void disableCorrectionCCDB(const CalibsdEdx calib)
void loadSplineTopologyCorrectionFromFile(std::string_view fileName)
void setGainMap(const CalDet< float > &gainMap, const float minGain, const float maxGain)
setting the gain map map from a CalDet
void loadPolTopologyCorrectionFromFile(std::string_view fileName)
================================================================================================
const ChargeType const float const float const float const float relPad
const ChargeType const float tanTheta
void setPolTopologyCorrection(const CalibdEdxTrackTopologyPol &calibTrackTopology)
GPUd() bool isDead(const int32_t sector
const ChargeType const float const float const float const float const float const float threshold
bool isCorrectionCCDB(const CalibsdEdx calib) const
void setActualBufferAddress(char *actualFlatBufferPtr)
set location of external flat buffer
bool isTopologyCorrectionPolynomialsSet() const
returns status if the polynomials correction is set
void setSplineTopologyCorrection(const CalibdEdxTrackTopologySpline &calibTrackTopology)
void setDeadChannelMap(const CalDet< bool > &deadMap)
setting the gain map map from a CalDet
CalibdEdxContainer & operator=(const CalibdEdxContainer &)=delete
Assignment operator: disabled to avoid ambiguity. Use cloneFromObject() instead.
~CalibdEdxContainer()=default
Destructor.
void setZeroSupresssionThreshold(const CalDet< float > &thresholdMap)
const ChargeType const float const float const float const float const float const float const float charge const
void setFutureBufferAddress(char *futureFlatBufferPtr)
set future location of the flat buffer
CalibdEdxContainer()=default
Default constructor: creates an empty uninitialized object.
const ChargeType const float const float const float const float const float relTime
void setResidualCorrection(const CalibdEdxCorrection &residualCorr)
bool isTopologyCorrectionSplinesSet() const
returns status if the spline correction is set
GPUd() float getGain(const int32_t sector
const ChargeType const float tgl
void setDefaultPolTopologyCorrection()
setting a default topology correction which just returns 1
void loadResidualCorrectionFromFile(std::string_view fileName)
void moveBufferTo(char *newBufferPtr)
void setGainMapResidual(const CalDet< float > &gainMapResidual, const float minResidualGain=0.7f, const float maxResidualGain=1.3f)
setting the gain map map from a CalDet
GPUd() float getTopologyCorrection(const int32_t region
void loadZeroSupresssionThresholdFromFile(std::string_view fileName, std::string_view objName, const float minCorrectionFactor, const float maxCorrectionFactor)
void setCorrectionCCDB(const CalibsdEdx calib)
const ChargeType const float const float sinPhi
const ChargeType const float const float snp
void setUsageOfFullGainMap(const bool applyFullGainMap)
void destroy()
destroy the object (release internal flat buffer)
GPUd() float getResidualGain(const int32_t sector
void loadFromFile(std::string_view fileName, std::string_view objName="ccdb_object")
GLint GLenum GLint x
Definition glcorearb.h:403
GLboolean GLboolean GLboolean b
Definition glcorearb.h:1233
GLboolean GLboolean GLboolean GLboolean a
Definition glcorearb.h:1233
GLdouble GLdouble GLdouble z
Definition glcorearb.h:843
Global TPC definitions and constants.
Definition SimTraits.h:167
CalibsdEdx
flags to set which corrections will be loaded from the CCDB
@ CalTimeGain
flag for residual dE/dx time dependent gain correction
@ CalTopologyPol
flag for a topology correction using polynomials
@ CalResidualGainMap
flag for applying residual gain map
@ CalThresholdMap
flag for using threshold map
@ CalTopologySpline
flag for a topology correction using splines
@ CalGainMap
flag for using the gain map to get the correct cluster charge
ChargeType
Definition Defs.h:70
PadFlags operator|(PadFlags a, PadFlags b)
Definition Defs.h:115
PadFlags operator&(PadFlags a, PadFlags b)
Definition Defs.h:113
@ CalTimeGain
Gain variation over time.
PadFlags operator~(PadFlags a)
Definition Defs.h:114
GEM stack identification.
Definition Defs.h:77