15#ifndef ALICEO2_MATLAYERCYLSET_H
16#define ALICEO2_MATLAYERCYLSET_H
23#ifndef GPUCA_ALIGPUCODE
63 GPUd()
int getNLayers()
const {
return get() ? get()->mNLayers : 0; }
67 GPUd()
float getRMin()
const {
return get()->mRMin; }
68 GPUd() float getRMax()
const {
return get()->mRMax; }
69 GPUd() float getZMax()
const {
return get()->mZMax; }
70 GPUd() float getRMin2()
const {
return get()->mRMin2; }
71 GPUd() float getRMax2()
const {
return get()->mRMax2; }
73#ifndef GPUCA_ALIGPUCODE
75 void addLayer(
float rmin,
float rmax,
float zmax,
float dz,
float drphi);
79 void dumpToTree(
const std::string& outName =
"matbudTree.root")
const;
80 void writeToFile(
const std::string& outFName =
"matbud.root");
95#ifndef GPUCA_ALIGPUCODE
99 return getMatBudget(point0.X(), point0.Y(), point0.Z(), point1.X(), point1.Y(), point1.Z());
121 void fixPointers(
char* oldPtr,
char* newPtr,
bool newPtrValid =
true);
Definition of FlatObject class.
Declarations for single cylindrical material layer class.
void setActualBufferAddress(char *actualFlatBufferPtr)
static constexpr size_t getBufferAlignmentBytes()
Gives minimal alignment in bytes required for the flat buffer.
GPUd() float getZMax() const
void addLayer(float rmin, float rmax, float zmax, float dz, float drphi)
GPUd() float getRMax() const
void optimizePhiSlices(float maxRelDiff=0.05)
void cloneFromObject(const MatLayerCylSet &obj, char *newFlatBufferPtr)
MatLayerCyl & getLayer(int i)
MatLayerCylSet(const MatLayerCylSet &src)=delete
MatBudget getMatBudget(const math_utils::Point3D< float > &point0, const math_utils::Point3D< float > &point1) const
void finalizeStructures()
static MatLayerCylSet * loadFromFile(const std::string &inpFName="matbud.root")
static constexpr float VoxelRDelta
uint16_t mLayerVoxelLU[2 *NumVoxels]
static constexpr int NumVoxels
GPUd() const MatLayerCylSetLayout *get() const
void populateFromTGeo(int ntrPerCel=10)
bool mInitializedLayerVoxelLU
helper structure to lookup a layer based on known radius (static dimension for easy copy to GPU)
~MatLayerCylSet()=default
static constexpr size_t getClassAlignmentBytes()
Gives minimal alignment in bytes required for the class object.
void moveBufferTo(char *newFlatBufferPtr)
MatLayerCylSet * extractCopy(float rmin, float rmax, float tol=1e-3) const
GPUd() float getRMin2() const
std::size_t estimateFlatBufferSize() const
GPUCA_ALIGPUCODE.
ClassDefNV(MatLayerCylSet, 1)
if the voxels have been initialized
static constexpr float InvVoxelRDelta
void dumpToTree(const std::string &outName="matbudTree.root") const
GPUd() MatLayerCylSetLayout *get()
static MatLayerCylSet * rectifyPtrFromFile(MatLayerCylSet *ptr)
GPUd() const MatLayerCyl &getLayer(int i) const
void setFutureBufferAddress(char *futureFlatBufferPtr)
static constexpr float LayerRMax
GPUd() float getRMax2() const
void fixPointers(char *newPtr=nullptr)
void writeToFile(const std::string &outFName="matbud.root")
GPUd() int getNLayers() const
char * releaseInternalBuffer()
_____________ Methods for making the data buffer external __________________________
void adoptInternalBuffer(char *buf)
GLuint GLfloat GLfloat GLfloat GLfloat y1
GLuint GLfloat GLfloat GLfloat x1
GLuint GLfloat GLfloat y0
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
int mNRIntervals
number of R interval boundaries (gaps are possible)
float mRMax2
precalculater rmax^2
int mNLayers
number of layers
float mRMin2
precalculater rmin^2