15#ifndef ALICEO2_TPC_CALIBDEDXTRACKTOPOLOGYPOL_H_
16#define ALICEO2_TPC_CALIBDEDXTRACKTOPOLOGYPOL_H_
23#ifndef GPUCA_ALIGPUCODE
30#if !defined(GPUCA_GPUCODE)
37 std::vector<gpu::NDPiecewisePolynomialContainer>
mCalibPols{};
49#if !defined(GPUCA_GPUCODE) && !defined(GPUCA_STANDALONE)
79 const float corr = (
chargeT ==
ChargeType::Tot) ? getCorrectionqTot(region,
tanTheta,
sinPhi,
z,
threshold,
charge) : getCorrectionqMax(region,
tanTheta,
sinPhi,
z,
relPad,
relTime);
93 const float corr = mScalingFactorsqTot[region] * mCalibPolsqTot[region].eval(
x);
107 const float corr = mScalingFactorsqMax[region] * mCalibPolsqMax[region].eval(
x);
113 GPUd() float getMinThreshold(
const int32_t region = 0)
const {
return mCalibPolsqTot[region].getXMin(3); };
117 GPUd() float getMaxThreshold(
const int32_t region = 0)
const {
return mCalibPolsqTot[region].getXMax(3); };
121 GPUd() float getScalingFactorqTot(
const int32_t region)
const {
return mScalingFactorsqTot[region]; };
125 GPUd() float getScalingFactorqMax(
const int32_t region)
const {
return mScalingFactorsqMax[region]; };
127#if !defined(GPUCA_GPUCODE)
130 const auto&
getPolyqTot(
const int32_t region)
const {
return mCalibPolsqTot[region]; }
134 const auto&
getPolyqMax(
const int32_t region)
const {
return mCalibPolsqMax[region]; }
136#ifndef GPUCA_STANDALONE
150 void writeToFile(TFile& outf,
const char*
name =
"CalibdEdxTrackTopologyPol")
const;
164 void dumpToTree(
const uint32_t nSamplingPoints[],
const char* outName =
"track_topology_corr_debug.root")
const;
181#if !defined(GPUCA_GPUCODE)
201 constexpr static int32_t FFits{10};
202 constexpr static int32_t FDim{5};
203 constexpr static int32_t FDegree{3};
206 float mScalingFactorsqTot[FFits]{1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
207 float mScalingFactorsqMax[FFits]{1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
209#if !defined(GPUCA_GPUCODE)
Definition of FlatObject class.
calibration class for the track topology correction of the dE/dx using multvariate polynomials
CalibdEdxTrackTopologyPol()=default
Default constructor: creates an empty uninitialized object.
CalibdEdxTrackTopologyPol(std::string_view fileName, std::string_view name="CalibdEdxTrackTopologyPol")
void loadFromFile(const char *fileName, const char *name)
static std::string getPolyName(const int32_t region, const ChargeType charge)
void dumpToTree(const uint32_t nSamplingPoints[], const char *outName="track_topology_corr_debug.root") const
GPUd() float getScalingFactorqMax(const int32_t region) const
const ChargeType const float const float const float const float const float relTime
void setDefaultPolynomials()
setting a default topology correction which just returns 1
void setScalingFactorqMax(const float factor, const int32_t region)
const ChargeType const float const float const float z
void setPolynomialsFromFile(TFile &inpf)
const ChargeType float x[] const
const ChargeType const float tanTheta
GPUd() float getScalingFactorqTot(const int32_t region) const
GPUd() float getMaxThreshold(const int32_t region=0) const
const auto & getPolyqMax(const int32_t region) const
const ChargeType const float const float const float const float const float const float threshold
void setFutureBufferAddress(char *futureFlatBufferPtr)
set future location of the flat buffer
void writeToFile(TFile &outf, const char *name="CalibdEdxTrackTopologyPol") const
~CalibdEdxTrackTopologyPol()=default
destructor
GPUd() float getCorrection(const int32_t region
void setScalingFactorqTot(const float factor, const int32_t region)
void moveBufferTo(char *newBufferPtr)
const ChargeType const float const float sinPhi
void setFromContainer(const CalibdEdxTrackTopologyPolContainer &container)
void setActualBufferAddress(char *actualFlatBufferPtr)
set location of external flat buffer
const auto & getPolyqTot(const int32_t region) const
void cloneFromObject(const CalibdEdxTrackTopologyPol &obj, char *newFlatBufferPtr)
========== FlatObject functionality, see FlatObject class for description =================
GPUd() float getMinThreshold(const int32_t region=0) const
void destroy()
destroy the object (release internal flat buffer)
const ChargeType const float const float const float const float relPad
GLuint const GLchar * name
GLdouble GLdouble GLdouble z
Global TPC definitions and constants.
simple struct to enable writing the MultivariatePolynomialCT to file
ClassDefNV(CalibdEdxTrackTopologyPolContainer, 2)
std::vector< float > mScalingFactorsqMax
value which is used to scale the result of the polynomial for qMax (can be used for normalization)
std::vector< float > mScalingFactorsqTot
value which is used to scale the result of the polynomial for qTot (can be used for normalization)
CalibdEdxTrackTopologyPolContainer()=default
default constructor
std::vector< gpu::NDPiecewisePolynomialContainer > mCalibPols
parameters of the polynomial