14#include <TGeoManager.h>
15#include <TGeoMatrix.h>
18#include <fairlogger/Logger.h>
23#include <boost/algorithm/string/predicate.hpp>
31 : mGeoName(geo.mGeoName),
32 mKey110DEG(geo.mKey110DEG),
33 mnSupModInDCAL(geo.mnSupModInDCAL),
34 mNCellsInSupMod(geo.mNCellsInSupMod),
35 mNETAdiv(geo.mNETAdiv),
36 mNPHIdiv(geo.mNPHIdiv),
37 mNCellsInModule(geo.mNCellsInModule),
38 mPhiBoundariesOfSM(geo.mPhiBoundariesOfSM),
39 mPhiCentersOfSM(geo.mPhiCentersOfSM),
40 mPhiCentersOfSMSec(geo.mPhiCentersOfSMSec),
41 mPhiCentersOfCells(geo.mPhiCentersOfCells),
42 mCentersOfCellsEtaDir(geo.mCentersOfCellsEtaDir),
43 mCentersOfCellsPhiDir(geo.mCentersOfCellsPhiDir),
44 mEtaCentersOfCells(geo.mEtaCentersOfCells),
47 mCentersOfCellsXDir(geo.mCentersOfCellsXDir),
48 mArm1EtaMin(geo.mArm1EtaMin),
49 mArm1EtaMax(geo.mArm1EtaMax),
50 mArm1PhiMin(geo.mArm1PhiMin),
51 mArm1PhiMax(geo.mArm1PhiMax),
52 mEtaMaxOfTRD1(geo.mEtaMaxOfTRD1),
53 mDCALPhiMin(geo.mDCALPhiMin),
54 mDCALPhiMax(geo.mDCALPhiMax),
55 mEMCALPhiMax(geo.mEMCALPhiMax),
56 mDCALStandardPhiMax(geo.mDCALStandardPhiMax),
57 mDCALInnerExtandedEta(geo.mDCALInnerExtandedEta),
58 mDCALInnerEdge(geo.mDCALInnerEdge),
59 mShishKebabTrd1Modules(geo.mShishKebabTrd1Modules),
60 mPhiModuleSize(geo.mPhiModuleSize),
61 mEtaModuleSize(geo.mEtaModuleSize),
62 mPhiTileSize(geo.mPhiTileSize),
63 mEtaTileSize(geo.mEtaTileSize),
65 mIPDistance(geo.mIPDistance),
66 mLongModuleSize(geo.mLongModuleSize),
67 mShellThickness(geo.mShellThickness),
68 mZLength(geo.mZLength),
69 mSampling(geo.mSampling),
70 mECPbRadThickness(geo.mECPbRadThickness),
71 mECScintThick(geo.mECScintThick),
72 mNECLayers(geo.mNECLayers),
73 mNumberOfSuperModules(geo.mNumberOfSuperModules),
74 mEMCSMSystem(geo.mEMCSMSystem),
75 mFrontSteelStrip(geo.mFrontSteelStrip),
76 mLateralSteelStrip(geo.mLateralSteelStrip),
77 mPassiveScintThick(geo.mPassiveScintThick),
78 mPhiSuperModule(geo.mPhiSuperModule),
79 mNPhiSuperModule(geo.mNPhiSuperModule),
80 mTrd1Angle(geo.mTrd1Angle),
81 m2Trd1Dx2(geo.m2Trd1Dx2),
82 mPhiGapForSM(geo.mPhiGapForSM),
83 mTrd1AlFrontThick(geo.mTrd1AlFrontThick),
84 mTrd1BondPaperThick(geo.mTrd1BondPaperThick),
87 mSteelFrontThick(geo.mSteelFrontThick),
88 mCellIndexLookup(geo.mCellIndexLookup)
104 mPhiBoundariesOfSM(),
106 mPhiCentersOfSMSec(),
107 mPhiCentersOfCells(),
108 mCentersOfCellsEtaDir(),
109 mCentersOfCellsPhiDir(),
110 mEtaCentersOfCells(),
113 mCentersOfCellsXDir(),
122 mDCALStandardPhiMax(0),
123 mDCALInnerExtandedEta(0),
125 mShishKebabTrd1Modules(),
136 mECPbRadThickness(0.),
139 mNumberOfSuperModules(0),
141 mFrontSteelStrip(0.),
142 mLateralSteelStrip(0.),
143 mPassiveScintThick(0.),
149 mTrd1AlFrontThick(0.0),
150 mTrd1BondPaperThick(0.),
161 for (
auto icell = 0; icell <
mNCells; icell++) {
172 LOG(fatal) <<
"assignment operator, not implemented";
179 LOG(error) <<
"Do not call delete on me";
200 const std::string_view mctitle)
203 if (!
name.length()) {
211 LOG(info) <<
"\n current geometry is " << sGeom->
GetName() <<
" : you should not call " <<
name;
220 const std::string_view mcname,
const std::string_view mctitle)
222 using boost::algorithm::contains;
226 if (runNumber >= 104064 && runNumber < 140000) {
230 if (contains(geoName,
"FIRSTYEARV1") && geoName != std::string(
"")) {
231 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() *** ATTENTION *** \n"
232 <<
"\t Specified geometry name <<" << geoName <<
">> for run " << runNumber
233 <<
" is not considered! \n"
234 <<
"\t In use <<EMCAL_FIRSTYEARV1>>, check run number and year";
237 <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() - Initialized geometry with name <<EMCAL_FIRSTYEARV1>>";
241 }
else if (runNumber >= 140000 && runNumber <= 170593) {
244 if (contains(geoName,
"COMPLETEV1") && geoName != std::string(
"")) {
245 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() *** ATTENTION *** \n"
246 <<
"\t Specified geometry name <<" << geoName <<
">> for run " << runNumber
247 <<
" is not considered! \n"
248 <<
"\t In use <<EMCAL_COMPLETEV1>>, check run number and year";
251 <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() - Initialized geometry with name <<EMCAL_COMPLETEV1>>";
254 }
else if (runNumber > 176000 && runNumber <= 197692) {
258 if (contains(geoName,
"COMPLETE12SMV1") && geoName != std::string(
"")) {
259 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() *** ATTENTION *** \n"
260 <<
"\t Specified geometry name <<" << geoName <<
" >> for run " << runNumber
261 <<
" is not considered! \n"
262 <<
"\t In use <<EMCAL_COMPLETE12SMV1>>, check run number and year";
264 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() - Initialized geometry with name "
265 "<<EMCAL_COMPLETE12SMV1>>";
272 if (contains(geoName,
"DCAL_8SM") && geoName != std::string(
"")) {
273 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() *** ATTENTION *** \n"
274 <<
"\t Specified geometry name <<" << geoName <<
">> for run " << runNumber
275 <<
" is not considered! \n"
276 <<
"\t In use <<EMCAL_COMPLETE12SMV1_DCAL_8SM>>, check run number and year";
278 LOG(info) <<
"o2::emcal::Geometry::GetInstanceFromRunNumber() - Initialized geometry with name "
279 "<<EMCAL_COMPLETE12SMV1_DCAL_8SM>>";
291 using boost::algorithm::contains;
311 Float_t samplingFactorTranportModel = 1.;
315 if (contains(mcname,
"Geant3")) {
316 samplingFactorTranportModel = 1.;
317 }
else if (contains(mcname,
"Fluka")) {
318 samplingFactorTranportModel = 1.;
319 }
else if (contains(mcname,
"Geant4")) {
320 std::string physicslist = mctitle.substr(mctitle.find(
":") + 2).data();
321 LOG(info) <<
"Selected physics list: " << physicslist;
326 samplingFactorTranportModel = 0.81;
327 if (physicslist ==
"FTFP_BERT_EMV+optical") {
328 samplingFactorTranportModel = 0.821;
329 }
else if (physicslist ==
"FTFP_BERT_EMV+optical+biasing") {
330 samplingFactorTranportModel = 0.81;
331 }
else if (physicslist ==
"FTFP_INCLXX_EMV+optical") {
332 samplingFactorTranportModel = 0.81;
336 LOG(info) <<
"MC modeler <" << mcname <<
">, Title <" << mctitle <<
">: Sampling " << std::setw(2)
337 << std::setprecision(3) <<
mSampling <<
", model fraction with respect to G3 "
338 << samplingFactorTranportModel <<
", final sampling " <<
mSampling * samplingFactorTranportModel;
340 mSampling *= samplingFactorTranportModel;
345 using boost::algorithm::contains;
351 if (contains(
mGeoName,
"SHISH_77_TRD1_2X2_FINAL_110DEG")) {
364 if (!(contains(
mGeoName,
"EMCAL_PDC06") || contains(
mGeoName,
"EMCAL_WSUC") || contains(
mGeoName,
"EMCAL_COMPLETE") ||
365 contains(
mGeoName,
"EMCAL_COMPLETEV1") || contains(
mGeoName,
"EMCAL_COMPLETE12SMV1") ||
366 contains(
mGeoName,
"EMCAL_FIRSTYEAR") || contains(
mGeoName,
"EMCAL_FIRSTYEARV1"))) {
367 LOG(fatal) <<
"Init, " <<
mGeoName <<
" is an undefined geometry!\n";
375 if (contains(
mGeoName,
"COMPLETEV1")) {
380 if (contains(
mGeoName,
"DCAL_DEV")) {
382 }
else if (contains(
mGeoName,
"DCAL_8SM")) {
384 }
else if (contains(
mGeoName,
"DCAL")) {
439 if (contains(
mGeoName,
"FIRSTYEAR")) {
444 if (contains(
mGeoName,
"FIRSTYEARV1") || contains(
mGeoName,
"COMPLETEV1") || contains(
mGeoName,
"COMPLETE12SMV1")) {
459 if (contains(
mGeoName,
"COMPLETEV1")) {
462 }
else if (contains(
mGeoName,
"COMPLETE12SMV1")) {
469 if (contains(
mGeoName,
"DCAL_8SM")) {
471 }
else if (contains(
mGeoName,
"DCAL_DEV")) {
492 for (
int i = 0;
i < 2;
i++) {
496 }
else if (contains(
mGeoName,
"FIRSTYEAR")) {
497 for (
int i = 0;
i < 4;
i++) {
502 for (
int i = 0;
i < 10;
i++) {
511 for (
int i = 0;
i < 2;
i++) {
528 for (
int i = 0;
i < 2;
i++) {
556 LOG(error) <<
"Uknown SuperModule Type !!\n";
638 const double INNNER_EXTENDED_PHI =
641 TMath::Tan((TMath::Pi() / 2. - 8 *
mTrd1Angle * TMath::DegToRad() +
666 LOG(error) <<
"Unkown SM Type!!\n";
685 m->LocalToMaster(loc, glob);
687 LOG(fatal) <<
"Geo matrixes are not loaded \n";
693 Double_t tglob[3], tloc[3];
696 vglob.SetXYZ(tglob[0], tglob[1], tglob[2]);
703 memset(glob, 0,
sizeof(Double_t) * 3);
706 loc[0] = cellpos.X();
707 loc[1] = cellpos.Y();
708 loc[2] = cellpos.Z();
717 m->LocalToMaster(loc, glob);
719 LOG(fatal) <<
"Geo matrixes are not loaded \n";
728 vglob.SetXYZ(glob[0], glob[1], glob[2]);
735 return std::make_tuple(vglob.Eta(), vglob.Phi());
746 for (
int i = 0;
i < supermoduleID;
i++) {
770 cellid += etaInModule;
782 int moduleEta = etaInSupermodule /
mNETAdiv,
783 modulePhi = phiInSupermodule /
mNPHIdiv,
784 moduleID = moduleEta * nModulesInSMPhi + modulePhi;
785 int etaInModule = etaInSupermodule %
mNETAdiv,
786 phiInModule = phiInSupermodule %
mNPHIdiv;
788 return std::make_tuple(phiInModule, etaInModule, moduleID);
796 LOG(
debug) <<
"Wrong cell indexes : SM " << nSupMod <<
", column (eta) " << ieta <<
", row (phi) " << iphi;
805 return GetAbsCellId(nSupMod, std::get<2>(indexmod), nIphi, nIeta);
825 for (
int isec = 0; isec < sector; isec++) {
831 return std::make_tuple(
row,
col);
836 if (col < 0 || col >= 4 *
GetNEta()) {
849 if (rowSM < nphism) {
885 Int_t colInModule = colSM %
mNETAdiv,
887 colInModule =
mNETAdiv - 1 - colInModule;
888 return std::make_tuple(
supermodule, std::get<2>(indexmod), rowInMOdule, colInModule);
907 phi = TVector2::Phi_0_2pi(phi);
910 for (Int_t
i = 0;
i < nphism;
i++) {
924 LOG(
debug) <<
"eta " << eta <<
" phi " << phi <<
" (" << std::setw(5) << std::setprecision(2)
925 << phi * TMath::RadToDeg() <<
") : nSupMod " << nSupMod <<
": #bound " <<
i;
937 phi = TVector2::Phi_0_2pi(phi);
955 for (Int_t
i = 1;
i < nphi;
i++) {
964 LOG(debug2) <<
" iphi " << iphi <<
" : dmin " << dmin <<
" (phi " << phi <<
", phiLoc " << phiLoc <<
")\n";
967 Double_t absEta = TMath::Abs(eta);
969 etaShift = iphi * neta,
975 for (Int_t
i = ieta + 1;
i < neta;
i++) {
987 LOG(debug2) <<
" ieta " << ieta <<
" : dmin " << dmin <<
" (eta=" << eta <<
") : nSupMod " << nSupMod;
992 ieta = (neta - 1) - ieta;
1011 for (nSupMod = -1;
test >= 0;) {
1036 return std::make_tuple(nSupMod, nModule, nIphi, nIeta);
1051 int nModulesInPhi = -1;
1054 nModulesInPhi =
mNPhi / 2;
1058 nModulesInPhi =
mNPhi / 3;
1061 nModulesInPhi =
mNPhi;
1064 return std::make_tuple(
int(moduleID % nModulesInPhi),
int(moduleID / nModulesInPhi));
1068 int etaInModule)
const
1073 int etaInSupermodule = etaOfModule *
mNETAdiv + (
mNETAdiv - 1 - etaInModule);
1074 int phiInSupermodule = phiOfModule *
mNPHIdiv + phiInModule;
1076 if (phiInSupermodule < 0 || etaInSupermodule < 0) {
1077 LOG(
debug) <<
" Supermodule " << supermoduleID <<
", Module " << moduleID <<
" (phi " << phiInModule <<
", eta " << etaInModule <<
")"
1078 <<
" => in Supermodule: eta " << etaInSupermodule <<
", phi " << phiInSupermodule;
1080 return std::make_tuple(phiInSupermodule, etaInSupermodule);
1085 if (supermoduleID == 13 || supermoduleID == 15 || supermoduleID == 17) {
1088 }
else if (supermoduleID == 18 || supermoduleID == 19) {
1092 return std::tuple<int, int>(iphi, ieta);
1097 if (supermoduleID == 13 || supermoduleID == 15 || supermoduleID == 17) {
1100 }
else if (supermoduleID == 18 || supermoduleID == 19) {
1104 return std::tuple<int, int>(iphi, ieta);
1114 Double_t xr, yr, zr;
1121 Int_t nSupMod = std::get<0>(cellindex), nModule = std::get<1>(cellindex), nIphi = std::get<2>(cellindex),
1122 nIeta = std::get<3>(cellindex);
1124 Int_t iphi = std::get<0>(indexinsm), ieta = std::get<1>(indexinsm);
1128 if (nSupMod % 2 == 0) {
1145 if (nSupMod % 2 != 0) {
1146 iphi2 = (phiindex / 3 - 1) - iphi;
1150 if (nSupMod % 2 != 0) {
1151 iphi2 = (phiindex / 2 - 1) - iphi;
1156 if (nSupMod % 2 != 0) {
1157 iphi2 = (phiindex / 3 - 1) - iphi;
1161 if (nSupMod % 2 != 0) {
1162 iphi2 = (phiindex - 1) - iphi;
1167 LOG(
debug) <<
"absId " << absId <<
" nSupMod " << nSupMod <<
" iphi " << iphi <<
" ieta " << ieta <<
" xr " << xr
1168 <<
" yr " << yr <<
" zr " << zr;
1176 Double_t xr, yr, zr;
1179 Int_t kDCalshift = 8;
1181 Int_t iphim = -1, ietam = -1;
1188 Int_t nSupMod = std::get<0>(cellindex), nModule = std::get<1>(cellindex), nIphi = std::get<2>(cellindex),
1189 nIeta = std::get<3>(cellindex);
1191 iphim = std::get<0>(indmodep);
1192 ietam = std::get<1>(indmodep);
1194 Int_t iphi = std::get<0>(indexinsm), ieta = std::get<1>(indexinsm);
1197 if (nSupMod % 2 == 0) {
1208 ietam += kDCalshift;
1221 if (nSupMod % 2 != 0) {
1222 iphi2 = (nphiIndex / 3 - 1) - iphi;
1226 if (nSupMod % 2 != 0) {
1227 iphi2 = (nphiIndex / 2 - 1) - iphi;
1232 if (nSupMod % 2 != 0) {
1233 iphi2 = (nphiIndex / 3 - 1) - iphi;
1237 if (nSupMod % 2 != 0) {
1238 iphi2 = (nphiIndex - 1) - iphi;
1243 LOG(
debug) <<
"absId " << absId <<
" nSupMod " << nSupMod <<
" iphi " << iphi <<
" ieta " << ieta <<
" xr " << xr
1244 <<
" yr " << yr <<
" zr " << zr;
1250 LOG(debug2) <<
" o2::emcal::Geometry::CreateListOfTrd1Modules() started\n";
1253 for (
int iz = 0; iz <
mNZ; iz++) {
1262 LOG(debug2) <<
" Already exits :\n";
1280 Int_t ieta = 0, nModule = 0;
1281 Double_t xr = 0., zr = 0., theta = 0., phi = 0., eta = 0.,
r = 0.,
x = 0.,
y = 0.;
1283 Double_t ytCenterModule = 0.0, ytCenterCell = 0.0;
1289 for (Int_t it = 0; it <
mNPhi; it++) {
1291 for (Int_t ic = 0; ic <
mNPHIdiv; ic++) {
1293 ytCenterCell = ytCenterModule +
mPhiTileSize * (2 * ic - 1) / 2.;
1295 ytCenterCell = ytCenterModule +
mPhiTileSize * (ic - 1);
1297 ytCenterCell = ytCenterModule;
1303 phi = TMath::ATan2(ytCenterCell, r0);
1306 LOG(debug2) <<
" ind " << std::setw(2) << std::setprecision(2) << ind <<
" : y " << std::setw(8)
1318 for (Int_t it = 0; it <
mNZ; it++) {
1320 nModule =
mNPhi * it;
1321 for (Int_t ic = 0; ic <
mNETAdiv; ic++) {
1325 ieta = std::get<1>(indexinsm);
1330 ieta = std::get<1>(indexinsm);
1335 ieta = std::get<1>(indexinsm);
1343 r = TMath::Sqrt(
x *
x +
y *
y + zr * zr);
1344 theta = TMath::ACos(zr /
r);
1355 LOG(debug2) <<
" ind " << std::setw(2) << std::setprecision(2) <<
i + 1 <<
" : z " << std::setw(8)
1375 ImpactOnEmcal({particle->Vx(), particle->Vy(), particle->Vz()}, particle->Theta(), particle->Phi(), absID, vimpact);
1388 vimpact.SetXYZ(0, 0, 0);
1390 if (phi == 0 || theta == 0) {
1395 Double_t factor = (
mIPDistance - vtx.Y()) / p.Y();
1396 direction = vtx + factor * p;
1403 Double_t loc[3], loc2[3], loc3[3];
1404 Double_t glob[3] = {}, glob2[3] = {}, glob3[3] = {};
1415 Int_t nSupMod = std::get<0>(cellindex), nModule = std::get<1>(cellindex), nIphi = std::get<2>(cellindex),
1416 nIeta = std::get<3>(cellindex);
1418 Int_t nIphi2 = -1, nIeta2 = -1, absId2 = -1, absId3 = -1;
1424 absId2 =
GetAbsCellId(nSupMod, nModule, nIphi, nIeta2);
1430 absId3 =
GetAbsCellId(nSupMod, nModule, nIphi2, nIeta);
1451 m->LocalToMaster(loc, glob);
1452 m->LocalToMaster(loc2, glob2);
1453 m->LocalToMaster(loc3, glob3);
1455 LOG(fatal) <<
"Geo matrixes are not loaded \n";
1459 Double_t
a = glob[1] * (glob2[2] - glob3[2]) + glob2[1] * (glob3[2] - glob[2]) + glob3[1] * (glob[2] - glob2[2]);
1460 Double_t
b = glob[2] * (glob2[0] - glob3[0]) + glob2[2] * (glob3[0] - glob[0]) + glob3[2] * (glob[0] - glob2[0]);
1461 Double_t
c = glob[0] * (glob2[1] - glob3[1]) + glob2[0] * (glob3[1] - glob[1]) + glob3[0] * (glob[1] - glob2[1]);
1462 Double_t d = glob[0] * (glob2[1] * glob3[2] - glob3[1] * glob2[2]) +
1463 glob2[0] * (glob3[1] * glob[2] - glob[1] * glob3[2]) +
1464 glob3[0] * (glob[1] * glob2[2] - glob2[1] * glob[2]);
1469 Double_t norm = TMath::Sqrt(
a *
a +
b *
b +
c *
c);
1470 Double_t glob4[3] = {};
1473 if (point.Dot(dir) < 0) {
1476 glob4[0] = glob[0] - dist *
a / norm;
1477 glob4[1] = glob[1] - dist *
b / norm;
1478 glob4[2] = glob[2] - dist *
c / norm;
1479 d = glob4[0] *
a + glob4[1] *
b + glob4[2] *
c;
1484 Double_t den =
a * (vtx.X() - direction.X()) +
b * (vtx.Y() - direction.Y()) +
c * (vtx.Z() - direction.Z());
1486 LOG(error) <<
"ImpactOnEmcal() No solution :\n";
1490 Double_t
length =
a * vtx.X() +
b * vtx.Y() +
c * vtx.Z() + d;
1493 vimpact.SetXYZ(vtx.X() +
length * (direction.X() - vtx.X()), vtx.Y() +
length * (direction.Y() - vtx.Y()),
1494 vtx.Z() +
length * (direction.Z() - vtx.Z()));
1497 vimpact.SetXYZ(vimpact.Z() + dist *
a / norm, vimpact.Y() + dist *
b / norm, vimpact.Z() + dist *
c / norm);
1520 Double_t
r = sqrt(pnt.X() * pnt.X() + pnt.Y() * pnt.Y());
1525 Double_t theta = TMath::ATan2(
r, pnt.Z());
1530 eta = -TMath::Log(TMath::Tan(theta / 2.));
1536 Double_t phi = TMath::ATan2(pnt.Y(), pnt.X()) * 180. / TMath::Pi();
1555 LOG(fatal) <<
"Wrong supermodule index -> " << smod;
1562 LOG(fatal) <<
"Cannot find EMCAL misalignment matrices! Recover them either: \n"
1563 <<
"\t - importing TGeoManager from file geometry.root or \n"
1564 <<
"\t - from OADB in file OADB/EMCAL/EMCALlocal2master.root or \n"
1565 <<
"\t - from OCDB in directory OCDB/EMCAL/Align/Data/ or \n"
1566 <<
"\t - from AliESDs (not in AliAOD) via AliESDRun::GetEMCALMatrix(Int_t superModIndex). \n"
1567 <<
"Store them via AliEMCALGeometry::SetMisalMatrix(Int_t superModIndex)";
1577 LOG(fatal) <<
"Wrong supermodule index -> " << smod;
1585 const Int_t buffersize = 255;
1586 char path[buffersize];
1591 for (Int_t
i = 0;
i < smod + 1;
i++) {
1601 TString smName =
"";
1614 LOG(error) <<
"Unkown SM Type!!\n";
1617 snprintf(
path, buffersize,
"/cave/barrel_1/%s_%d", smName.Data(), smOrder);
1619 if (!gGeoManager->cd(
path)) {
1620 LOG(fatal) <<
"Geo manager can not find path " <<
path <<
"!\n";
1623 return gGeoManager->GetCurrentMatrix();
1627 const Float_t misaligTransShifts[15],
const Float_t misaligRotShifts[15],
1639 gGeoManager->cd(
"/cave/barrel_1/");
1640 TGeoNode* geoXEn1 = gGeoManager->GetCurrentNode();
1641 TGeoNodeMatrix* geoSM[nSMod];
1642 TGeoVolume* geoSMVol[nSMod];
1643 TGeoShape* geoSMShape[nSMod];
1644 TGeoBBox* geoBox[nSMod];
1645 TGeoMatrix* geoSMMatrix[nSMod];
1647 for (
int iSM = 0; iSM < nSMod; iSM++) {
1648 geoSM[iSM] =
dynamic_cast<TGeoNodeMatrix*
>(geoXEn1->GetDaughter(iSM));
1649 geoSMVol[iSM] = geoSM[iSM]->GetVolume();
1650 geoSMShape[iSM] = geoSMVol[iSM]->GetShape();
1651 geoBox[iSM] =
dynamic_cast<TGeoBBox*
>(geoSMShape[iSM]);
1652 geoSMMatrix[iSM] = geoSM[iSM]->GetMatrix();
1680 if (dcol >= 47.5 || dcol < -0.5) {
1681 LOG(error) <<
"Bad tower coordinate dcol=" << dcol <<
", where dcol >= 47.5 || dcol<-0.5; org: " << dcolorg;
1684 if (drow >= 23.5 || drow < -0.5) {
1685 LOG(error) <<
"Bad tower coordinate drow=" << drow <<
", where drow >= 23.5 || drow<-0.5; org: " << droworg;
1688 if (sm >= nSMod || sm < 0) {
1689 LOG(error) <<
"Bad SM number sm=" << nSMod <<
", where sm >= " << sm <<
" || sm < 0\n";
1693 istrip =
int((dcol + 0.5) / 2);
1696 teta1 = TMath::DegToRad() * istrip * 1.5;
1701 for (
int is = 0; is <= istrip; is++) {
1702 teta1 = TMath::DegToRad() * (is * 1.5 + 0.75);
1704 zIs = zIs + 2 * dz * TMath::Cos(teta1);
1707 zIs + 2 * dz * TMath::Cos(teta1) + 2 * dz * TMath::Sin(teta1) * TMath::Tan(teta1 - 0.75 * TMath::DegToRad());
1711 z0 = dz * (dcol - 2 * istrip + 0.5);
1712 zb = (2 * dz - z0 -
depth * TMath::Tan(teta1));
1714 z = zIs - zb * TMath::Cos(teta1);
1715 y =
depth / TMath::Cos(teta1) + zb * TMath::Sin(teta1);
1717 x = (drow + 0.5) * dx;
1722 double xx =
y - geoBox[sm]->GetDX();
1723 double yy = -
x + geoBox[sm]->GetDY();
1724 double zz =
z - geoBox[sm]->GetDZ();
1725 const double localIn[3] = {xx, yy, zz};
1730 geoSMMatrix[sm]->LocalToMaster(localIn, dglobal);
1735 if (sm == 2 || sm == 3) {
1736 global[0] = dglobal[0] + misaligTransShifts[3] + misaligRotShifts[3] * TMath::Sin(TMath::DegToRad() * 20);
1737 global[1] = dglobal[1] + misaligTransShifts[4] + misaligRotShifts[4] * TMath::Cos(TMath::DegToRad() * 20);
1738 global[2] = dglobal[2] + misaligTransShifts[5];
1739 }
else if (sm == 0 || sm == 1) {
1740 global[0] = dglobal[0] + misaligTransShifts[0];
1741 global[1] = dglobal[1] + misaligTransShifts[1];
1742 global[2] = dglobal[2] + misaligTransShifts[2];
1744 LOG(info) <<
"Careful, correction not implemented yet!\n";
1745 global[0] = dglobal[0];
1746 global[1] = dglobal[1];
1747 global[2] = dglobal[2];
1750 LOG(fatal) <<
"Geometry boxes information, check that geometry.root is loaded\n";
1761 LOG(fatal) <<
"Wrong supermodule index -> " << smod << std::endl;
1785 int i = nsupmod / 2;
1791 int i = nsupmod / 2;
1816 auto supermoduleID = std::get<0>(cellindex);
1819 int row = std::get<0>(etaphishift),
col = std::get<1>(etaphishift);
1821 int ddlInSupermoudel = -1;
1822 if (0 <=
row &&
row < 8) {
1823 ddlInSupermoudel = 0;
1824 }
else if (8 <=
row &&
row < 16 && 0 <=
col &&
col < 24) {
1825 ddlInSupermoudel = 0;
1826 }
else if (8 <=
row &&
row < 16 && 24 <=
col &&
col < 48) {
1827 ddlInSupermoudel = 1;
1828 }
else if (16 <=
row &&
row < 24) {
1829 ddlInSupermoudel = 1;
1831 if (supermoduleID % 2 == 1) {
1832 ddlInSupermoudel = 1 - ddlInSupermoudel;
1835 return std::make_tuple(supermoduleID * 2 + ddlInSupermoudel,
row,
col);
Error handling access to non-initialized geometry.
EMCAL geometry definition.
std::tuple< int, int, int > GetModuleIndexesFromCellIndexesInSModule(int supermoduleID, int phiInSupermodule, int etaInSupermodule) const
Transition from cell indexes (iphi, ieta) to module indexes (iphim, ietam, nModule)
Float_t mFrontSteelStrip
13-may-05
static Geometry * GetInstanceFromRunNumber(Int_t runNumber, const std::string_view="", const std::string_view mcname="TGeant3", const std::string_view mctitle="")
Instanciate geometry depending on the run number. Mostly used in analysis and MC anchors.
Float_t mEtaMaxOfTRD1
Max eta in case of TRD1 geometry (see AliEMCALShishKebabTrd1Module)
Int_t GetSuperModuleNumber(Int_t absId) const
Get cell SM, from absolute ID number.
void RecalculateTowerPosition(Float_t drow, Float_t dcol, const Int_t sm, const Float_t depth, const Float_t misaligTransShifts[15], const Float_t misaligRotShifts[15], Float_t global[3]) const
std::tuple< int, int, int, int > CalculateCellIndex(Int_t absId) const
Calculate cell SM, module numbers from absolute ID number.
Float_t mIPDistance
Radial Distance of the inner surface of the EMCAL.
Float_t mDCALPhiMin
Minimum angular position of DCAL in Phi (degrees)
Float_t mPassiveScintThick
13-may-05
Float_t mPhiTileSize
Size of phi tile.
int GlobalRow(int cellID) const
Get row number of cell in global numbering scheme.
Int_t mNZ
Number of Towers in the Z direction.
Float_t mECScintThick
cm, Thickness of the scintillators
const TGeoHMatrix * GetMatrixForSuperModuleFromGeoManager(Int_t smod) const
Provides shift-rotation matrix for EMCAL from the TGeoManager.
std::tuple< int, int > GetCellPhiEtaIndexInSModule(int supermoduleID, int moduleID, int phiInModule, int etaInModule) const
Get eta-phi indexes of cell in SM.
std::tuple< int, int, int, int > GetCellIndex(Int_t absId) const
Get cell SM, module numbers from absolute ID number.
std::tuple< double, double > GetPhiBoundariesOfSM(Int_t nSupMod) const
Int_t mNECLayers
number of scintillator layers
std::vector< Double_t > mPhiCentersOfCells
[fNPhi*fNPHIdiv] from center of SM (-10. < phi < +10.)
const TGeoHMatrix * GetMatrixForSuperModule(Int_t smod) const
Provides shift-rotation matrix for EMCAL from externally set matrix or from TGeoManager.
Geometry & operator=(const Geometry &rvalue)
Assignment operator.
Float_t GetDCALInnerEdge() const
std::tuple< int, int, int > getOnlineID(int towerID)
Get link ID, row and column from cell ID, have a look here: https://alice.its.cern....
Int_t GetNEta() const
Get the number of modules in supermodule in #eta direction.
Float_t mEtaModuleSize
Eta -> Y.
Double_t GetPhiCenterOfSMSec(Int_t nsupmod) const
Float_t GetPhiModuleSize() const
Bool_t CheckAbsCellId(Int_t absId) const
Check whether a cell number is valid.
Float_t mZLength
Total length in z direction.
Float_t mEnvelop[3]
The GEANT TUB for the detector.
Float_t mDCALInnerEdge
Inner edge for DCAL.
void CreateListOfTrd1Modules()
Float_t mParSM[3]
SM sizes as in GEANT (TRD1)
Float_t GetShellThickness() const
Int_t mNCellsInModule
Number cell in module.
std::vector< EMCALSMType > mEMCSMSystem
geometry structure
Bool_t IsDCALExtSM(Int_t nSupMod) const
Check if iSupMod is a valid DCal 1/3rd SM.
std::tuple< int, int, int, int > GetCellIndexFromGlobalRowCol(int row, int col) const
Get the cell indices from global position in the EMCAL.
Double_t GetPhiCenterOfSM(Int_t nsupmod) const
const TGeoHMatrix * SMODULEMATRIX[EMCAL_MODULES]
Orientations of EMCAL super modules.
std::tuple< int, int > GetModulePhiEtaIndexInSModule(int supermoduleID, int moduleID) const
Get eta-phi indexes of module in SM.
std::tuple< int, int, int > GetPositionInSupermoduleFromGlobalRowCol(int row, int col) const
Get the posision (row, col) of a global row-col position.
const TGeoHMatrix * GetMatrixForSuperModuleFromArray(Int_t smod) const
Provides shift-rotation matrix for EMCAL from fkSModuleMatrix[smod].
Float_t mTrd1AlFrontThick
Thickness of the Al front plate.
Float_t mSampling
Sampling factor.
Float_t mDCALPhiMax
Maximum angular position of DCAL in Phi (degrees)
Float_t mTrd1BondPaperThick
Thickness of the Bond Paper sheet.
Int_t mNCells
Number of cells in calo.
Float_t mArm1PhiMin
Minimum angular position of EMCAL in Phi (degrees)
void SetMisalMatrix(const TGeoHMatrix *m, Int_t smod) const
Int_t mNETAdiv
Number eta division of module.
Float_t mLateralSteelStrip
13-may-05
std::tuple< int, int > GlobalRowColFromIndex(int cellID) const
get (Column,Row) pair of cell in global numbering scheme
Float_t mTrd1Angle
angle in x-z plane (in degree)
Float_t mECPbRadThickness
cm, Thickness of the Pb radiators
void GetGlobal(const Double_t *loc, Double_t *glob, int ind) const
Figure out the global coordinates from local coordinates on a supermodule.
std::vector< Double_t > mEtaCentersOfCells
[fNEta*fNETAdiv*fNPhi*fNPHIdiv], positive direction (eta>0); eta depend from phi position;
int GetAbsCellId(int supermoduleID, int moduleID, int phiInModule, int etaInModule) const
Get cell absolute ID number from location module (2 times 2 cells) of a super module.
Float_t mArm1PhiMax
Maximum angular position of EMCAL in Phi (degrees)
static Geometry * GetInstance()
Get geometry instance. It should have been set before.
std::tuple< double, double > EtaPhiFromIndex(Int_t absId) const
Figure out the eta/phi coordinates of a cell.
Int_t mKey110DEG
For calculation abs cell id; 19-oct-05.
std::vector< Double_t > mPhiCentersOfSMSec
Phi of centers of section where SM lies; size is fNumberOfSuperModules/2.
std::vector< Double_t > mCentersOfCellsEtaDir
Size fNEta*fNETAdiv (for TRD1 only) (eta or z in SM, in cm)
std::string mGeoName
Geometry name string.
Int_t GetNPhiSuperModule() const
int GlobalCol(int cellID) const
Get column number of cell in global numbering scheme.
Float_t mShellThickness
Total thickness in (x,y) direction.
EMCALSMType GetSMType(Int_t nSupMod) const
std::vector< Double_t > mCentersOfCellsPhiDir
Size fNPhi*fNPHIdiv (for TRD1 only) (phi or y in SM, in cm)
Int_t mNPHIdiv
Number phi division of module.
Int_t mnSupModInDCAL
For calculation abs cell id; 06-nov-12.
Float_t mEtaTileSize
Size of eta tile.
int SuperModuleNumberFromEtaPhi(Double_t eta, Double_t phi) const
Given a global eta/phi point check if it belongs to a supermodule covered region.
void DefineEMC(std::string_view mcname, std::string_view mctitle)
Init function of previous class EMCGeometry.
Bool_t IsDCALSM(Int_t nSupMod) const
Check if iSupMod is a valid DCal standard SM.
Bool_t Impact(const TParticle *particle) const
Check if particle falls in the EMCal/DCal geometry.
std::vector< ShishKebabTrd1Module > mShishKebabTrd1Modules
List of modules.
Bool_t IsInEMCAL(const math_utils::Point3D< double > &pnt) const
Checks whether point is inside the EMCal volume.
math_utils::Point3D< double > RelPosCellInSModule(Int_t absId, Double_t distEf) const
Look to see what the relative position inside a given cell is for a recpoint.
const std::string & GetName() const
Float_t mEMCALPhiMax
Maximum angular position of EMCAL in Phi (degrees)
Bool_t IsInDCAL(const math_utils::Point3D< double > &pnt) const
Checks whether point is inside the DCal volume.
Int_t mNPhiSuperModule
9 - number supermodule in phi direction
Float_t mPhiModuleSize
Phi -> X.
Float_t mPhiGapForSM
Gap betweeen supermodules in phi direction.
Geometry()=default
Default constructor. It must be kept public for root persistency purposes, but should never be called...
Float_t m2Trd1Dx2
2*dx2 for TRD1
AcceptanceType_t IsInEMCALOrDCAL(const math_utils::Point3D< double > &pnt) const
Checks whether point is inside the EMCal volume (included DCal)
Int_t GetNumberOfSuperModules() const
Int_t GetNumberOfModuleInPhiDirection(Int_t nSupMod) const
std::tuple< int, int > ShiftOnlineToOfflineCellIndexes(Int_t supermoduleID, Int_t iphi, Int_t ieta) const
Adapt cell indices in supermodule to online indexing.
Float_t mPhiSuperModule
Phi of normal supermodule (20, in degree)
Float_t mArm1EtaMin
Minimum pseudorapidity position of EMCAL in Eta.
void ImpactOnEmcal(const math_utils::Point3D< double > &vtx, Double_t theta, Double_t phi, Int_t &absId, math_utils::Point3D< double > &vimpact) const
Get the impact coordinates on EMCAL.
Int_t GetNPhi() const
Get the number of modules in supermodule in #phi direction.
Float_t mArm1EtaMax
Maximum pseudorapidity position of EMCAL in Eta.
Int_t GetAbsCellIdFromCellIndexes(Int_t nSupMod, Int_t iphi, Int_t ieta) const
Transition from super module number (nSupMod) and cell indexes (ieta,iphi) to cell absolute ID number...
std::vector< Double_t > mCentersOfCellsXDir
Size fNEta*fNETAdiv (for TRD1 only) ( x in SM, in cm)
Int_t mNPhi
Number of Towers in the PHI direction.
const ShishKebabTrd1Module & GetShishKebabModule(Int_t neta) const
Get the Module parameters for a eta.
Int_t mNumberOfSuperModules
default is 12 = 6 * 2
std::tuple< double, double > GetPhiBoundariesOfSMGap(Int_t nPhiSec) const
std::vector< Double_t > mPhiBoundariesOfSM
Phi boundaries of SM in rad; size is fNumberOfSuperModules;.
std::vector< std::tuple< int, int, int, int > > mCellIndexLookup
Lookup table for cell indices.
void DefineSamplingFraction(const std::string_view mcname="", const std::string_view mctitle="")
Set the value of the Sampling used to calibrate the MC hits energy (check)
Float_t mDCALStandardPhiMax
Special edge for the case that DCAL contian extension.
Float_t mLongModuleSize
Size of long module.
int GetAbsCellIdFromEtaPhi(Double_t eta, Double_t phi) const
Get cell absolute ID number from eta and phi location.
Int_t mNCellsInSupMod
Number cell in super module.
int GetCellAbsIDFromGlobalRowCol(int row, int col) const
Get the absolute cell ID from global position in the EMCAL.
std::tuple< int, int > ShiftOfflineToOnlineCellIndexes(Int_t supermoduleID, Int_t iphi, Int_t ieta) const
Adapt cell indices in supermodule to offline indexing.
std::vector< Double_t > mPhiCentersOfSM
Phi of centers of SM; size is fNumberOfSuperModules/2.
Float_t mDCALInnerExtandedEta
DCAL inner edge in Eta (with some extension)
Exception handling non-existing cell IDs.
const char * what() const noexcept final
Access to error message of the exception.
Error Handling when an invalid module ID (outside the limits) is called.
Exception handling errors due to positions not in the EMCAL area.
Exception handling improper or uninitialized supermodule types.
Handling error for invalid positions in row-column space.
Main class for TRD1 geometry of Shish-Kebab case.
void GetCenterOfCellInLocalCoordinateofSM3X3(Int_t ieta, Double_t &xr, Double_t &zr) const
void GetCenterOfCellInLocalCoordinateofSM1X1(Double_t &xr, Double_t &zr) const
Double_t GetMaxEtaOfModule() const
static Double_t ThetaToEta(Double_t theta)
void GetPositionAtCenterCellLine(Int_t ieta, Double_t dist, TVector2 &v) const
const TVector2 & GetCenterOfCellInLocalCoordinateofSM(Int_t ieta) const
Double_t GetRadius() const
GLuint const GLchar * name
GLboolean GLboolean GLboolean b
GLuint GLsizei GLsizei * length
GLint GLint GLsizei GLsizei GLsizei depth
GLsizei const GLchar *const * path
GLboolean GLboolean GLboolean GLboolean a
GLdouble GLdouble GLdouble z
const std::string DEFAULT_GEOMETRY
@ EMCAL_MODULES
Number of modules, 12 for EMCal + 8 for DCAL.
@ EMCAL_ROWS
Number of rows per module for EMCAL.
@ EMCAL_COLS
Number of columns per module for EMCAL.
FIXME: do not use data model tables.
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"