49 float aCer[2] = {26.981538, 15.9994};
50 float zCer[2] = {13., 8.};
51 float wCer[2] = {0.5294, 0.4706};
55 float aAir[4] = {12.0107, 14.0067, 15.9994, 39.948};
56 float zAir[4] = {6., 7., 8., 18.};
57 float wAir[4] = {0.000124, 0.755267, 0.231781, 0.012827};
58 float dAir = 1.20479E-3;
59 float dAir1 = 1.20479E-11;
62 float aWater[2] = {1.00794, 15.9994};
63 float zWater[2] = {1., 8.};
64 float wWater[2] = {0.111894, 0.888106};
68 float aSiO2[2] = {28.0855, 15.9990};
69 float zSiO2[2] = {14., 8.};
70 float wSiO2[2] = {0.467, 0.533};
74 float aPolyethylene[2] = {12.01, 1.};
75 float zPolyethylene[2] = {6., 1.};
76 float wPolyethylene[2] = {.33, .67};
79 int nPolyurethane = 4;
80 float aPolyurethane[4] = {1.00794, 14.010, 12.0107, 15.9994};
81 float zPolyurethane[4] = {1.0, 7.0, 6.0, 8.0};
82 float wPolyurethane[4] = {0.017077588, 0.237314387, 0.203327619, 0.542280405};
83 float dPolyurethane = 1.25;
88 float aAl5083[9] = {54.938, 55.845, 63.546, 24.305, 28.086, 65.38, 51.996, 47.867, 26.982};
89 float zAl5083[9] = {25., 26., 29., 12., 14., 30., 24., 22., 13.};
91 float wAl5083[9] = {0.007, 0.004, 0.001, 0.0445, 0.004, 0.0025, 0.0015, 0.0015, 0.934};
92 float dAl5083 = 2.650;
96 float aAlBeMet[2] = {26.982, 9.012};
97 float zAlBeMet[2] = {13., 4.};
98 float wAlBeMet[2] = {0.38, 0.62};
99 float dAlBeMet = 2.071;
101 matmgr.Mixture(
"ALICE3_TRKSERVICES", 66,
"CERAMIC", aCer, zCer, dCer, 2, wCer);
102 matmgr.Mixture(
"ALICE3_TRKSERVICES", 68,
"AIR", aAir, zAir, dAir, 4, wAir);
103 matmgr.Mixture(
"ALICE3_TRKSERVICES", 69,
"POLYETHYLENE", aPolyethylene, zPolyethylene, .95, 2, wPolyethylene);
104 matmgr.Mixture(
"ALICE3_TRKSERVICES", 70,
"POLYURETHANE", aPolyurethane, zPolyurethane, dPolyurethane, nPolyurethane, wPolyurethane);
105 matmgr.Mixture(
"ALICE3_TRKSERVICES", 71,
"SILICONDIOXIDE", aSiO2, zSiO2, dSiO2, 2, wSiO2);
106 matmgr.Mixture(
"ALICE3_TRKSERVICES", 72,
"WATER", aWater, zWater, dWater, 2, wWater);
107 matmgr.Material(
"ALICE3_TRKSERVICES", 67,
"COPPER", 63.546, 29, 8.96, 1.43, 15.1);
108 matmgr.Material(
"ALICE3_TRKSERVICES", 73,
"BERYLLIUM", 9.01, 4., 1.848, 35.3, 36.7);
109 matmgr.Mixture(
"ALICE3_TRKSERVICES", 74,
"ALUMINIUM5083", aAl5083, zAl5083, dAl5083, 9, wAl5083);
110 matmgr.Mixture(
"ALICE3_TRKSERVICES", 75,
"ALUMINIUMBERYLLIUMMETAL", aAlBeMet, zAlBeMet, dAlBeMet, 2, wAlBeMet);
111 matmgr.Material(
"ALICE3_TRKSERVICES", 76,
"CARBONFIBERM55J6K", 12.0107, 6, 1.92, 22.4, 999);
112 matmgr.Mixture(
"ALICE3_PIPE", 77,
"VACUUM", aAir, zAir, dAir1, 4, wAir);
114 matmgr.Medium(
"ALICE3_TRKSERVICES", 1,
"CERAMIC", 66, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
115 matmgr.Medium(
"ALICE3_TRKSERVICES", 2,
"COPPER", 67, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
116 matmgr.Medium(
"ALICE3_TRKSERVICES", 3,
"AIR", 68, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
117 matmgr.Medium(
"ALICE3_TRKSERVICES", 4,
"POLYETHYLENE", 69, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
118 matmgr.Medium(
"ALICE3_TRKSERVICES", 5,
"POLYURETHANE", 70, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
119 matmgr.Medium(
"ALICE3_TRKSERVICES", 6,
"SILICONDIOXIDE", 71, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
120 matmgr.Medium(
"ALICE3_TRKSERVICES", 7,
"WATER", 72, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
121 matmgr.Medium(
"ALICE3_TRKSERVICES", 8,
"BERYLLIUM", 73, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
122 matmgr.Medium(
"ALICE3_TRKSERVICES", 9,
"ALUMINIUM5083", 74, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
123 matmgr.Medium(
"ALICE3_TRKSERVICES", 10,
"ALUMINIUMBERYLLIUMMETAL", 75, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
124 matmgr.Medium(
"ALICE3_TRKSERVICES", 11,
"CARBONFIBERM55J6K", 76, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
125 matmgr.Medium(
"ALICE3_PIPE", 12,
"VACUUM", 77, 0, ifield, fieldm, tmaxfd, stemax, deemax, epsil, stmin);
201 TGeoMedium* medSiO2 = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_SILICONDIOXIDE");
202 TGeoMedium* medPE = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYETHYLENE");
203 TGeoMedium* medCu = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_COPPER");
204 TGeoMedium* medPU = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYURETHANE");
205 TGeoMedium* medH2O = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_WATER");
207 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
209 float siO2FiberThick = 0.5 * 0.212;
210 float peFiberThick = 0.5 * 0.212;
212 float rMinInnerServices = 68.5f;
213 float zLengthInnerServices = 201.f;
214 float translation = (
int)orientation * (149.f + zLengthInnerServices / 2);
216 TGeoTube* outerDisksFiberSIO2 =
new TGeoTube(
"TRK_OUTERDISKS_FIBER_SIO2sh", rMinInnerServices, rMinInnerServices + siO2FiberThick, zLengthInnerServices / 2);
217 TGeoTube* outerDisksFiberPE =
new TGeoTube(
"TRK_OUTERDISKS_FIBER_PEsh", rMinInnerServices + siO2FiberThick, rMinInnerServices + siO2FiberThick + peFiberThick, zLengthInnerServices / 2);
218 rMinInnerServices += siO2FiberThick + peFiberThick;
219 TGeoVolume* outerDisksFiberSIO2Volume =
new TGeoVolume(
"TRK_OUTERDISKS_FIBER_SIO2", outerDisksFiberSIO2, medSiO2);
220 TGeoVolume* outerDisksFiberPEVolume =
new TGeoVolume(
"TRK_OUTERDISKS_FIBER_PE", outerDisksFiberPE, medPE);
221 outerDisksFiberSIO2Volume->SetLineColor(kGray);
222 outerDisksFiberPEVolume->SetLineColor(kGray);
223 auto* combiTrans =
new TGeoCombiTrans(0, 0, translation,
nullptr);
224 motherVolume->AddNode(outerDisksFiberSIO2Volume, 1, combiTrans);
225 motherVolume->AddNode(outerDisksFiberPEVolume, 1, combiTrans);
228 float cuPowerThick = 0.09 * 1.186;
229 float pePowerThick = 0.91 * 1.186;
231 TGeoTube* outerDisksPowerCu =
new TGeoTube(
"TRK_OUTERDISKS_POWER_CUsh", rMinInnerServices, rMinInnerServices + cuPowerThick, zLengthInnerServices / 2);
232 TGeoTube* outerDisksPowerPE =
new TGeoTube(
"TRK_OUTERDISKS_POWER_PEsh", rMinInnerServices + cuPowerThick, rMinInnerServices + cuPowerThick + pePowerThick, zLengthInnerServices / 2);
233 rMinInnerServices += cuPowerThick + pePowerThick;
234 TGeoVolume* outerDisksPowerCuVolume =
new TGeoVolume(
"TRK_OUTERDISKS_POWER_CU", outerDisksPowerCu, medCu);
235 TGeoVolume* outerDisksPowerPEVolume =
new TGeoVolume(
"TRK_OUTERDISKS_POWER_PE", outerDisksPowerPE, medPE);
236 outerDisksPowerCuVolume->SetLineColor(kGray);
237 outerDisksPowerPEVolume->SetLineColor(kGray);
238 motherVolume->AddNode(outerDisksPowerCuVolume, 1, combiTrans);
239 motherVolume->AddNode(outerDisksPowerPEVolume, 1, combiTrans);
242 float puCoolingThick = 0.56 * 0.647;
243 float h2oCoolingThick = 0.44 * 0.647;
245 TGeoTube* outerDisksCoolingPU =
new TGeoTube(
"TRK_OUTERDISKS_COOLING_PUsh", rMinInnerServices, rMinInnerServices + puCoolingThick, zLengthInnerServices / 2);
246 TGeoTube* outerDisksCoolingH2O =
new TGeoTube(
"TRK_OUTERDISKS_COOLING_H2Osh", rMinInnerServices + puCoolingThick, rMinInnerServices + puCoolingThick + h2oCoolingThick, zLengthInnerServices / 2);
248 TGeoVolume* outerDisksCoolingPUVolume =
new TGeoVolume(
"TRK_OUTERDISKS_COOLING_PU", outerDisksCoolingPU, medPU);
249 TGeoVolume* outerDisksCoolingH2OVolume =
new TGeoVolume(
"TRK_OUTERDISKS_COOLING_H2O", outerDisksCoolingH2O, medH2O);
250 outerDisksCoolingPUVolume->SetLineColor(kGray);
251 outerDisksCoolingH2OVolume->SetLineColor(kGray);
252 motherVolume->AddNode(outerDisksCoolingPUVolume, 1, combiTrans);
253 motherVolume->AddNode(outerDisksCoolingH2OVolume, 1, combiTrans);
262 TGeoMedium* medSiO2 = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_SILICONDIOXIDE");
263 TGeoMedium* medPE = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYETHYLENE");
264 TGeoMedium* medCu = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_COPPER");
265 TGeoMedium* medPU = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYURETHANE");
266 TGeoMedium* medH2O = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_WATER");
267 TGeoMedium* medCFiber = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_CARBONFIBERM55J6K");
270 float siO2FiberThick = 0.5 * 0.307;
271 float peFiberThick = 0.5 * 0.307;
272 float puCoolingThick = 0.56 * 0.474;
273 float h2oCoolingThick = 0.44 * 0.474;
274 float cuPowerThick = 0.09 * 1.09;
275 float pePowerThick = 0.91 * 1.09;
276 const float totalThickness = siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick + h2oCoolingThick;
279 float rMinMiddleCarbonSupport = 34.8f;
280 float rMaxMiddleCarbonSupport = 35.f;
281 const float zLengthMiddleCarbon = 129.f;
282 TGeoTube* middleBarrelCarbonSupport =
new TGeoTube(
"TRK_MID_CARBONSUPPORTsh", rMinMiddleCarbonSupport, rMaxMiddleCarbonSupport, zLengthMiddleCarbon / 2.);
283 TGeoVolume* middleBarrelCarbonSupportVolume =
new TGeoVolume(
"TRK_MID_CARBONSUPPORT", middleBarrelCarbonSupport, medCFiber);
284 middleBarrelCarbonSupportVolume->SetLineColor(kGray);
285 LOGP(info,
"Creating carbon fiber support for Middle Tracker");
286 motherVolume->AddNode(middleBarrelCarbonSupportVolume, 1,
nullptr);
289 float rMinMiddleServices = 35.f;
290 float rMinMiddleBarrel = rMinMiddleServices;
291 const float zLengthCylinderMiddleServices = 40.5f;
292 const float zLengthMiddleServices = 143.f;
293 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
294 rMinMiddleServices = 35.f;
295 LOGP(info,
"Building services for Middle Tracker rminMiddleServices");
296 TGeoTube* middleBarrelFiberSIO2 =
new TGeoTube(Form(
"TRK_MID_FIBER_SIO2sh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + siO2FiberThick, zLengthCylinderMiddleServices );
297 rMinMiddleServices += siO2FiberThick;
298 TGeoTube* middleBarrelFiberPE =
new TGeoTube(Form(
"TRK_MID_FIBER_PEsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + peFiberThick, zLengthCylinderMiddleServices );
299 rMinMiddleServices += peFiberThick;
300 TGeoVolume* middleBarrelFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_MID_FIBER_SIO2_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelFiberSIO2, medSiO2);
301 TGeoVolume* middleBarrelFiberPEVolume =
new TGeoVolume(Form(
"TRK_MID_FIBER_PE_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelFiberPE, medPE);
302 middleBarrelFiberSIO2Volume->SetLineColor(kGray);
303 middleBarrelFiberPEVolume->SetLineColor(kGray);
304 auto* combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zLengthMiddleServices - zLengthCylinderMiddleServices),
nullptr);
305 motherVolume->AddNode(middleBarrelFiberSIO2Volume, 1, combiTrans);
306 motherVolume->AddNode(middleBarrelFiberPEVolume, 1, combiTrans);
309 TGeoTube* middleBarrelPowerCu =
new TGeoTube(Form(
"TRK_MID_POWER_CUsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + cuPowerThick, zLengthCylinderMiddleServices );
310 rMinMiddleServices += cuPowerThick;
311 TGeoTube* middleBarrelPowerPE =
new TGeoTube(Form(
"TRK_MID_POWER_PEsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + pePowerThick, zLengthCylinderMiddleServices );
312 rMinMiddleServices += pePowerThick;
313 TGeoVolume* middleBarrelPowerCuVolume =
new TGeoVolume(Form(
"TRK_MID_POWER_CU_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelPowerCu, medCu);
314 TGeoVolume* middleBarrelPowerPEVolume =
new TGeoVolume(Form(
"TRK_MID_POWER_PE_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelPowerPE, medPE);
315 middleBarrelPowerCuVolume->SetLineColor(kGray);
316 middleBarrelPowerPEVolume->SetLineColor(kGray);
317 motherVolume->AddNode(middleBarrelPowerCuVolume, 1, combiTrans);
318 motherVolume->AddNode(middleBarrelPowerPEVolume, 1, combiTrans);
321 TGeoTube* middleBarrelCoolingPU =
new TGeoTube(Form(
"TRK_MID_COOLING_PUsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + puCoolingThick, zLengthCylinderMiddleServices );
322 rMinMiddleServices += puCoolingThick;
323 TGeoTube* middleBarrelCoolingH2O =
new TGeoTube(Form(
"TRK_MID_COOLING_H2Osh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleServices, rMinMiddleServices + h2oCoolingThick, zLengthCylinderMiddleServices );
324 rMinMiddleServices = rMinMiddleServices += h2oCoolingThick;
325 TGeoVolume* middleBarrelCoolingPUVolume =
new TGeoVolume(Form(
"TRK_MID_COOLING_PU_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelCoolingPU, medPU);
326 TGeoVolume* middleBarrelCoolingH2OVolume =
new TGeoVolume(Form(
"TRK_MID_COOLING_H2O_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelCoolingH2O, medH2O);
327 middleBarrelCoolingPUVolume->SetLineColor(kGray);
328 middleBarrelCoolingH2OVolume->SetLineColor(kGray);
329 motherVolume->AddNode(middleBarrelCoolingPUVolume, 1, combiTrans);
330 motherVolume->AddNode(middleBarrelCoolingH2OVolume, 1, combiTrans);
333 const float rMinMiddleBarrelDisk = 5.68f;
334 const float rMaxMiddleBarrelDisk = 35.f;
335 const float zLengthMiddleBarrel = 64.5f;
336 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
337 TGeoTube* middleBarrelConnDiskSIO2 =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_FIBER_SIO2sh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, siO2FiberThick / 2.);
338 TGeoTube* middleBarrelConnDiskPE =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_FIBER_PEsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, peFiberThick / 2.);
339 TGeoVolume* middleBarrelConnDiskSIO2Volume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_FIBER_SIO2_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskSIO2, medSiO2);
340 TGeoVolume* middleBarrelConnDiskPEVolume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_FIBER_PE_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskPE, medPE);
341 middleBarrelConnDiskSIO2Volume->SetLineColor(kGray);
342 middleBarrelConnDiskPEVolume->SetLineColor(kGray);
343 auto* rot =
new TGeoRotation(
"", 0, 0, 180);
344 auto* combiTransSIO2 =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick / 2. + zLengthMiddleBarrel), rot);
345 auto* combiTransPE =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick / 2. + zLengthMiddleBarrel), rot);
346 motherVolume->AddNode(middleBarrelConnDiskSIO2Volume, 1, combiTransSIO2);
347 motherVolume->AddNode(middleBarrelConnDiskPEVolume, 1, combiTransPE);
349 TGeoTube* middleBarrelConnDiskCu =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_POWER_CUsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, cuPowerThick / 2.);
350 TGeoTube* middleBarrelConnDiskPEPower =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_POWER_PEsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, pePowerThick / 2.);
351 TGeoVolume* middleBarrelConnDiskCuVolume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_POWER_CU_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskCu, medCu);
352 TGeoVolume* middleBarrelConnDiskPEPowerVolume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_POWER_PE_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskPEPower, medPE);
353 middleBarrelConnDiskCuVolume->SetLineColor(kGray);
354 middleBarrelConnDiskPEPowerVolume->SetLineColor(kGray);
355 auto* combiTransCu =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick / 2. + zLengthMiddleBarrel), rot);
356 auto* combiTransPEPower =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick / 2. + zLengthMiddleBarrel), rot);
357 motherVolume->AddNode(middleBarrelConnDiskCuVolume, 1, combiTransCu);
358 motherVolume->AddNode(middleBarrelConnDiskPEPowerVolume, 1, combiTransPEPower);
360 TGeoTube* middleBarrelConnDiskPU =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_PUsh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, puCoolingThick / 2.);
361 TGeoTube* middleBarrelConnDiskH2O =
new TGeoTube(Form(
"TRK_MIDBARCONN_DISK_H2Osh_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, h2oCoolingThick / 2.);
362 TGeoVolume* middleBarrelConnDiskPUVolume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_PU_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskPU, medPU);
363 TGeoVolume* middleBarrelConnDiskH2OVolume =
new TGeoVolume(Form(
"TRK_MIDBARCONN_DISK_H2O_%s", orientation == Orientation::kASide ?
"bwd" :
"fwd"), middleBarrelConnDiskH2O, medH2O);
364 middleBarrelConnDiskPUVolume->SetLineColor(kGray);
365 middleBarrelConnDiskH2OVolume->SetLineColor(kGray);
366 auto* combiTransPU =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick / 2. + zLengthMiddleBarrel), rot);
367 auto* combiTransH2O =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick + h2oCoolingThick / 2. + zLengthMiddleBarrel), rot);
368 motherVolume->AddNode(middleBarrelConnDiskPUVolume, 1, combiTransPU);
369 motherVolume->AddNode(middleBarrelConnDiskH2OVolume, 1, combiTransH2O);
373 float rMaxMiddleServicesBarFwd = 74.5f + siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick + h2oCoolingThick;
374 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
376 TGeoTube* middleBarFwdFiberSIO2 =
new TGeoTube(
"TRK_MIDBARFWD_FIBER_SIO2sh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, siO2FiberThick / 2.);
377 TGeoTube* middleBarFwdFiberPE =
new TGeoTube(
"TRK_MIDBARFWD_FIBER_PEsh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, peFiberThick / 2.);
378 TGeoVolume* middleBarFwdFiberSIO2Volume =
new TGeoVolume(
"TRK_MIDBARFWD_FIBER_SIO2", middleBarFwdFiberSIO2, medSiO2);
379 TGeoVolume* middleBarFwdFiberPEVolume =
new TGeoVolume(
"TRK_MIDBARFWD_FIBER_PE", middleBarFwdFiberPE, medPE);
380 middleBarFwdFiberSIO2Volume->SetLineColor(kGray);
381 middleBarFwdFiberPEVolume->SetLineColor(kGray);
382 auto* rot =
new TGeoRotation(
"", 0, 0, 180);
383 auto* combiTransSIO2 =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick / 2. + zLengthMiddleServices), rot);
384 auto* combiTransPE =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick / 2. + zLengthMiddleServices), rot);
385 motherVolume->AddNode(middleBarFwdFiberSIO2Volume, 1, combiTransSIO2);
386 motherVolume->AddNode(middleBarFwdFiberPEVolume, 1, combiTransPE);
389 TGeoTube* middleBarFwdPowerCu =
new TGeoTube(
"TRK_MIDBARFWD_POWER_CUsh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, cuPowerThick / 2.);
390 TGeoTube* middleBarFwdPowerPE =
new TGeoTube(
"TRK_MIDBARFWD_POWER_PEsh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, pePowerThick / 2.);
391 TGeoVolume* middleBarFwdPowerCuVolume =
new TGeoVolume(
"TRK_MIDBARFWD_POWER_CU", middleBarFwdPowerCu, medCu);
392 TGeoVolume* middleBarFwdPowerPEVolume =
new TGeoVolume(
"TRK_MIDBARFWD_POWER_PE", middleBarFwdPowerPE, medPE);
393 middleBarFwdPowerCuVolume->SetLineColor(kGray);
394 middleBarFwdPowerPEVolume->SetLineColor(kGray);
395 auto* combiTransCu =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick / 2. + zLengthMiddleServices), rot);
396 auto* combiTransPEPower =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick / 2. + zLengthMiddleServices), rot);
397 motherVolume->AddNode(middleBarFwdPowerCuVolume, 1, combiTransCu);
398 motherVolume->AddNode(middleBarFwdPowerPEVolume, 1, combiTransPEPower);
401 TGeoTube* middleBarFwdCoolingPU =
new TGeoTube(
"TRK_MIDBARFWD_COOLING_PUsh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, puCoolingThick / 2.);
402 TGeoTube* middleBarFwdCoolingH2O =
new TGeoTube(
"TRK_MIDBARFWD_COOLING_H2Osh", rMinMiddleBarrel, rMaxMiddleServicesBarFwd, h2oCoolingThick / 2.);
403 TGeoVolume* middleBarFwdCoolingPUVolume =
new TGeoVolume(
"TRK_MIDBARFWD_COOLING_PU", middleBarFwdCoolingPU, medPU);
404 TGeoVolume* middleBarFwdCoolingH2OVolume =
new TGeoVolume(
"TRK_MIDBARFWD_COOLING_H2O", middleBarFwdCoolingH2O, medH2O);
405 middleBarFwdCoolingPUVolume->SetLineColor(kGray);
406 middleBarFwdCoolingH2OVolume->SetLineColor(kGray);
407 auto* combiTransCoolingPU =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick / 2. + zLengthMiddleServices), rot);
408 auto* combiTransCoolingH2O =
new TGeoCombiTrans(0, 0, (
int)orientation * (siO2FiberThick + peFiberThick + cuPowerThick + pePowerThick + puCoolingThick + h2oCoolingThick / 2. + zLengthMiddleServices), rot);
409 motherVolume->AddNode(middleBarFwdCoolingPUVolume, 1, combiTransCoolingPU);
410 motherVolume->AddNode(middleBarFwdCoolingH2OVolume, 1, combiTransCoolingH2O);
414 const float zLengthMiddleServicesFwd = 350.f - (143.f + totalThickness);
416 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
418 float siO2FiberThick = 0.5 * 0.307;
419 float peFiberThick = 0.5 * 0.307;
420 float rMinMiddleServicesFwd = 74.5f;
422 float translation = (
int)orientation * (143.f + totalThickness + zLengthMiddleServicesFwd / 2);
424 TGeoTube* middleFwdFiberSIO2 =
new TGeoTube(
"TRK_MIDFWD_FIBER_SIO2sh", rMinMiddleServicesFwd, rMinMiddleServicesFwd + siO2FiberThick, zLengthMiddleServicesFwd / 2);
425 TGeoTube* middleFwdFiberPE =
new TGeoTube(
"TRK_MIDFWD_FIBER_PEsh", rMinMiddleServicesFwd + siO2FiberThick, rMinMiddleServicesFwd + siO2FiberThick + peFiberThick, zLengthMiddleServicesFwd / 2);
426 rMinMiddleServicesFwd += siO2FiberThick + peFiberThick;
427 TGeoVolume* middleFwdFiberSIO2Volume =
new TGeoVolume(
"TRK_MIDFWD_FIBER_SIO2", middleFwdFiberSIO2, medSiO2);
428 TGeoVolume* middleFwdFiberPEVolume =
new TGeoVolume(
"TRK_MIDFWD_FIBER_PE", middleFwdFiberPE, medPE);
429 middleFwdFiberSIO2Volume->SetLineColor(kGray);
430 middleFwdFiberPEVolume->SetLineColor(kGray);
431 auto* combiTrans =
new TGeoCombiTrans(0, 0, translation,
nullptr);
432 motherVolume->AddNode(middleFwdFiberSIO2Volume, 1, combiTrans);
433 motherVolume->AddNode(middleFwdFiberPEVolume, 1, combiTrans);
436 float cuPowerThick = 0.09 * 1.09;
437 float pePowerThick = 0.91 * 1.09;
439 TGeoTube* middleFwdPowerCu =
new TGeoTube(
"TRK_MIDFWD_POWER_CUsh", rMinMiddleServicesFwd, rMinMiddleServicesFwd + cuPowerThick, zLengthMiddleServicesFwd / 2);
440 TGeoTube* middleFwdPowerPE =
new TGeoTube(
"TRK_MIDFWD_POWER_PEsh", rMinMiddleServicesFwd + cuPowerThick, rMinMiddleServicesFwd + cuPowerThick + pePowerThick, zLengthMiddleServicesFwd / 2);
441 rMinMiddleServicesFwd += cuPowerThick + pePowerThick;
442 TGeoVolume* middleFwdPowerCuVolume =
new TGeoVolume(
"TRK_MIDFWD_POWER_CU", middleFwdPowerCu, medCu);
443 TGeoVolume* middleFwdPowerPEVolume =
new TGeoVolume(
"TRK_MIDFWD_POWER_PE", middleFwdPowerPE, medPE);
444 middleFwdPowerCuVolume->SetLineColor(kGray);
445 middleFwdPowerPEVolume->SetLineColor(kGray);
446 motherVolume->AddNode(middleFwdPowerCuVolume, 1, combiTrans);
447 motherVolume->AddNode(middleFwdPowerPEVolume, 1, combiTrans);
450 float puCoolingThick = 0.56 * 0.474;
451 float h2oCoolingThick = 0.44 * 0.474;
453 TGeoTube* middleFwdCoolingPU =
new TGeoTube(
"TRK_MIDFWD_COOLING_PUsh", rMinMiddleServicesFwd, rMinMiddleServicesFwd + puCoolingThick, zLengthMiddleServicesFwd / 2);
454 TGeoTube* middleFwdCoolingH2O =
new TGeoTube(
"TRK_MIDFWD_COOLING_H2Osh", rMinMiddleServicesFwd + puCoolingThick, rMinMiddleServicesFwd + puCoolingThick + h2oCoolingThick, zLengthMiddleServicesFwd / 2);
456 TGeoVolume* middleFwdCoolingPUVolume =
new TGeoVolume(
"TRK_MIDFWD_COOLING_PU", middleFwdCoolingPU, medPU);
457 TGeoVolume* middleFwdCoolingH2OVolume =
new TGeoVolume(
"TRK_MIDFWD_COOLING_H2O", middleFwdCoolingH2O, medH2O);
458 middleFwdCoolingPUVolume->SetLineColor(kGray);
459 middleFwdCoolingH2OVolume->SetLineColor(kGray);
460 motherVolume->AddNode(middleFwdCoolingPUVolume, 1, combiTrans);
461 motherVolume->AddNode(middleFwdCoolingH2OVolume, 1, combiTrans);
473 TGeoMedium* medSiO2 = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_SILICONDIOXIDE");
474 TGeoMedium* medPE = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYETHYLENE");
475 TGeoMedium* medCu = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_COPPER");
476 TGeoMedium* medPU = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYURETHANE");
477 TGeoMedium* medH2O = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_WATER");
480 const float siO2FiberThick = 0.5 * 0.269;
481 const float peFiberThick = 0.5 * 0.269;
483 const float zLengthOuterBarrelServices = 350.f;
485 TGeoTube* outerBarrelFiberSIO2 =
new TGeoTube(
"TRK_OUTERBARREL_FIBER_SIO2sh", rMinOuterBarrelServices, rMinOuterBarrelServices + siO2FiberThick, zLengthOuterBarrelServices);
486 TGeoTube* outerBarrelFiberPE =
new TGeoTube(
"TRK_OUTERBARREL_FIBER_PEsh", rMinOuterBarrelServices + siO2FiberThick, rMinOuterBarrelServices + siO2FiberThick + peFiberThick, zLengthOuterBarrelServices);
487 rMinOuterBarrelServices += siO2FiberThick + peFiberThick;
488 TGeoVolume* outerBarrelFiberSIO2Volume =
new TGeoVolume(
"TRK_OUTERBARREL_FIBER_SIO2", outerBarrelFiberSIO2, medSiO2);
489 TGeoVolume* outerBarrelFiberPEVolume =
new TGeoVolume(
"TRK_OUTERBARREL_FIBER_PE", outerBarrelFiberPE, medPE);
490 outerBarrelFiberSIO2Volume->SetLineColor(kGray);
491 outerBarrelFiberPEVolume->SetLineColor(kGray);
492 motherVolume->AddNode(outerBarrelFiberSIO2Volume, 1,
nullptr);
493 motherVolume->AddNode(outerBarrelFiberPEVolume, 1,
nullptr);
496 const float cuPowerThick = 0.09 * 0.430;
497 const float pePowerThick = 0.91 * 0.430;
499 TGeoTube* outerBarrelPowerCu =
new TGeoTube(
"TRK_OUTERBARREL_POWER_CUsh", rMinOuterBarrelServices, rMinOuterBarrelServices + cuPowerThick, zLengthOuterBarrelServices);
500 TGeoTube* outerBarrelPowerPE =
new TGeoTube(
"TRK_OUTERBARREL_POWER_PEsh", rMinOuterBarrelServices + cuPowerThick, rMinOuterBarrelServices + cuPowerThick + pePowerThick, zLengthOuterBarrelServices);
501 rMinOuterBarrelServices += cuPowerThick + pePowerThick;
502 TGeoVolume* outerBarrelPowerCuVolume =
new TGeoVolume(
"TRK_OUTERBARREL_POWER_CU", outerBarrelPowerCu, medCu);
503 TGeoVolume* outerBarrelPowerPEVolume =
new TGeoVolume(
"TRK_OUTERBARREL_POWER_PE", outerBarrelPowerPE, medPE);
504 outerBarrelPowerCuVolume->SetLineColor(kGray);
505 outerBarrelPowerPEVolume->SetLineColor(kGray);
506 motherVolume->AddNode(outerBarrelPowerCuVolume, 1,
nullptr);
507 motherVolume->AddNode(outerBarrelPowerPEVolume, 1,
nullptr);
510 const float puCoolingThick = 0.56 * 1.432;
511 const float h2oCoolingThick = 0.44 * 1.432;
513 TGeoTube* outerBarrelCoolingPU =
new TGeoTube(
"TRK_OUTERBARREL_COOLING_PUsh", rMinOuterBarrelServices, rMinOuterBarrelServices + puCoolingThick, zLengthOuterBarrelServices);
514 TGeoTube* outerBarrelCoolingH2O =
new TGeoTube(
"TRK_OUTERBARREL_COOLING_H2Osh", rMinOuterBarrelServices + puCoolingThick, rMinOuterBarrelServices + puCoolingThick + h2oCoolingThick, zLengthOuterBarrelServices);
516 TGeoVolume* outerBarrelCoolingPUVolume =
new TGeoVolume(
"TRK_OUTERBARREL_COOLING_PU", outerBarrelCoolingPU, medPU);
517 TGeoVolume* outerBarrelCoolingH2OVolume =
new TGeoVolume(
"TRK_OUTERBARREL_COOLING_H2O", outerBarrelCoolingH2O, medH2O);
518 outerBarrelCoolingPUVolume->SetLineColor(kGray);
519 outerBarrelCoolingH2OVolume->SetLineColor(kGray);
520 motherVolume->AddNode(outerBarrelCoolingPUVolume, 1,
nullptr);
521 motherVolume->AddNode(outerBarrelCoolingH2OVolume, 1,
nullptr);
529 TGeoMedium* medSiO2 = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_SILICONDIOXIDE");
530 TGeoMedium* medPE = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYETHYLENE");
531 TGeoMedium* medCu = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_COPPER");
532 TGeoMedium* medPU = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYURETHANE");
533 TGeoMedium* medH2O = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_WATER");
534 TGeoMedium* medCFiber = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_CARBONFIBERM55J6K");
537 const int ITBarrelnFiber = 70;
538 const int ITBarrelnPower = 70;
542 float puCoolingAreaB = 0;
543 float h2oCoolingAreaB = 0;
548 const int ITDisknFiber = 3 * 24;
549 const int ITDisknPower = 3 * 16;
553 float puCoolingAreaD = 0;
554 float h2oCoolingAreaD = 0;
559 float rMinMiddleCarbonSupport = 34.8f;
560 float rMaxMiddleCarbonSupport = 35.f;
561 const float zLengthMiddleCarbon = 129.f;
562 TGeoTube* middleBarrelCarbonSupport =
new TGeoTube(
"TRK_MID_CARBONSUPPORTsh", rMinMiddleCarbonSupport, rMaxMiddleCarbonSupport, zLengthMiddleCarbon / 2.);
563 TGeoVolume* middleBarrelCarbonSupportVolume =
new TGeoVolume(
"TRK_MID_CARBONSUPPORT", middleBarrelCarbonSupport, medCFiber);
564 middleBarrelCarbonSupportVolume->SetLineColor(kGray);
565 LOGP(info,
"Creating carbon fiber support for Middle Tracker");
566 motherVolume->AddNode(middleBarrelCarbonSupportVolume, 1,
nullptr);
569 float rMinMiddleServices = 35.f;
570 float rMinMiddleBarrel = rMinMiddleServices;
571 const float zLengthCylinderMiddleServices = 40.5f;
572 const float zLengthMiddleServices = 143.f;
575 rMinMiddleServices = 35.f;
576 LOGP(info,
"Building services for Middle Tracker rminMiddleServices");
579 const float rMinMiddleBarrelDisk = 5.68f;
580 const float rMaxMiddleBarrelDisk = 35.f;
581 const float zLengthMiddleBarrel = 64.5f;
582 auto orientation = Orientation::kASide;
583 float diskCircumference = rMaxMiddleBarrelDisk * 3.14;
585 double zCur = zLengthMiddleBarrel;
586 double dZ = siO2FiberAreaB / diskCircumference / 2.;
587 TGeoTube* middleBarrelConnDiskSIO2 =
new TGeoTube(
"TRK_MIDBARCONN_DISK_FIBER_SIO2sh", rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, dZ);
588 TGeoVolume* middleBarrelConnDiskSIO2Volume =
new TGeoVolume(
"TRK_MIDBARCONN_DISK_FIBER_SIO2", middleBarrelConnDiskSIO2, medSiO2);
589 middleBarrelConnDiskSIO2Volume->SetLineColor(kGray);
590 auto* rot =
new TGeoRotation(
"", 0, 0, 180);
591 auto* combiTransSIO2 =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
594 dZ = peFiberAreaB / diskCircumference / 2.;
595 TGeoTube* middleBarrelConnDiskPE =
new TGeoTube(
"TRK_MIDBARCONN_DISK_FIBER_PEsh", rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, dZ);
596 TGeoVolume* middleBarrelConnDiskPEVolume =
new TGeoVolume(
"TRK_MIDBARCONN_DISK_FIBER_PE", middleBarrelConnDiskPE, medPE);
597 middleBarrelConnDiskPEVolume->SetLineColor(kGray);
598 auto* combiTransPE =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
600 motherVolume->AddNode(middleBarrelConnDiskSIO2Volume, 1, combiTransSIO2);
601 motherVolume->AddNode(middleBarrelConnDiskPEVolume, 1, combiTransPE);
604 dZ = cuPowerAreaB / diskCircumference / 2.;
605 TGeoTube* middleBarrelConnDiskCu =
new TGeoTube(
"TRK_MIDBARCONN_DISK_POWER_CUsh", rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, dZ);
606 TGeoVolume* middleBarrelConnDiskCuVolume =
new TGeoVolume(
"TRK_MIDBARCONN_DISK_POWER_CU", middleBarrelConnDiskCu, medCu);
607 middleBarrelConnDiskCuVolume->SetLineColor(kGray);
608 auto* combiTransCu =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
611 dZ = pePowerAreaB / diskCircumference / 2.;
612 TGeoTube* middleBarrelConnDiskPEPower =
new TGeoTube(
"TRK_MIDBARCONN_DISK_POWER_PEsh", rMinMiddleBarrelDisk, rMaxMiddleBarrelDisk, dZ);
613 TGeoVolume* middleBarrelConnDiskPEPowerVolume =
new TGeoVolume(
"TRK_MIDBARCONN_DISK_POWER_PE", middleBarrelConnDiskPEPower, medPE);
614 middleBarrelConnDiskPEPowerVolume->SetLineColor(kGray);
615 auto* combiTransPEPower =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
616 motherVolume->AddNode(middleBarrelConnDiskCuVolume, 1, combiTransCu);
617 motherVolume->AddNode(middleBarrelConnDiskPEPowerVolume, 1, combiTransPEPower);
619 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
620 for (
int iSide = 0; iSide < 2; iSide++) {
623 if (orientation == Orientation::kCSide) {
629 double rCur = rMinMiddleServices;
630 double dR = siO2FiberAreaD / (3.14 * rCur);
631 TGeoTubeSeg* middleDiskFiberSIO2 =
new TGeoTubeSeg(Form(
"TRK_MLD_FIBER_SIO2sh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
632 TGeoVolume* middleDiskFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_MLD_FIBER_SIO2_%s%d", orLabel.c_str(), iSide), middleDiskFiberSIO2, medSiO2);
633 middleDiskFiberSIO2Volume->SetLineColor(kGray);
636 dR = peFiberAreaD / (3.14 * rCur);
637 TGeoTubeSeg* middleDiskFiberPE =
new TGeoTubeSeg(Form(
"TRK_MLD_FIBER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
638 TGeoVolume* middleDiskFiberPEVolume =
new TGeoVolume(Form(
"TRK_MLD_FIBER_PE_%s%d", orLabel.c_str(), iSide), middleDiskFiberPE, medPE);
639 middleDiskFiberPEVolume->SetLineColor(kGray);
640 auto* combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zLengthMiddleServices - zLengthCylinderMiddleServices),
new TGeoRotation(
"", refAngle + iSide * 180., 0, 0));
641 motherVolume->AddNode(middleDiskFiberSIO2Volume, 1, combiTrans);
642 motherVolume->AddNode(middleDiskFiberPEVolume, 1, combiTrans);
646 dR = cuPowerAreaD / (3.14 * rCur);
647 TGeoTubeSeg* middleDiskPowerCu =
new TGeoTubeSeg(Form(
"TRK_MLD_POWER_CUsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
648 TGeoVolume* middleDiskPowerCuVolume =
new TGeoVolume(Form(
"TRK_MLD_POWER_CU_%s%d", orLabel.c_str(), iSide), middleDiskPowerCu, medCu);
649 middleDiskPowerCuVolume->SetLineColor(kGray);
652 dR = pePowerAreaD / (3.14 * rCur);
653 TGeoTubeSeg* middleDiskPowerPE =
new TGeoTubeSeg(Form(
"TRK_MLD_POWER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
654 TGeoVolume* middleDiskPowerPEVolume =
new TGeoVolume(Form(
"TRK_MLD_POWER_PE_%s%d", orLabel.c_str(), iSide), middleDiskPowerPE, medPE);
655 middleDiskPowerPEVolume->SetLineColor(kGray);
657 motherVolume->AddNode(middleDiskPowerCuVolume, 1, combiTrans);
658 motherVolume->AddNode(middleDiskPowerPEVolume, 1, combiTrans);
660 if (orientation == Orientation::kASide) {
664 dR = siO2FiberAreaB / (3.14 * rCur);
665 TGeoTubeSeg* middleBarrelFiberSIO2 =
new TGeoTubeSeg(Form(
"TRK_MLB_FIBER_SIO2sh_A%d", iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
666 TGeoVolume* middleBarrelFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_MLB_FIBER_SIO2_A%d", iSide), middleBarrelFiberSIO2, medSiO2);
667 middleBarrelFiberSIO2Volume->SetLineColor(kGray);
670 dR = peFiberAreaB / (3.14 * rCur);
671 TGeoTubeSeg* middleBarrelFiberPE =
new TGeoTubeSeg(Form(
"TRK_MLB_FIBER_PEsh_A%d", iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
672 TGeoVolume* middleBarrelFiberPEVolume =
new TGeoVolume(Form(
"TRK_MLB_FIBER_PE_A%d", iSide), middleBarrelFiberPE, medPE);
673 middleBarrelFiberPEVolume->SetLineColor(kGray);
674 auto* combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zLengthMiddleServices - zLengthCylinderMiddleServices),
new TGeoRotation(
nullptr, refAngle + iSide * 180., 0, 0));
675 motherVolume->AddNode(middleBarrelFiberSIO2Volume, 1, combiTrans);
676 motherVolume->AddNode(middleBarrelFiberPEVolume, 1, combiTrans);
680 dR = cuPowerAreaB / (3.14 * rCur);
681 TGeoTubeSeg* middleBarrelPowerCu =
new TGeoTubeSeg(Form(
"TRK_MLB_POWER_CUsh_A%d", iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
682 TGeoVolume* middleBarrelPowerCuVolume =
new TGeoVolume(Form(
"TRK_MLB_POWER_CU_A%d", iSide), middleBarrelPowerCu, medCu);
683 middleBarrelPowerCuVolume->SetLineColor(kGray);
686 dR = pePowerAreaB / (3.14 * rCur);
687 TGeoTubeSeg* middleBarrelPowerPE =
new TGeoTubeSeg(Form(
"TRK_MLB_POWER_PEsh_A%d", iSide), rCur, rCur + dR, zLengthCylinderMiddleServices, -45, 45);
688 TGeoVolume* middleBarrelPowerPEVolume =
new TGeoVolume(Form(
"TRK_MLB_POWER_PE_A%d", iSide), middleBarrelPowerPE, medPE);
689 middleBarrelPowerPEVolume->SetLineColor(kGray);
691 motherVolume->AddNode(middleBarrelPowerCuVolume, 1, combiTrans);
692 motherVolume->AddNode(middleBarrelPowerPEVolume, 1, combiTrans);
702 float rMaxMiddleServicesBarFwd = 74.5f;
703 diskCircumference = rMaxMiddleServicesBarFwd * 3.14;
704 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
707 if (orientation == Orientation::kCSide) {
711 double totalThickness = 0;
712 for (
int iSide = 0; iSide < 2; iSide++) {
714 double zCur = zLengthMiddleServices;
715 double dZ = siO2FiberAreaD / diskCircumference / 2.;
716 totalThickness += 2 * dZ;
717 if (orientation == Orientation::kASide) {
718 dZ += siO2FiberAreaB / diskCircumference / 2.;
720 TGeoTubeSeg* middleBarFwdFiberSIO2 =
new TGeoTubeSeg(Form(
"TRK_MIDBARFWD_FIBER_SIO2sh_%s%d", orLabel.c_str(), iSide), rMinMiddleBarrel, rMaxMiddleServicesBarFwd, dZ, -45, 45);
721 TGeoVolume* middleBarFwdFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_MIDBARFWD_FIBER_SIO2_%s%d", orLabel.c_str(), iSide), middleBarFwdFiberSIO2, medSiO2);
722 auto* rot =
new TGeoRotation(
"", refAngle + iSide * 180., 0, 180.);
723 auto* combiTransSIO2 =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
726 dZ = peFiberAreaD / diskCircumference / 2.;
727 totalThickness += 2 * dZ;
728 if (orientation == Orientation::kASide) {
729 dZ += peFiberAreaB / diskCircumference / 2.;
731 TGeoTubeSeg* middleBarFwdFiberPE =
new TGeoTubeSeg(Form(
"TRK_MIDBARFWD_FIBER_PEsh_%s%d", orLabel.c_str(), iSide), rMinMiddleBarrel, rMaxMiddleServicesBarFwd, dZ, -45, 45);
732 TGeoVolume* middleBarFwdFiberPEVolume =
new TGeoVolume(Form(
"TRK_MIDBARFWD_FIBER_PE_%s%d", orLabel.c_str(), iSide), middleBarFwdFiberPE, medPE);
733 middleBarFwdFiberSIO2Volume->SetLineColor(kGray);
734 middleBarFwdFiberPEVolume->SetLineColor(kGray);
735 auto* combiTransPE =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
736 motherVolume->AddNode(middleBarFwdFiberSIO2Volume, 1, combiTransSIO2);
737 motherVolume->AddNode(middleBarFwdFiberPEVolume, 1, combiTransPE);
741 dZ = cuPowerAreaD / diskCircumference / 2.;
742 totalThickness += 2 * dZ;
743 if (orientation == Orientation::kASide) {
744 dZ += cuPowerAreaB / diskCircumference / 2.;
746 TGeoTubeSeg* middleBarFwdPowerCu =
new TGeoTubeSeg(Form(
"TRK_MIDBARFWD_POWER_CUsh_%s%d", orLabel.c_str(), iSide), rMinMiddleBarrel, rMaxMiddleServicesBarFwd, dZ, -45, 45);
747 TGeoVolume* middleBarFwdPowerCuVolume =
new TGeoVolume(Form(
"TRK_MIDBARFWD_POWER_CU_%s%d", orLabel.c_str(), iSide), middleBarFwdPowerCu, medCu);
748 auto* combiTransCu =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
751 dZ = pePowerAreaD / diskCircumference / 2.;
752 totalThickness += 2 * dZ;
753 if (orientation == Orientation::kASide) {
754 dZ += pePowerAreaB / diskCircumference / 2.;
756 TGeoTubeSeg* middleBarFwdPowerPE =
new TGeoTubeSeg(Form(
"TRK_MIDBARFWD_POWER_PEsh_%s%d", orLabel.c_str(), iSide), rMinMiddleBarrel, rMaxMiddleServicesBarFwd, dZ, -45, 45);
757 TGeoVolume* middleBarFwdPowerPEVolume =
new TGeoVolume(Form(
"TRK_MIDBARFWD_POWER_PE_%s%d", orLabel.c_str(), iSide), middleBarFwdPowerPE, medPE);
758 middleBarFwdPowerCuVolume->SetLineColor(kGray);
759 middleBarFwdPowerPEVolume->SetLineColor(kGray);
760 auto* combiTransPEPower =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ), rot);
761 motherVolume->AddNode(middleBarFwdPowerCuVolume, 1, combiTransCu);
762 motherVolume->AddNode(middleBarFwdPowerPEVolume, 1, combiTransPEPower);
768 float zLengthMiddleServicesFwd = 350.f - (143.f + totalThickness);
770 for (
int iSide = 0; iSide < 2; iSide++) {
772 float rMinMiddleServicesFwd = 74.5f;
774 float translation = (
int)orientation * (143.f + totalThickness + zLengthMiddleServicesFwd / 2);
776 double rCur = rMinMiddleServicesFwd;
777 double dR = siO2FiberAreaD / (3.14 * rCur);
778 if (orientation == Orientation::kASide) {
779 dR += siO2FiberAreaB / (3.14 * rCur);
781 TGeoTubeSeg* middleFwdFiberSIO2 =
new TGeoTubeSeg(Form(
"TRK_MIDFWD_FIBER_SIO2sh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthMiddleServicesFwd / 2, -45, 45);
782 TGeoVolume* middleFwdFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_MIDFWD_FIBER_SIO2_%s%d", orLabel.c_str(), iSide), middleFwdFiberSIO2, medSiO2);
783 middleFwdFiberSIO2Volume->SetLineColor(kGray);
786 dR = peFiberAreaD / (3.14 * rCur);
787 if (orientation == Orientation::kASide) {
788 dR += peFiberAreaB / (3.14 * rCur);
790 TGeoTubeSeg* middleFwdFiberPE =
new TGeoTubeSeg(Form(
"TRK_MIDFWD_FIBER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthMiddleServicesFwd / 2, -45, 45);
791 TGeoVolume* middleFwdFiberPEVolume =
new TGeoVolume(Form(
"TRK_MIDFWD_FIBER_PE_%s%d", orLabel.c_str(), iSide), middleFwdFiberPE, medPE);
792 middleFwdFiberPEVolume->SetLineColor(kGray);
794 auto* rot =
new TGeoRotation(
"", refAngle + iSide * 180., 0, 0.);
795 auto* combiTrans =
new TGeoCombiTrans(0, 0, translation, rot);
796 motherVolume->AddNode(middleFwdFiberSIO2Volume, 1, combiTrans);
797 motherVolume->AddNode(middleFwdFiberPEVolume, 1, combiTrans);
801 dR = cuPowerAreaD / (3.14 * rCur);
802 if (orientation == Orientation::kASide) {
803 dR += cuPowerAreaB / (3.14 * rCur);
805 TGeoTubeSeg* middleFwdPowerCu =
new TGeoTubeSeg(Form(
"TRK_MIDFWD_POWER_CUsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthMiddleServicesFwd / 2, -45, 45);
806 TGeoVolume* middleFwdPowerCuVolume =
new TGeoVolume(Form(
"TRK_MIDFWD_POWER_CU_%s%d", orLabel.c_str(), iSide), middleFwdPowerCu, medCu);
807 middleFwdPowerCuVolume->SetLineColor(kGray);
810 dR = pePowerAreaD / (3.14 * rCur);
811 if (orientation == Orientation::kASide) {
812 dR += pePowerAreaB / (3.14 * rCur);
814 TGeoTubeSeg* middleFwdPowerPE =
new TGeoTubeSeg(Form(
"TRK_MIDFWD_POWER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthMiddleServicesFwd / 2, -45, 45);
815 TGeoVolume* middleFwdPowerPEVolume =
new TGeoVolume(Form(
"TRK_MIDFWD_POWER_PE_%s%d", orLabel.c_str(), iSide), middleFwdPowerPE, medPE);
816 middleFwdPowerPEVolume->SetLineColor(kGray);
817 motherVolume->AddNode(middleFwdPowerCuVolume, 1, combiTrans);
818 motherVolume->AddNode(middleFwdPowerPEVolume, 1, combiTrans);
832 TGeoMedium* medSiO2 = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_SILICONDIOXIDE");
833 TGeoMedium* medPE = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYETHYLENE");
834 TGeoMedium* medCu = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_COPPER");
835 TGeoMedium* medPU = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_POLYURETHANE");
836 TGeoMedium* medH2O = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_WATER");
837 TGeoMedium* medCFiber = matmgr.getTGeoMedium(
"ALICE3_TRKSERVICES_CARBONFIBERM55J6K");
840 const int OTDisknFiber = 3 * 51;
841 const int OTDisknPower = 3 * 34;
845 float puCoolingAreaD = 0;
846 float h2oCoolingAreaD = 0;
851 const int OTBarrelnFiber = 460;
852 const int OTBarrelnPower = 306;
856 float puCoolingAreaB = 0;
857 float h2oCoolingAreaB = 0;
861 float rMinOuterServices = 68.5f;
862 float zLengthOuterServices = 201.f;
865 float rMinOuterCarbonSupport = 82.0f;
866 float rMaxOuterCarbonSupport = 82.4f;
867 const float zLengthOuterCarbon = 280.0f;
868 TGeoTube* outerBarrelCarbonSupport =
new TGeoTube(
"TRK_OT_CARBONSUPPORTsh", rMinOuterCarbonSupport, rMaxOuterCarbonSupport, zLengthOuterCarbon / 2.);
869 TGeoVolume* outerBarrelCarbonSupportVolume =
new TGeoVolume(
"TRK_OT_CARBONSUPPORT", outerBarrelCarbonSupport, medCFiber);
870 outerBarrelCarbonSupportVolume->SetLineColor(kGray);
871 LOGP(info,
"Creating carbon fiber support for Outer Tracker");
872 motherVolume->AddNode(outerBarrelCarbonSupportVolume, 1,
nullptr);
874 for (
auto& orientation : {Orientation::kASide, Orientation::kCSide}) {
875 string orLabel =
"A";
877 if (orientation == Orientation::kCSide) {
885 double rMax = rMinOuterServices;
887 double dZ = siO2FiberAreaB / (4 * 3.14 * rMax);
888 TGeoTube* outerBarrelFiberSIO2 =
new TGeoTube(Form(
"TRK_OUTERBARREL_FIBER_SIO2sh_%s", orLabel.c_str()), rMin, rMax, dZ);
889 TGeoVolume* outerBarrelFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_OUTERBARREL_FIBER_SIO2_%s", orLabel.c_str()), outerBarrelFiberSIO2, medSiO2);
890 outerBarrelFiberSIO2Volume->SetLineColor(kGray);
891 auto* combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ),
nullptr);
892 motherVolume->AddNode(outerBarrelFiberSIO2Volume, 1, combiTrans);
895 dZ = peFiberAreaB / (4 * 3.14 * rMax);
896 TGeoTube* outerBarrelFiberPE =
new TGeoTube(Form(
"TRK_OUTERBARREL_FIBER_PEsh_%s", orLabel.c_str()), rMin, rMax, dZ);
897 TGeoVolume* outerBarrelFiberPEVolume =
new TGeoVolume(Form(
"TRK_OUTERBARREL_FIBER_PE_%s", orLabel.c_str()), outerBarrelFiberPE, medPE);
898 outerBarrelFiberPEVolume->SetLineColor(kGray);
899 combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ),
nullptr);
900 motherVolume->AddNode(outerBarrelFiberPEVolume, 1, combiTrans);
903 dZ = cuPowerAreaB / (4 * 3.14 * rMax);
904 TGeoTube* outerBarrelPowerCu =
new TGeoTube(Form(
"TRK_OUTERBARREL_POWER_CUsh_%s", orLabel.c_str()), rMin, rMax, dZ);
905 TGeoVolume* outerBarrelPowerCuVolume =
new TGeoVolume(Form(
"TRK_OUTERBARREL_POWER_CU_%s", orLabel.c_str()), outerBarrelPowerCu, medCu);
906 outerBarrelFiberSIO2Volume->SetLineColor(kGray);
907 combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ),
nullptr);
908 motherVolume->AddNode(outerBarrelPowerCuVolume, 1, combiTrans);
911 dZ = pePowerAreaB / (4 * 3.14 * rMax);
912 TGeoTube* outerBarrelPowerPE =
new TGeoTube(Form(
"TRK_OUTERBARREL_POWER_PEsh_%s", orLabel.c_str()), rMin, rMax, dZ);
913 TGeoVolume* outerBarrelPowerPEVolume =
new TGeoVolume(Form(
"TRK_OUTERBARREL_POWER_PE_%s", orLabel.c_str()), outerBarrelPowerPE, medPE);
914 outerBarrelPowerPEVolume->SetLineColor(kGray);
915 combiTrans =
new TGeoCombiTrans(0, 0, (
int)orientation * (zCur + dZ),
nullptr);
916 motherVolume->AddNode(outerBarrelPowerPEVolume, 1, combiTrans);
918 for (
int iSide = 0; iSide < 2; iSide++) {
920 double rCur = rMinOuterServices;
921 double dR = (siO2FiberAreaD + siO2FiberAreaB) / (3.14 * rCur);
922 TGeoTubeSeg* outerDisksFiberSIO2 =
new TGeoTubeSeg(Form(
"TRK_OUTERDISKS_FIBER_SIO2sh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthOuterServices / 2, -45, 45);
923 TGeoVolume* outerDisksFiberSIO2Volume =
new TGeoVolume(Form(
"TRK_OUTERDISKS_FIBER_SIO2_%s%d", orLabel.c_str(), iSide), outerDisksFiberSIO2, medSiO2);
924 outerDisksFiberSIO2Volume->SetLineColor(kGray);
927 dR = (peFiberAreaD + peFiberAreaB) / (3.14 * rCur);
928 TGeoTubeSeg* outerDisksFiberPE =
new TGeoTubeSeg(Form(
"TRK_OUTERDISKS_FIBER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthOuterServices / 2, -45, 45);
929 TGeoVolume* outerDisksFiberPEVolume =
new TGeoVolume(Form(
"TRK_OUTERDISKS_FIBER_PE_%s%d", orLabel.c_str(), iSide), outerDisksFiberPE, medPE);
930 outerDisksFiberPEVolume->SetLineColor(kGray);
932 float translation = (
int)orientation * (149.f + zLengthOuterServices / 2);
933 auto* combiTrans =
new TGeoCombiTrans(0, 0, translation,
new TGeoRotation(
"", refAngle + iSide * 180., 0, 0));
934 motherVolume->AddNode(outerDisksFiberSIO2Volume, 1, combiTrans);
935 motherVolume->AddNode(outerDisksFiberPEVolume, 1, combiTrans);
939 dR = (cuPowerAreaD + cuPowerAreaB) / (3.14 * rCur);
940 TGeoTubeSeg* outerDisksPowerCu =
new TGeoTubeSeg(Form(
"TRK_OUTERDISKS_POWER_CUsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthOuterServices / 2, -45, 45);
941 TGeoVolume* outerDisksPowerCuVolume =
new TGeoVolume(Form(
"TRK_OUTERDISKS_POWER_CU_%s%d", orLabel.c_str(), iSide), outerDisksPowerCu, medCu);
942 outerDisksPowerCuVolume->SetLineColor(kGray);
945 dR = (pePowerAreaD + pePowerAreaB) / (3.14 * rCur);
946 TGeoTubeSeg* outerDisksPowerPE =
new TGeoTubeSeg(Form(
"TRK_OUTERDISKS_POWER_PEsh_%s%d", orLabel.c_str(), iSide), rCur, rCur + dR, zLengthOuterServices / 2, -45, 45);
947 TGeoVolume* outerDisksPowerPEVolume =
new TGeoVolume(Form(
"TRK_OUTERDISKS_POWER_PE_%s%d", orLabel.c_str(), iSide), outerDisksPowerPE, medPE);
948 outerDisksPowerPEVolume->SetLineColor(kGray);
949 motherVolume->AddNode(outerDisksPowerCuVolume, 1, combiTrans);
950 motherVolume->AddNode(outerDisksPowerPEVolume, 1, combiTrans);