15#ifndef ALICEO2_BASE_GEOMETRYMANAGER_H_
16#define ALICEO2_BASE_GEOMETRYMANAGER_H_
18#include <TGeoManager.h>
19#include <TGeoMaterial.h>
20#include <TGeoPhysicalNode.h>
54 static void loadGeometry(std::string_view geomFilePath =
"",
bool applyMisalignment =
false,
bool preferAlignedFile =
true);
64 static TGeoHMatrix*
getMatrix(
const char* symname);
72 return (detid << sDetOffset) | (sensid & sSensorMask);
79 static bool applyAlignment(
const std::vector<o2::detectors::AlignParam>& algPars);
80 static bool applyAlignment(
const std::vector<
const std::vector<o2::detectors::AlignParam>*> algPars);
122 static TGeoHMatrix*
getMatrix(TGeoPNEntry* pne);
123 static void accountMaterial(
const TGeoMaterial* material, MatBudgetExt& bd);
126 bd.
meanRho = material->GetDensity();
127 bd.
meanX2X0 = material->GetRadLen();
133 static Bool_t getOriginalMatrixFromPath(
const char*
path, TGeoHMatrix&
m);
137 static constexpr UInt_t sDetOffset = 15;
138 static constexpr UInt_t sSensorMask =
139 (0x1 << sDetOffset) - 1;
140 static std::mutex sTGMutex;
142 ClassDefOverride(GeometryManager, 0);
Declarations for material properties of the cell (voxel)
static o2::base::MatBudget meanMaterialBudget(const math_utils::Point3D< double > &start, const math_utils::Point3D< double > &end)
static bool isGeometryLoaded()
~GeometryManager() override=default
Default destructor.
static const char * getSymbolicName(o2::detectors::DetID detid, int sensid)
static TGeoHMatrix * getMatrix(o2::detectors::DetID detid, Int_t sensid)
static o2::base::MatBudget meanMaterialBudget(float x0, float y0, float z0, float x1, float y1, float z1)
static Bool_t getOriginalMatrix(o2::detectors::DetID detid, int sensid, TGeoHMatrix &m)
static void loadGeometry(std::string_view geomFilePath="", bool applyMisalignment=false, bool preferAlignedFile=true)
static MatBudgetExt meanMaterialBudgetExt(const math_utils::Point3D< float > &start, const math_utils::Point3D< float > &end)
static o2::base::MatBudget meanMaterialBudget(const math_utils::Point3D< float > &start, const math_utils::Point3D< float > &end)
static bool applyAlignment(const std::vector< o2::detectors::AlignParam > &algPars)
misalign geometry with alignment objects from the array, optionaly check overlaps
static MatBudgetExt meanMaterialBudgetExt(float x0, float y0, float z0, float x1, float y1, float z1)
static int getSensID(o2::detectors::DetID detid, int sensid)
static TGeoHMatrix * getMatrix(const char *symname)
static MatBudgetExt meanMaterialBudgetExt(const math_utils::Point3D< double > &start, const math_utils::Point3D< double > &end)
static TGeoPNEntry * getPNEntry(o2::detectors::DetID detid, Int_t sensid)
static void applyMisalignent(bool applyMisalignment=true)
Static class with identifiers, bitmasks and names for ALICE detectors.
GLuint GLfloat GLfloat GLfloat GLfloat y1
GLuint GLfloat GLfloat GLfloat x1
GLuint GLsizei GLsizei * length
GLsizei const GLchar *const * path
GLuint GLfloat GLfloat y0
std::string detectors(const std::vector< std::string > &det, unsigned mask)
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
MatBudgetExt(const MatBudgetExt &src)=default
MatBudgetExt & operator=(const MatBudgetExt &src)=default
void normalize(double nrm)
ClassDefNV(MatBudgetExt, 1)
float meanRho
mean density, g/cm^3
float meanX2X0
fraction of radiaton lenght