From 144a9aa1f5ee02ae39476d6150fb3b4a7c9bce06 Mon Sep 17 00:00:00 2001 From: Matteo Concas Date: Thu, 15 Feb 2024 13:22:30 +0100 Subject: [PATCH] ALICE 3: Add ECal detector (#12682) * Resize Magnet accoding to SD * Add ECal as Pb Cylinder * Update GeometryTGeo.h --- Common/SimConfig/src/SimConfig.cxx | 8 +- .../DetectorsCommonDataFormats/DetID.h | 9 +- .../Headers/include/Headers/DataHeader.h | 3 +- Detectors/Upgrades/ALICE3/CMakeLists.txt | 1 + Detectors/Upgrades/ALICE3/ECal/CMakeLists.txt | 13 + Detectors/Upgrades/ALICE3/ECal/README.md | 10 + .../Upgrades/ALICE3/ECal/base/CMakeLists.txt | 19 ++ .../base/include/ECalBase/ECalBaseParam.h | 33 +++ .../ECal/base/include/ECalBase/GeometryTGeo.h | 47 ++++ .../ALICE3/ECal/base/src/ECalBaseLinkDef.h | 22 ++ .../ALICE3/ECal/base/src/ECalBaseParam.cxx | 14 ++ .../ALICE3/ECal/base/src/GeometryTGeo.cxx | 66 +++++ .../ALICE3/ECal/simulation/CMakeLists.txt | 18 ++ .../include/ECalSimulation/Detector.h | 105 ++++++++ .../ALICE3/ECal/simulation/src/Detector.cxx | 234 ++++++++++++++++++ .../simulation/src/ECalSimulationLinkDef.h | 21 ++ .../include/Alice3DetectorsPassive/Magnet.h | 6 +- macro/CMakeLists.txt | 2 +- macro/build_geometry.C | 6 + run/CMakeLists.txt | 1 + 20 files changed, 625 insertions(+), 13 deletions(-) create mode 100644 Detectors/Upgrades/ALICE3/ECal/CMakeLists.txt create mode 100644 Detectors/Upgrades/ALICE3/ECal/README.md create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/CMakeLists.txt create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/ECalBaseParam.h create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/GeometryTGeo.h create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseLinkDef.h create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseParam.cxx create mode 100644 Detectors/Upgrades/ALICE3/ECal/base/src/GeometryTGeo.cxx create mode 100644 Detectors/Upgrades/ALICE3/ECal/simulation/CMakeLists.txt create mode 100644 Detectors/Upgrades/ALICE3/ECal/simulation/include/ECalSimulation/Detector.h create mode 100644 Detectors/Upgrades/ALICE3/ECal/simulation/src/Detector.cxx create mode 100644 Detectors/Upgrades/ALICE3/ECal/simulation/src/ECalSimulationLinkDef.h diff --git a/Common/SimConfig/src/SimConfig.cxx b/Common/SimConfig/src/SimConfig.cxx index 8a19217ad629d..9460b429b38d5 100644 --- a/Common/SimConfig/src/SimConfig.cxx +++ b/Common/SimConfig/src/SimConfig.cxx @@ -74,14 +74,14 @@ void SimConfig::determineActiveModules(std::vector const& inputargs if (activeModules[0] != "all") { if (isUpgrade) { for (int i = 0; i < activeModules.size(); ++i) { - if (activeModules[i] != "IT3" && activeModules[i] != "TRK" && activeModules[i] != "FT3" && activeModules[i] != "FCT" && activeModules[i] != "A3IP" && activeModules[i] != "TF3" && activeModules[i] != "RCH" && activeModules[i] != "MI3") { + if (activeModules[i] != "IT3" && activeModules[i] != "TRK" && activeModules[i] != "FT3" && activeModules[i] != "FCT" && activeModules[i] != "A3IP" && activeModules[i] != "TF3" && activeModules[i] != "RCH" && activeModules[i] != "MI3" && activeModules[i] != "ECL") { LOGP(fatal, "List of active modules contains {}, which is not a module from the upgrades.", activeModules[i]); } } } if (!isUpgrade) { for (int i = 0; i < activeModules.size(); ++i) { - if (activeModules[i] == "TRK" || activeModules[i] == "FT3" || activeModules[i] == "FCT" || activeModules[i] == "A3IP" && activeModules[i] == "TF3" && activeModules[i] == "RCH" && activeModules[i] == "MI3") { + if (activeModules[i] == "TRK" || activeModules[i] == "FT3" || activeModules[i] == "FCT" || activeModules[i] == "A3IP" && activeModules[i] == "TF3" && activeModules[i] == "RCH" && activeModules[i] == "MI3" && activeModules[i] == "ECL") { LOGP(fatal, "List of active modules contains {}, which is not a run 3 module", activeModules[i]); } } @@ -93,7 +93,7 @@ void SimConfig::determineActiveModules(std::vector const& inputargs #ifdef ENABLE_UPGRADES if (isUpgrade) { for (int d = DetID::First; d <= DetID::Last; ++d) { - if (d == DetID::TRK || d == DetID::FT3 || d == DetID::FCT || d == DetID::TF3 || d == DetID::RCH) { + if (d == DetID::TRK || d == DetID::FT3 || d == DetID::FCT || d == DetID::TF3 || d == DetID::RCH || d == DetID::ECL) { activeModules.emplace_back(DetID::getName(d)); } } @@ -112,7 +112,7 @@ void SimConfig::determineActiveModules(std::vector const& inputargs activeModules.emplace_back("SHIL"); for (int d = DetID::First; d <= DetID::Last; ++d) { #ifdef ENABLE_UPGRADES - if (d != DetID::IT3 && d != DetID::TRK && d != DetID::FT3 && d != DetID::FCT && d != DetID::TF3 && d != DetID::RCH && d != DetID::MI3) { + if (d != DetID::IT3 && d != DetID::TRK && d != DetID::FT3 && d != DetID::FCT && d != DetID::TF3 && d != DetID::RCH && d != DetID::ECL && d != DetID::MI3) { activeModules.emplace_back(DetID::getName(d)); } } diff --git a/DataFormats/Detectors/Common/include/DetectorsCommonDataFormats/DetID.h b/DataFormats/Detectors/Common/include/DetectorsCommonDataFormats/DetID.h index f796f1f815ece..a2767c7620cdd 100644 --- a/DataFormats/Detectors/Common/include/DetectorsCommonDataFormats/DetID.h +++ b/DataFormats/Detectors/Common/include/DetectorsCommonDataFormats/DetID.h @@ -86,7 +86,8 @@ class DetID static constexpr ID TF3 = 22; static constexpr ID RCH = 23; static constexpr ID MI3 = 24; - static constexpr ID Last = MI3; + static constexpr ID ECL = 25; + static constexpr ID Last = ECL; #else static constexpr ID Last = FOC; ///< if extra detectors added, update this !!! #endif @@ -180,7 +181,7 @@ class DetID // detector names, will be defined in DataSources static constexpr const char* sDetNames[nDetectors + 1] = ///< defined detector names #ifdef ENABLE_UPGRADES - {"ITS", "TPC", "TRD", "TOF", "PHS", "CPV", "EMC", "HMP", "MFT", "MCH", "MID", "ZDC", "FT0", "FV0", "FDD", "TST", "CTP", "FOC", "IT3", "TRK", "FT3", "FCT", "TF3", "RCH", "MI3", nullptr}; + {"ITS", "TPC", "TRD", "TOF", "PHS", "CPV", "EMC", "HMP", "MFT", "MCH", "MID", "ZDC", "FT0", "FV0", "FDD", "TST", "CTP", "FOC", "IT3", "TRK", "FT3", "FCT", "TF3", "RCH", "MI3", "ECL", nullptr}; #else {"ITS", "TPC", "TRD", "TOF", "PHS", "CPV", "EMC", "HMP", "MFT", "MCH", "MID", "ZDC", "FT0", "FV0", "FDD", "TST", "CTP", "FOC", nullptr}; #endif @@ -194,7 +195,7 @@ class DetID #ifdef ENABLE_UPGRADES , o2h::gDataOriginIT3, o2h::gDataOriginTRK, o2h::gDataOriginFT3, o2h::gDataOriginFCT, o2h::gDataOriginTF3, - o2h::gDataOriginRCH, o2h::gDataOriginMI3 + o2h::gDataOriginRCH, o2h::gDataOriginMI3, o2h::gDataOriginECL #endif }; #endif // GPUCA_GPUCODE_DEVICE @@ -213,7 +214,7 @@ GPUconstexpr() DetID::mask_t sMasks[DetID::nDetectors] = ///< detectot masks #ifdef ENABLE_UPGRADES , DetID::mask_t(math_utils::bit2Mask(DetID::IT3)), DetID::mask_t(math_utils::bit2Mask(DetID::TRK)), DetID::mask_t(math_utils::bit2Mask(DetID::FT3)), DetID::mask_t(math_utils::bit2Mask(DetID::FCT)), DetID::mask_t(math_utils::bit2Mask(DetID::TF3)), - DetID::mask_t(math_utils::bit2Mask(DetID::RCH)), DetID::mask_t(math_utils::bit2Mask(DetID::MI3)) + DetID::mask_t(math_utils::bit2Mask(DetID::RCH)), DetID::mask_t(math_utils::bit2Mask(DetID::MI3)), DetID::mask_t(math_utils::bit2Mask(DetID::ECL)) #endif }; } // namespace detid_internal diff --git a/DataFormats/Headers/include/Headers/DataHeader.h b/DataFormats/Headers/include/Headers/DataHeader.h index 844823ffed0ed..c37eff9b34f20 100644 --- a/DataFormats/Headers/include/Headers/DataHeader.h +++ b/DataFormats/Headers/include/Headers/DataHeader.h @@ -585,7 +585,8 @@ constexpr o2::header::DataOrigin gDataOriginFT3{"FT3"}; constexpr o2::header::DataOrigin gDataOriginFCT{"FCT"}; constexpr o2::header::DataOrigin gDataOriginTF3{"TF3"}; constexpr o2::header::DataOrigin gDataOriginRCH{"RCH"}; -constexpr o2::header::DataOrigin gDataOriginMI3{"MI3"}; // upgrades +constexpr o2::header::DataOrigin gDataOriginMI3{"MI3"}; +constexpr o2::header::DataOrigin gDataOriginECL{"ECL"}; // upgrades constexpr o2::header::DataOrigin gDataOriginGPU{"GPU"}; diff --git a/Detectors/Upgrades/ALICE3/CMakeLists.txt b/Detectors/Upgrades/ALICE3/CMakeLists.txt index 8330005c3b2e7..0d60f0317dff3 100644 --- a/Detectors/Upgrades/ALICE3/CMakeLists.txt +++ b/Detectors/Upgrades/ALICE3/CMakeLists.txt @@ -11,6 +11,7 @@ add_subdirectory(Passive) add_subdirectory(TRK) +add_subdirectory(ECal) add_subdirectory(FT3) add_subdirectory(FCT) add_subdirectory(AOD) diff --git a/Detectors/Upgrades/ALICE3/ECal/CMakeLists.txt b/Detectors/Upgrades/ALICE3/ECal/CMakeLists.txt new file mode 100644 index 0000000000000..83838a01d13f1 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/CMakeLists.txt @@ -0,0 +1,13 @@ +# Copyright 2019-2020 CERN and copyright holders of ALICE O2. +# See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +# All rights not expressly granted are reserved. +# +# This software is distributed under the terms of the GNU General Public +# License v3 (GPL Version 3), copied verbatim in the file "COPYING". +# +# In applying this license CERN does not waive the privileges and immunities +# granted to it by virtue of its status as an Intergovernmental Organization +# or submit itself to any jurisdiction. + +add_subdirectory(base) +add_subdirectory(simulation) \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/README.md b/Detectors/Upgrades/ALICE3/ECal/README.md new file mode 100644 index 0000000000000..288040fbd5fd9 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/README.md @@ -0,0 +1,10 @@ + + +# ALICE 3 Electromagnetic Calorimenter + +This is top page for the ECL detector documentation. + + \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/base/CMakeLists.txt b/Detectors/Upgrades/ALICE3/ECal/base/CMakeLists.txt new file mode 100644 index 0000000000000..70017cc051e80 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/CMakeLists.txt @@ -0,0 +1,19 @@ +# Copyright 2019-2020 CERN and copyright holders of ALICE O2. +# See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +# All rights not expressly granted are reserved. +# +# This software is distributed under the terms of the GNU General Public +# License v3 (GPL Version 3), copied verbatim in the file "COPYING". +# +# In applying this license CERN does not waive the privileges and immunities +# granted to it by virtue of its status as an Intergovernmental Organization +# or submit itself to any jurisdiction. + +o2_add_library(ECalBase + SOURCES src/GeometryTGeo.cxx + src/ECalBaseParam.cxx + PUBLIC_LINK_LIBRARIES O2::DetectorsBase) + +o2_target_root_dictionary(ECalBase + HEADERS include/ECalBase/GeometryTGeo.h + include/ECalBase/ECalBaseParam.h) \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/ECalBaseParam.h b/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/ECalBaseParam.h new file mode 100644 index 0000000000000..35d25b0050bba --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/ECalBaseParam.h @@ -0,0 +1,33 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#ifndef O2_ECAL_BASEPARAM_H +#define O2_ECAL_BASEPARAM_H + +#include "CommonUtils/ConfigurableParam.h" +#include "CommonUtils/ConfigurableParamHelper.h" + +namespace o2 +{ +namespace ecal +{ +struct ECalBaseParam : public o2::conf::ConfigurableParamHelper { + float rMin = 125.0; // cm + float rMax = 155.0; // cm + float zLength = 350.0; // cm + + O2ParamDef(ECalBaseParam, "ECalBase"); +}; + +} // namespace ecal +} // end namespace o2 + +#endif \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/GeometryTGeo.h b/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/GeometryTGeo.h new file mode 100644 index 0000000000000..1cff6dd7d3313 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/include/ECalBase/GeometryTGeo.h @@ -0,0 +1,47 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#ifndef ALICEO2_ECAL_GEOMETRYTGEO_H +#define ALICEO2_ECAL_GEOMETRYTGEO_H + +#include + +namespace o2 +{ +namespace ecal +{ +class GeometryTGeo : public o2::detectors::DetMatrixCache +{ + public: + GeometryTGeo(bool build = false, int loadTrans = 0); + void Build(int loadTrans); + void fillMatrixCache(int mask); + static GeometryTGeo* Instance(); + + static const char* getECalVolPattern() { return sVolumeName.c_str(); } + static const char* getECalSensorPattern() { return sSensorName.c_str(); } + + static const char* composeSymNameECal() + { + return Form("%s_%d", o2::detectors::DetID(o2::detectors::DetID::ECL).getName(), 0); + } + static const char* composeSymNameSensor(); // A single sensor for the moment + + protected: + static std::string sVolumeName; + static std::string sSensorName; + + private: + static std::unique_ptr sInstance; +}; +} // namespace ecal +} // namespace o2 +#endif diff --git a/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseLinkDef.h b/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseLinkDef.h new file mode 100644 index 0000000000000..3bf7ccd32460c --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseLinkDef.h @@ -0,0 +1,22 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#ifdef __CLING__ + +#pragma link off all globals; +#pragma link off all classes; +#pragma link off all functions; + +#pragma link C++ class o2::ecal::GeometryTGeo + +#pragma link C++ class o2::ecal::ECalBaseParam + ; +#pragma link C++ class o2::conf::ConfigurableParamHelper < o2::ecal::ECalBaseParam> + ; + +#endif \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseParam.cxx b/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseParam.cxx new file mode 100644 index 0000000000000..54eb2860526b3 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/src/ECalBaseParam.cxx @@ -0,0 +1,14 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#include "ECalBase/ECalBaseParam.h" + +O2ParamImpl(o2::ecal::ECalBaseParam); \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/base/src/GeometryTGeo.cxx b/Detectors/Upgrades/ALICE3/ECal/base/src/GeometryTGeo.cxx new file mode 100644 index 0000000000000..49f57d8a8c5cc --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/base/src/GeometryTGeo.cxx @@ -0,0 +1,66 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#include +#include + +namespace o2 +{ +namespace ecal +{ +std::unique_ptr GeometryTGeo::sInstance; + +std::string GeometryTGeo::sVolumeName = "ECALV"; +std::string GeometryTGeo::sSensorName = "ECALSensor"; + +GeometryTGeo::GeometryTGeo(bool build, int loadTrans) : DetMatrixCache() +{ + if (sInstance) { + LOGP(fatal, "Invalid use of public constructor: o2::ecal::GeometryTGeo instance exists"); + } + if (build) { + Build(loadTrans); + } +} + +void GeometryTGeo::Build(int loadTrans) +{ + if (isBuilt()) { + LOGP(warning, "Already built"); + return; // already initialized + } + + if (!gGeoManager) { + LOGP(fatal, "Geometry is not loaded"); + } + + fillMatrixCache(loadTrans); +} + +void GeometryTGeo::fillMatrixCache(int mask) +{ +} + +GeometryTGeo* GeometryTGeo::Instance() +{ + if (!sInstance) { + sInstance = std::unique_ptr(new GeometryTGeo(true, 0)); + } + return sInstance.get(); +} + +const char* GeometryTGeo::composeSymNameSensor() +{ + return Form("%s/%d", composeSymNameECal(), 0); +} + +} // namespace ecal +} // namespace o2 \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/simulation/CMakeLists.txt b/Detectors/Upgrades/ALICE3/ECal/simulation/CMakeLists.txt new file mode 100644 index 0000000000000..8c8c5a6bba15f --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/simulation/CMakeLists.txt @@ -0,0 +1,18 @@ +# Copyright 2019-2020 CERN and copyright holders of ALICE O2. +# See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +# All rights not expressly granted are reserved. +# +# This software is distributed under the terms of the GNU General Public +# License v3 (GPL Version 3), copied verbatim in the file "COPYING". +# +# In applying this license CERN does not waive the privileges and immunities +# granted to it by virtue of its status as an Intergovernmental Organization +# or submit itself to any jurisdiction. + +o2_add_library(ECalSimulation + SOURCES src/Detector.cxx + PUBLIC_LINK_LIBRARIES O2::ECalBase + O2::ITSMFTSimulation) + +o2_target_root_dictionary(ECalSimulation + HEADERS include/ECalSimulation/Detector.h) \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/simulation/include/ECalSimulation/Detector.h b/Detectors/Upgrades/ALICE3/ECal/simulation/include/ECalSimulation/Detector.h new file mode 100644 index 0000000000000..54e715224f728 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/simulation/include/ECalSimulation/Detector.h @@ -0,0 +1,105 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. +// +// Design and equations: Nicola Nicassio nicola.nicassio@cern.ch +// + +#ifndef ALICEO2_ECAL_DETECTOR_H +#define ALICEO2_ECAL_DETECTOR_H + +#include "DetectorsBase/Detector.h" +#include "ITSMFTSimulation/Hit.h" + +#include "ECalBase/GeometryTGeo.h" + +#include +#include + +namespace o2 +{ +namespace ecal +{ + +class Detector : public o2::base::DetImpl +{ + public: + Detector(bool active); + Detector(); + ~Detector(); + + void ConstructGeometry() override; + + o2::itsmft::Hit* addHit(int trackID, int detID, const TVector3& startPos, const TVector3& endPos, + const TVector3& startMom, double startE, double endTime, double eLoss, + unsigned char startStatus, unsigned char endStatus); + + // Mandatory overrides + void BeginPrimary() override { ; } + void FinishPrimary() override { ; } + void InitializeO2Detector() override; + void PostTrack() override { ; } + void PreTrack() override { ; } + bool ProcessHits(FairVolume* v = nullptr) override; + void EndOfEvent() override; + void Register() override; + void Reset() override; + + // Custom memer functions + std::vector* getHits(int iColl) const + { + if (!iColl) { + return mHits; + } + return nullptr; + } + + void createMaterials(); + void createGeometry(); + + private: + // Transient data about track passing the sensor + struct TrackData { + bool mHitStarted; // hit creation started + unsigned char mTrkStatusStart; // track status flag + TLorentzVector mPositionStart; // position at entrance + TLorentzVector mMomentumStart; // momentum + double mEnergyLoss; // energy loss + } mTrackData; //! transient data + + GeometryTGeo* mGeometryTGeo; //! + std::vector* mHits; // ITSMFT ones for the moment + + void defineSensitiveVolumes(); + float mInnerRadius; + float mOuterRadius; + float mLength; + + protected: + template + friend class o2::base::DetImpl; + ClassDefOverride(Detector, 1); +}; +} // namespace ecal +} // namespace o2 + +#ifdef USESHM +namespace o2 +{ +namespace base +{ +template <> +struct UseShm { + static constexpr bool value = true; +}; +} // namespace base +} // namespace o2 +#endif +#endif \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/simulation/src/Detector.cxx b/Detectors/Upgrades/ALICE3/ECal/simulation/src/Detector.cxx new file mode 100644 index 0000000000000..587dd4053b777 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/simulation/src/Detector.cxx @@ -0,0 +1,234 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#include + +#include +#include +#include +#include +#include + +#include "DetectorsBase/Stack.h" +#include "ITSMFTSimulation/Hit.h" +#include "ECalSimulation/Detector.h" +#include "ECalBase/ECalBaseParam.h" + +using o2::itsmft::Hit; + +namespace o2 +{ +namespace ecal +{ + +Detector::Detector() + : o2::base::DetImpl("ECL", true), + mTrackData(), + mHits(o2::utils::createSimVector()) +{ +} + +Detector::Detector(bool active) + : o2::base::DetImpl("ECL", true), + mTrackData(), + mHits(o2::utils::createSimVector()) +{ + auto& ecalPars = ECalBaseParam::Instance(); + mInnerRadius = ecalPars.rMin; + mOuterRadius = ecalPars.rMax; + mLength = ecalPars.zLength; +} + +Detector::~Detector() +{ + if (mHits) { + o2::utils::freeSimVector(mHits); + } +} + +void Detector::ConstructGeometry() +{ + createMaterials(); + createGeometry(); +} + +void Detector::createMaterials() +{ + int ifield = 2; // ? + float fieldm = 10.0; // ? + o2::base::Detector::initFieldTrackingParams(ifield, fieldm); + + float tmaxfdLead = 0.1; // .10000E+01; // Degree + float stemaxLead = .10000E+01; // cm + float deemaxLead = 0.1; // 0.30000E-02; // Fraction of particle's energy 0RegisterAny(addNameTo("Hit").data(), mHits, true); + } +} + +void Detector::createGeometry() +{ + LOGP(info, "Creating ECal geometry"); + + TGeoManager* geoManager = gGeoManager; + TGeoVolume* vALIC = geoManager->GetVolume("barrel"); + if (!vALIC) { + LOGP(fatal, "Could not find barrel volume while constructing ECal geometry"); + } + new TGeoVolumeAssembly(GeometryTGeo::getECalVolPattern()); + TGeoVolume* vECal = geoManager->GetVolume(GeometryTGeo::getECalVolPattern()); + vALIC->AddNode(vECal, 2, new TGeoTranslation(0, 30., 0)); + + char vstrng[100] = "ECalVol"; + vECal->SetTitle(vstrng); + + // Build the ECal cylinder + auto& matmgr = o2::base::MaterialManager::Instance(); + TGeoMedium* medPb = matmgr.getTGeoMedium("ECL_LEAD"); + TGeoTube* ecalShape = new TGeoTube("ECLsh", mInnerRadius, mOuterRadius, mLength); + TGeoVolume* ecalVol = new TGeoVolume("ECL", ecalShape, medPb); + ecalVol->SetLineColor(kCyan + 1); + ecalVol->SetTransparency(50); + vECal->AddNode(ecalVol, 1, nullptr); +} + +void Detector::Reset() +{ + if (!o2::utils::ShmManager::Instance().isOperational()) { + mHits->clear(); + } +} + +bool Detector::ProcessHits(FairVolume* vol) +{ + // This method is called from the MC stepping + if (!(fMC->TrackCharge())) { + return false; + } + + int lay = vol->getVolumeId(); + int volID = vol->getMCid(); + + // Is it needed to keep a track reference when the outer ITS volume is encountered? + auto stack = (o2::data::Stack*)fMC->GetStack(); + if (fMC->IsTrackExiting() && (lay == 0)) { + o2::TrackReference tr(*fMC, GetDetId()); + tr.setTrackID(stack->GetCurrentTrackNumber()); + tr.setUserId(lay); + stack->addTrackReference(tr); + } + bool startHit = false, stopHit = false; + unsigned char status = 0; + if (fMC->IsTrackEntering()) { + status |= Hit::kTrackEntering; + } + if (fMC->IsTrackInside()) { + status |= Hit::kTrackInside; + } + if (fMC->IsTrackExiting()) { + status |= Hit::kTrackExiting; + } + if (fMC->IsTrackOut()) { + status |= Hit::kTrackOut; + } + if (fMC->IsTrackStop()) { + status |= Hit::kTrackStopped; + } + if (fMC->IsTrackAlive()) { + status |= Hit::kTrackAlive; + } + + // track is entering or created in the volume + if ((status & Hit::kTrackEntering) || (status & Hit::kTrackInside && !mTrackData.mHitStarted)) { + startHit = true; + } else if ((status & (Hit::kTrackExiting | Hit::kTrackOut | Hit::kTrackStopped))) { + stopHit = true; + } + + // increment energy loss at all steps except entrance + if (!startHit) { + mTrackData.mEnergyLoss += fMC->Edep(); + } + if (!(startHit | stopHit)) { + return false; // do noting + } + + if (startHit) { + mTrackData.mEnergyLoss = 0.; + fMC->TrackMomentum(mTrackData.mMomentumStart); + fMC->TrackPosition(mTrackData.mPositionStart); + mTrackData.mTrkStatusStart = status; + mTrackData.mHitStarted = true; + } + if (stopHit) { + TLorentzVector positionStop; + fMC->TrackPosition(positionStop); + // Retrieve the indices with the volume path + int stave(0), halfstave(0), chipinmodule(0), module; + fMC->CurrentVolOffID(1, chipinmodule); + fMC->CurrentVolOffID(2, module); + fMC->CurrentVolOffID(3, halfstave); + fMC->CurrentVolOffID(4, stave); + + Hit* p = addHit(stack->GetCurrentTrackNumber(), lay, mTrackData.mPositionStart.Vect(), positionStop.Vect(), + mTrackData.mMomentumStart.Vect(), mTrackData.mMomentumStart.E(), positionStop.T(), + mTrackData.mEnergyLoss, mTrackData.mTrkStatusStart, status); + // p->SetTotalEnergy(vmc->Etot()); + + // RS: not sure this is needed + // Increment number of Detector det points in TParticle + stack->addHit(GetDetId()); + } + + return true; +} + +o2::itsmft::Hit* Detector::addHit(int trackID, int detID, const TVector3& startPos, const TVector3& endPos, + const TVector3& startMom, double startE, double endTime, double eLoss, unsigned char startStatus, + unsigned char endStatus) +{ + mHits->emplace_back(trackID, detID, startPos, endPos, startMom, startE, endTime, eLoss, startStatus, endStatus); + return &(mHits->back()); +} + +} // namespace ecal +} // namespace o2 + +ClassImp(o2::ecal::Detector); \ No newline at end of file diff --git a/Detectors/Upgrades/ALICE3/ECal/simulation/src/ECalSimulationLinkDef.h b/Detectors/Upgrades/ALICE3/ECal/simulation/src/ECalSimulationLinkDef.h new file mode 100644 index 0000000000000..167342773f196 --- /dev/null +++ b/Detectors/Upgrades/ALICE3/ECal/simulation/src/ECalSimulationLinkDef.h @@ -0,0 +1,21 @@ +// Copyright 2019-2020 CERN and copyright holders of ALICE O2. +// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders. +// All rights not expressly granted are reserved. +// +// This software is distributed under the terms of the GNU General Public +// License v3 (GPL Version 3), copied verbatim in the file "COPYING". +// +// In applying this license CERN does not waive the privileges and immunities +// granted to it by virtue of its status as an Intergovernmental Organization +// or submit itself to any jurisdiction. + +#ifdef __CLING__ + +#pragma link off all globals; +#pragma link off all classes; +#pragma link off all functions; + +#pragma link C++ class o2::ecal::Detector + ; +#pragma link C++ class o2::base::DetImpl < o2::ecal::Detector> + ; + +#endif diff --git a/Detectors/Upgrades/ALICE3/Passive/include/Alice3DetectorsPassive/Magnet.h b/Detectors/Upgrades/ALICE3/Passive/include/Alice3DetectorsPassive/Magnet.h index 2a2ac011a6aaa..673e3ded075ac 100644 --- a/Detectors/Upgrades/ALICE3/Passive/include/Alice3DetectorsPassive/Magnet.h +++ b/Detectors/Upgrades/ALICE3/Passive/include/Alice3DetectorsPassive/Magnet.h @@ -35,11 +35,11 @@ class Alice3Magnet : public Alice3PassiveBase Alice3Magnet(const Alice3Magnet& orig); Alice3Magnet& operator=(const Alice3Magnet&); - float mInnerWrapInnerRadius{150.f}; // cm + float mInnerWrapInnerRadius{160.f}; // cm // Version including the Ecal according SD float mInnerWrapThickness{1.f}; // cm - float mCoilInnerRadius{170.f}; // cm + float mCoilInnerRadius{180.f}; // cm float mCoilThickness{0.3f}; // cm - float mRestMaterialRadius{170.3f}; // cm + float mRestMaterialRadius{180.3f}; // cm float mRestMaterialThickness{6.8f}; // cm float mOuterWrapInnerRadius{200.f}; // cm float mOuterWrapThickness{3.f}; // cm diff --git a/macro/CMakeLists.txt b/macro/CMakeLists.txt index de8c31a23c50f..8520031bcad73 100644 --- a/macro/CMakeLists.txt +++ b/macro/CMakeLists.txt @@ -111,7 +111,7 @@ o2_add_test_root_macro(analyzeOriginHits.C O2::DetectorsCommonDataFormats) if(ENABLE_UPGRADES) - set(upgradeTargets O2::Alice3DetectorsPassive O2::ITS3Simulation O2::TRKSimulation O2::FT3Simulation O2::FCTSimulation O2::IOTOFSimulation O2::RICHSimulation) + set(upgradeTargets O2::Alice3DetectorsPassive O2::ITS3Simulation O2::TRKSimulation O2::FT3Simulation O2::FCTSimulation O2::IOTOFSimulation O2::RICHSimulation O2::ECalSimulation) endif() o2_add_test_root_macro(build_geometry.C diff --git a/macro/build_geometry.C b/macro/build_geometry.C index ec959bfa00511..eb996d0482640 100644 --- a/macro/build_geometry.C +++ b/macro/build_geometry.C @@ -55,6 +55,7 @@ #include #include #include +#include #include #include #include @@ -250,6 +251,11 @@ void build_geometry(FairRunSim* run = nullptr) // ALICE 3 RICH addReadoutDetector(new o2::rich::Detector(isReadout("RCH"))); } + + if (isActivated("ECL")) { + // ALICE 3 ECAL + addReadoutDetector(new o2::ecal::Detector(isReadout("ECL"))); + } #endif if (isActivated("ITS")) { diff --git a/run/CMakeLists.txt b/run/CMakeLists.txt index 58e5d9e5af402..afaa7486ae013 100644 --- a/run/CMakeLists.txt +++ b/run/CMakeLists.txt @@ -44,6 +44,7 @@ target_link_libraries(allsim $<$:O2::FCTSimulation> $<$:O2::IOTOFSimulation> $<$:O2::RICHSimulation> + $<$:O2::ECalSimulation> O2::Generators) add_library(internal::allsim ALIAS allsim)