Project
Loading...
Searching...
No Matches
Pipe.cxx
Go to the documentation of this file.
1// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3// All rights not expressly granted are reserved.
4//
5// This software is distributed under the terms of the GNU General Public
6// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7//
8// In applying this license CERN does not waive the privileges and immunities
9// granted to it by virtue of its status as an Intergovernmental Organization
10// or submit itself to any jurisdiction.
11
15#include "TGeoTube.h"
16#include "TVirtualMC.h"
17#include "TGeoManager.h" // for TGeoManager, gGeoManager
18#include "TGeoMaterial.h" // for TGeoMaterial
19#include "TGeoMedium.h" // for TGeoMedium
20#include "TGeoVolume.h" // for TGeoVolume
21#include "TGeoCompositeShape.h" // for TGeoCompositeShape
22#include "TCanvas.h"
23// force availability of assert
24#ifdef NDEBUG
25#undef NDEBUG
26#endif
27#include <cassert>
28
29using namespace o2::passive;
30
33 const char* title,
34 float pipeRIn,
35 float pipeThickness,
36 float a3ipLength,
37 float vacuumVesselRIn,
38 float vacuumVesselThickness,
39 float vacuumVesselASideLength)
40 : Alice3PassiveBase{name, title},
41 mPipeRIn{pipeRIn},
42 mPipeThick{pipeThickness},
43 mA3IPLength{a3ipLength},
44 mVacuumVesselRIn{vacuumVesselRIn},
45 mVacuumVesselThick{vacuumVesselThickness},
46 mVacuumVesselASideLength{vacuumVesselASideLength}
47{
48}
49
50Alice3Pipe::~Alice3Pipe() = default;
51Alice3Pipe& Alice3Pipe::operator=(const Alice3Pipe& rhs)
52{
53 // self assignment
54 if (this == &rhs) {
55 return *this;
56 }
57
58 // base class assignment
59 Alice3PassiveBase::operator=(rhs);
60
61 return *this;
62}
63
65{
66 createMaterials();
67 //
68 // Class describing the beam Alice3Pipe geometry
69 //
70 // Rotation Matrices
71 //
72 const float kDegRad = TMath::Pi() / 180.;
73 // Rotation by 180 deg
74 TGeoRotation* rot180 = new TGeoRotation("rot180", 90., 180., 90., 90., 180., 0.);
75 TGeoRotation* rotyz = new TGeoRotation("rotyz", 90., 180., 0., 180., 90., 90.);
76 TGeoRotation* rotxz = new TGeoRotation("rotxz", 0., 0., 90., 90., 90., 180.);
77 //
78
79 //
80 // Media
82
83 const TGeoMedium* kMedBe = matmgr.getTGeoMedium("ALICE3_PIPE_BE");
84
85 // Top volume
86 TGeoVolume* top = gGeoManager->GetVolume("cave");
87 TGeoVolume* barrel = gGeoManager->GetVolume("barrel");
88 if (!barrel) {
89 LOG(fatal) << "Could not find the top volume";
90 }
91
92 // We split the naming of the parts if the beam pipe for ALICE 3 into parts
93 // - pipe A Side
94 // - pipe C Side (which hosts the primary vacuum vessel and covers all C Side as well)
95
96 // A3IP update
97 Double_t pipeASideLength = mA3IPLength / 2. - mVacuumVesselThick - mVacuumVesselASideLength / 2.;
98 Double_t pipeCSideLength = mA3IPLength / 2. + mVacuumVesselASideLength / 2.;
99
100 // Pipe tubes
101 TGeoTube* pipeASide = new TGeoTube("PIPE_Ash", mPipeRIn, mPipeRIn + mPipeThick, pipeASideLength / 2.);
102 TGeoTube* pipeCSide = new TGeoTube("PIPE_Csh", mVacuumVesselRIn, mVacuumVesselRIn + mVacuumVesselThick, pipeCSideLength / 2.);
103 TGeoTube* vacuumVesselWall = new TGeoTube("VACUUM_VESSEL_WALLsh", mPipeRIn, mVacuumVesselRIn + mVacuumVesselThick, mVacuumVesselThick / 2.);
104
105 // Pipe and vacuum vessel positions
106 TGeoTranslation* posPipeASide = new TGeoTranslation("PIPE_ASIDE_POSITION", 0, 0, mVacuumVesselASideLength / 2. + mVacuumVesselThick + pipeASideLength / 2.);
107 posPipeASide->RegisterYourself();
108 TGeoTranslation* posPipeCSide = new TGeoTranslation("PIPE_CSIDE_POSITION", 0, 0, mVacuumVesselASideLength / 2. - pipeCSideLength / 2.);
109 posPipeCSide->RegisterYourself();
110 TGeoTranslation* posVacuumVesselWall = new TGeoTranslation("WALL_POSITION", 0, 0, mVacuumVesselASideLength / 2. + mVacuumVesselThick / 2.);
111 posVacuumVesselWall->RegisterYourself();
112
113 // Pipe composite shape and volume
114 TString pipeCompositeFormula =
115 "PIPE_Ash:PIPE_ASIDE_POSITION"
116 "+PIPE_Csh:PIPE_CSIDE_POSITION"
117 "+VACUUM_VESSEL_WALLsh:WALL_POSITION";
118
119 TGeoCompositeShape* pipeComposite = new TGeoCompositeShape("A3IPsh", pipeCompositeFormula);
120 TGeoVolume* pipeVolume = new TGeoVolume("A3IP", pipeComposite, kMedBe);
121
122 // Add everything to the barrel
123 barrel->AddNode(pipeVolume, 1, new TGeoTranslation(0, 30.f, 0));
124
125 pipeVolume->SetLineColor(kGreen + 3);
126}
127
128void Alice3Pipe::createMaterials()
129{
130 //
131 // Define materials for beam Alice3Pipe
132 //
133 int isxfld = 2;
134 float sxmgmx = 10.;
136
137 // ****************
138 // Defines tracking media parameters.
139 //
140 float epsil = .1; // Tracking precision,
141 float stemax = -0.01; // Maximum displacement for multiple scat
142 float tmaxfd = -20.; // Maximum angle due to field deflection
143 float deemax = -.3; // Maximum fractional energy loss, DLS
144 float stmin = -.8;
145 // ***************
146
148
149 // Beryllium
150 matmgr.Material("ALICE3_PIPE", 5, "BERYLLIUM$", 9.01, 4., 1.848, 35.3, 36.7);
151 matmgr.Medium("ALICE3_PIPE", 5, "BE", 5, 0, isxfld, sxmgmx, tmaxfd, stemax, deemax, epsil, stmin);
152}
153
154// ----------------------------------------------------------------------------
155FairModule* Alice3Pipe::CloneModule() const { return new Alice3Pipe(*this); }
Definition of the Detector class.
ClassImp(IdPath)
static void initFieldTrackingParams(int &mode, float &maxfield)
Definition Detector.cxx:143
static MaterialManager & Instance()
a common base class for passive modules - implementing generic functions
Definition PassiveBase.h:24
FairModule * CloneModule() const override
Clone this object (used in MT mode only)
Definition Pipe.cxx:155
void ConstructGeometry() override
Definition Pipe.cxx:64
GLdouble GLdouble GLdouble GLdouble top
Definition glcorearb.h:4077
GLuint const GLchar * name
Definition glcorearb.h:781
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"