]>
Commit | Line | Data |
---|---|---|
9b0c60ab | 1 | #ifndef ALIITSV11GEOMETRYSSD_H |
2 | #define ALIITSV11GEOMETRYSSD_H | |
d7599219 | 3 | //************************************************************************* |
4 | // class AliITSv11GeometrySSD | |
5 | // Enrico Cattaruzza ecattar@ts.infn.it | |
6 | //************************************************************************* | |
9b0c60ab | 7 | /* Copyright(c) 2007-2009, ALICE Experiment at CERN, All rights reserved. * |
8 | * See cxx source for full Copyright notice */ | |
9 | /* $Id$ */ | |
d7599219 | 10 | class TGeoVolume; |
11 | class TGeoCombiTrans; | |
12 | class TGeoMedium; | |
13 | class TGeoCompositeShape; | |
44285dfa | 14 | class TGeoMatrix; |
d7599219 | 15 | class TVector3; |
16 | class TGeoArb8; | |
17 | class TList; | |
18 | class TGeoTube; | |
19 | class TGeoHMatrix; | |
bf210566 | 20 | class TGeoTranslation; |
21 | class TGeoXtru; | |
22 | class TGeoVolumeAssembly; | |
9acf2ecc | 23 | #include "AliITSv11Geometry.h" |
24 | class AliITSv11GeometrySSD: public AliITSv11Geometry { | |
d7599219 | 25 | public: |
26 | AliITSv11GeometrySSD(); | |
44285dfa | 27 | AliITSv11GeometrySSD(const AliITSv11GeometrySSD &source); |
28 | AliITSv11GeometrySSD& operator=(const AliITSv11GeometrySSD &source); | |
d7599219 | 29 | virtual ~AliITSv11GeometrySSD(){}; |
30 | ///////////////////////////////////////////////////////////////////////// | |
31 | // Public methods | |
32 | ///////////////////////////////////////////////////////////////////////// | |
47f8de53 | 33 | void CreateMaterials(); // Method setting the materials |
9b0c60ab | 34 | TGeoMedium* GetMedium(const char* mediumName); // It returns the Medium |
02d4acf9 | 35 | const char* GetSenstiveVolumeName5() const {return fgSSDsensitiveVolName5;}; |
bf210566 | 36 | // it returns the Sensitive Volume of Layer 5 |
02d4acf9 | 37 | const char* GetSenstiveVolumeName6() const {return fgSSDsensitiveVolName6;}; |
bf210566 | 38 | // it returns the Sensitive Volume of Layer 6 |
39 | TGeoVolumeAssembly* GetLadderSegment(Int_t i){return fladdersegment[i];}; // Get Ladder Segment | |
40 | TGeoVolumeAssembly* GetEndLadderSegment(Int_t i){return fendladdersegment[i];}; // Get End Ladder Segment | |
41 | TGeoVolume* GetLadder(Int_t i) {return fladder[i];}; // Get Ladder | |
ca86fdb4 | 42 | // TGeoVolumeAssembly* GetLadder(Int_t i) {return fladder[i];}; // Get Ladder |
e5bf64ae | 43 | TGeoVolumeAssembly* GetLayer(Int_t i)const {return i==5? fSSDLayer5 : fSSDLayer6;}; // Get Layer |
9b0c60ab | 44 | TGeoVolume** GetEndCapAssembly(); // End Cap Assembly |
bf210566 | 45 | void SetLadderSegment(); // Set Ladder Elementary Segment |
46 | void SetEndLadderSegment(); // Set End Ladder Segment | |
47 | void SetLadder(); // Set Ladder | |
48 | void SetLayer(); // Set Layer | |
47f8de53 | 49 | void SetSSDCone(); // Set SSD Cone |
fcfbdd23 | 50 | TGeoVolume* SetSSDCables(); // Set SSD Cables |
bf210566 | 51 | void Layer5(TGeoVolume* moth); // Setting Layer 5 into mother volume |
52 | void Layer6(TGeoVolume* moth); // Setting Layer 6 into mother volume | |
9b0c60ab | 53 | void LadderSupportLayer5(TGeoVolume* moth); // Setting Ladder Support of Layer 5 |
54 | void LadderSupportLayer6(TGeoVolume* moth); // Setting Ladder Support of Layer 6 | |
55 | void EndCapSupportSystemLayer5(TGeoVolume* moth); // Setting End Cap Support + End Cap Assembly Layer 5 | |
56 | void EndCapSupportSystemLayer6(TGeoVolume* moth); // Setting End Cap Support + End Cap Assembly Layer 6 | |
47f8de53 | 57 | void SSDCone(TGeoVolume* moth); // Setting SSD Cone; |
fcfbdd23 | 58 | void SSDCables(TGeoVolume* moth); // Setting SSD Cables; |
d7599219 | 59 | private: |
bf210566 | 60 | ///////////////////////////////////////////////////////////////////////////////// |
61 | // Names of the Sensitive Volumes of Layer 5 and Layer 6 | |
62 | ///////////////////////////////////////////////////////////////////////////////// | |
02d4acf9 | 63 | static const char* fgSSDsensitiveVolName5; // sens. vol. name for lay. 5 |
64 | static const char* fgSSDsensitiveVolName6; // sens. vol. name for lay. 6 | |
e21cdd03 | 65 | ///////////////////////////////////////////////////////////////////////////////// |
66 | // Variable for Vertical Disalignement of Modules | |
67 | ///////////////////////////////////////////////////////////////////////////////// | |
68 | static const Double_t fgkSSDModuleVerticalDisalignment; // Vertical Disalignement of Volume | |
ca86fdb4 | 69 | static const Double_t fgkSSDModuleVerticalDisalignment2; // Vertical Disalignement of Volume |
70 | static const Double_t fgkSSDTolerance; // SSD Tolerance | |
d7599219 | 71 | ///////////////////////////////////////////////////////////////////////// |
72 | // Layer5 (lengths are in mm and angles in degrees) | |
73 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 74 | static const Double_t fgkSSDLay5LadderLength; // Ladder Layer5 Length |
75 | static const Int_t fgkSSDLay5SensorsNumber; // Ladder Layer5 Sensor Number | |
76 | static const Int_t fgkSSDLay5LadderNumber; // Ladder Layer5 Number | |
77 | static const Double_t fgkSSDLay5RadiusMin; // Ladder Layer5 Min Radius | |
78 | static const Double_t fgkSSDLay5RadiusMax; // Ladder Layer5 Max Radius | |
79 | static const Double_t fgkLay5CenterITSPosition; // ITS center position respect | |
80 | // to Ladder Layer5 | |
d7599219 | 81 | ///////////////////////////////////////////////////////////////////////// |
82 | // Layer6 (lengths are in mm and angles in degrees) | |
83 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 84 | static const Double_t fgkSSDLay6LadderLength; // Ladder Layer6 Length |
85 | static const Int_t fgkSSDLay6SensorsNumber; // Ladder Layer6 Sensor Number | |
86 | static const Int_t fgkSSDLay6LadderNumber; // Ladder Layer6 Number | |
87 | static const Double_t fgkSSDLay6RadiusMin; // Ladder Layer6 Min Radius | |
88 | static const Double_t fgkSSDLay6RadiusMax; // Ladder Layer6 Max Radius | |
89 | static const Double_t fgkLay6CenterITSPosition; // ITS center position respect | |
90 | // to Ladder Layer6 | |
d7599219 | 91 | ///////////////////////////////////////////////////////////////////////// |
92 | // SSD Chips and Hybrid | |
93 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 94 | static const Int_t fgkSSDChipNumber; // SSD Module Chip Number |
95 | static const Double_t fgkSSDChipLength; // SSD Module Chip Length | |
96 | static const Double_t fgkSSDChipWidth; // SSD Module Chip Width | |
97 | static const Double_t fgkSSDChipHeight; // SSD Module Chip Height | |
98 | static const Double_t fgkSSDChipSeparationLength;// SSD Module Distance between Chips | |
99 | static const Double_t fgkSSDChipGlueLength; // SSD Module Chip Glue Layer Length | |
100 | static const Double_t fgkSSDChipGlueWidth; // SSD Module Chip Glue Layer Width | |
101 | static const Double_t fgkSSDChipGlueHeight; // SSD Module Chip Glue Layer Height | |
44285dfa | 102 | ///////////////////////////////////////////////////////////////////////// |
103 | // Stiffener Components | |
104 | ///////////////////////////////////////////////////////////////////////// | |
105 | static const Double_t fgkSSDStiffenerLength; // SSD Module Stiffener Length | |
106 | static const Double_t fgkSSDStiffenerWidth; // SSD Module Stiffener Width | |
107 | static const Double_t fgkSSDStiffenerHeight; // SSD Module Stiffener Height | |
108 | static const Double_t fgkSSDStiffenerToChipDist; // SSD Module Stiffener position respect | |
109 | // to sensor Edge | |
110 | static const Double_t fgkSSDCapacitor0603Length; // SSD Stiffener Capacitor 0603 Length | |
111 | static const Double_t fgkSSDCapacitor0603Width; // SSD Stiffener Capacitor 0603 Width | |
112 | static const Double_t fgkSSDCapacitor0603Height; // SSD Stiffener Capacitor 0603 Height | |
113 | static const Double_t fgkSSDCapacitor1812Length; // SSD Stiffener Capacitor 1812 Length | |
114 | static const Double_t fgkSSDCapacitor1812Width; // SSD Stiffener Capacitor 1812 Width | |
115 | static const Double_t fgkSSDCapacitor1812Height; // SSD Stiffener Capacitor 1812 Height | |
116 | static const Double_t fgkSSDWireLength; // SSD Stiffener Wire Length | |
117 | static const Double_t fgkSSDWireRadius; // SSD Stiffener Wire Radius | |
118 | static const Double_t fgkSSDConnectorPosition[2];// SSD Connector Position respect to Stiffener | |
119 | static const Double_t fgkSSDConnectorSeparation; // SSD Connector separation distance | |
120 | static const Double_t fgkSSDConnectorLength; // SSD Stiffener Connector Length | |
121 | static const Double_t fgkSSDConnectorWidth; // SSD Stiffener Connector Width | |
122 | static const Double_t fgkSSDConnectorHeight; // SSD Stiffener Connector Height | |
bf210566 | 123 | static const Double_t fgkSSDConnectorAlHeight; // SSD Stiffener Connector Al Height |
124 | static const Double_t fgkSSDConnectorNiHeight; // SSD Stiffener Connector Ni Height | |
d7599219 | 125 | ///////////////////////////////////////////////////////////////////////// |
126 | // Flex | |
127 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 128 | static const Double_t fgkSSDFlexFullLength; // SSD Flex Full Length |
129 | static const Double_t fgkSSDFlexLength[4]; // SSD Flex Components Length | |
130 | static const Double_t fgkSSDFlexWidth[2]; // SSD Flex Components Width | |
131 | static const Double_t fgkSSDFlexHeight[2]; // SSD Flex Layers Heigth | |
132 | static const Double_t fgkSSDFlexAngle; // SSD Flex Angle | |
133 | static const Double_t fgkSSDFlexHoleLength; // SSD Flex Hole Length | |
134 | static const Double_t fgkSSDFlexHoleWidth; // SSD Flex Hole Width | |
135 | static const Double_t fgkSSDEndFlexCompLength[6];// SSD End-Flex Components Length | |
136 | static const Double_t fgkSSDEndFlexCompWidth[3]; // SSD End-Flex Components Width | |
d7599219 | 137 | ///////////////////////////////////////////////////////////////////////////////// |
138 | // SSD Ladder Cable | |
139 | ///////////////////////////////////////////////////////////////////////////////// | |
44285dfa | 140 | static const Double_t fgkSSDLadderCableWidth; // SSD Ladder Cable Width |
44285dfa | 141 | ///////////////////////////////////////////////////////////////////////// |
142 | // SSD Module Components | |
143 | ///////////////////////////////////////////////////////////////////////// | |
144 | static const Double_t fgkSSDModuleStiffenerPosition[2]; // SSD Module Stiffener position | |
145 | // respect to Sensor Edge | |
146 | static const Double_t fgkSSDModuleSensorSupportDistance;// SSD Module Sensor Support Position | |
147 | // respect to Sensor Edge | |
148 | static const Double_t fgkSSDModuleCoolingBlockToSensor; // SSD Cooling Block Position | |
149 | // respect to sensor | |
d7599219 | 150 | ///////////////////////////////////////////////////////////////////////// |
151 | // Chip Cables | |
152 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 153 | static const Double_t fgkSSDChipCablesLength[2]; // SSD Chip Cables Components Length |
154 | static const Double_t fgkSSDChipCablesHeight[4]; // SSD Chip Cables Components Height | |
155 | static const Double_t fgkSSDChipCablesWidth[3]; // SSD Chip Cables Components Width | |
d7599219 | 156 | ///////////////////////////////////////////////////////////////////////// |
157 | // Cooling Block | |
158 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 159 | static const Double_t fgkSSDCoolingBlockLength; // SSD Cooling Block Length |
160 | static const Double_t fgkSSDCoolingBlockWidth; // SSD Cooling Block Width | |
161 | static const Double_t fgkSSDCoolingBlockHeight[3]; // SSD Cooling Block Heiht | |
162 | static const Double_t fgkSSDCoolingBlockHoleRadius[2];// SSD Cooling Block Hole Radius | |
163 | static const Double_t fgkSSDCoolingBlockHoleLength[2];// SSD Cooling Block Hole Length | |
164 | static const Double_t fgkSSDCoolingBlockHoleCenter; // SSD Cooling Block Hole Ceneter Position | |
165 | static const Double_t fgkSSDCoolingBlockHoleHeight; // SSD Cooling Block Hole Height | |
d7599219 | 166 | ///////////////////////////////////////////////////////////////////////// |
167 | // SSD Sensor | |
168 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 169 | static const char* fgkSSDSensitiveVolName; // SSD Name of the Sensitive Part of the Sensor |
170 | static const Double_t fgkSSDSensorLength; // SSD Sensor Length | |
171 | static const Double_t fgkSSDSensorHeight; // SSD Sensor Height | |
172 | static const Double_t fgkSSDSensorWidth; // SSD Sensor Width | |
173 | static const Double_t fgkSSDSensorOverlap; // SSD Sensor Beam Axis Overlap | |
174 | static const Double_t fgkSSDSensorInsensitiveLength; // SSD Insensitive Part Length | |
175 | static const Double_t fgkSSDSensorInsensitiveWidth; // SSD Insensitive Part Width | |
d7599219 | 176 | ///////////////////////////////////////////////////////////////////////// |
177 | // SSD Sensor Support | |
178 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 179 | static const Double_t fgkSSDSensorSideSupportLength; // SSD Side Sensor Support Length |
180 | static const Double_t fgkSSDSensorSideSupportWidth; // SSD Side Sensor Support Width | |
181 | static const Double_t fgkSSDSensorSideSupportHeight[2]; // SSD Side Sensor Support Height | |
182 | static const Double_t fgkSSDSensorSideSupportThickness[2]; // SSD Side Sensor Support Thickness | |
183 | static const Double_t fgkSSDSensorSideSupportPosition; // SSD Side Sensor Support Position | |
184 | static const Double_t fgkSSDSensorCenterSupportLength; // SSD Center Sensor Support Length | |
185 | static const Double_t fgkSSDSensorCenterSupportWidth; // SSD Center Sensor Support Width | |
186 | static const Double_t fgkSSDSensorCenterSupportHeight[2]; // SSD Center Sensor Support Height | |
187 | static const Double_t fgkSSDSensorCenterSupportThickness[2];// SSD Center Sensor Support Thickness | |
188 | static const Double_t fgkSSDSensorCenterSupportPosition; // SSD Center Sensor Support Position | |
189 | static const Int_t fgkSSDSensorSupportCombiTransNumber = 3; // Number of TGeoCombiTrans | |
190 | // for positioning volumes in Sensor Support Assembly | |
d7599219 | 191 | ///////////////////////////////////////////////////////////////////////// |
192 | //Parameters for Carbon Fiber | |
193 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 194 | static const Double_t fgkCarbonFiberTriangleLength; // Carbon Fiber Triangle Length |
195 | static const Double_t fgkCarbonFiberTriangleAngle; // Carbon Fiber Triangle Angle | |
196 | static const Double_t fgkCarbonFiberSupportTopEdgeDist[2]; // Carbon Fiber Support Top Edge Components | |
197 | static const Double_t fgkCarbonFiberSupportEdgeLength; // Carbon Fiber Support Edge Lenght | |
198 | static const Double_t fgkCarbonFiberSupportWidth; // Carbon Fiber Support Edge Width | |
199 | static const Double_t fgkCarbonFiberSupportXAxisLength; // Carbon Fiber Support X Axis Lenght | |
200 | static const Double_t fgkCarbonFiberSupportYAxisLength; // Carbon Fiber Support Y Axis Lenght | |
201 | static const Int_t fgkCarbonFiberAssemblyCombiTransNumber = 3; // Number of TGeoCombiTrans | |
202 | // for positioning volumes in Carbon Fiber Assembly | |
d7599219 | 203 | ////////////////////////////////////////////////////////////////////////////// |
204 | // Carbon Fiber Junction Parameters | |
205 | ////////////////////////////////////////////////////////////////////////////// | |
44285dfa | 206 | static const Double_t fgkCarbonFiberJunctionLength; // Carbon Fiber Junction Length |
207 | static const Double_t fgkCarbonFiberJunctionWidth; // Carbon Fiber Junction Width | |
208 | static const Double_t fgkCarbonFiberJunctionEdge[2]; // Carbon Fiber Junction Edge Length | |
209 | static const Double_t fgkCarbonFiberJunctionAngle[2]; // Carbon Fiber Junction Angle | |
210 | static const Double_t fgkCarbonFiberJunctionToSensorSupport; // Carbon Fiber Junction position respect to sensor | |
d7599219 | 211 | ///////////////////////////////////////////////////////////////////////// |
212 | //Parameters for Carbon Fiber Lower Support (lengths are in mm) | |
213 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 214 | static const Double_t fgkCarbonFiberLowerSupportWidth; // Lower Support of Carbon Fiber Width |
215 | static const Double_t fgkCarbonFiberLowerSupportLowerLenght; // Lower Support of Carbon Fiber Length | |
216 | static const Double_t fgkCarbonFiberLowerSupportHeight; // Lower Support of Carbon Fiber Height | |
217 | static const Double_t fgkCarbonFiberLowerSupportTransverseWidth; // Lower Support of Carbon Fiber Transverse separation | |
218 | static const Double_t fgkCarbonFiberLowerSupportVolumeSeparation; // Distance between Lower Supports of Carbon Fiber | |
219 | static const Double_t fgkCarbonFiberLowerSupportVolumePosition[2];// Carbon fiber lower Support Position | |
220 | ///////////////////////////////////////////////////////////////////////// | |
221 | // End Ladder Carbon Fiber Lower Junction Parameters (lengths are in mm and angles in degrees) | |
222 | ///////////////////////////////////////////////////////////////////////// | |
223 | static const Double_t fgkEndLadderCarbonFiberLowerJunctionLength[2]; // End Ladder Carbon Fiber Lower Up Support length | |
224 | static const Double_t fgkEndLadderCarbonFiberUpperJunctionLength[2]; // End Ladder Carbon Fiber Lower Down Support length | |
225 | static const Double_t fgkEndLadderMountingBlockPosition[2]; // End Ladder Mounting Block Position | |
9b0c60ab | 226 | static const Double_t fgkendladdercoolingsupportdistance[3]; // End Ladder Cooling Support Position |
d7599219 | 227 | ///////////////////////////////////////////////////////////////////////// |
228 | // Cooling Tube Support (lengths are in mm and angles in degrees) | |
229 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 230 | static const Double_t fgkCoolingTubeSupportRmax; // Cooling Tube Support Max Radius |
231 | static const Double_t fgkCoolingTubeSupportRmin; // Cooling Tube Support Min Radius | |
232 | static const Double_t fgkCoolingTubeSupportLength; // Cooling Tube Support Length | |
233 | static const Double_t fgkCoolingTubeSupportHeight; // Cooling Tube Support Height | |
234 | static const Double_t fgkCoolingTubeSupportWidth; // Cooling Tube Support Width | |
235 | static const Double_t fgkCoolingTubeSupportSeparation; // Cooling Tube Support Separation | |
236 | static const Double_t fgkCoolingTubeSupportToCarbonFiber; // Cooling Tube Support position respect to Carbon Fiber | |
d7599219 | 237 | ///////////////////////////////////////////////////////////////////////////////// |
238 | // Cooling Tube (lengths are in mm and angles in degrees) | |
239 | ///////////////////////////////////////////////////////////////////////////////// | |
44285dfa | 240 | static const Double_t fgkCoolingTubeRmax; // Cooling Tube Max Radius |
241 | static const Double_t fgkCoolingTubeRmin; // Cooling Tube Min Radius | |
242 | static const Double_t fgkCoolingTubeLength; // Cooling Tube Length | |
243 | static const Double_t fgkCoolingTubeSeparation; // Cooling Tube Separation | |
9b0c60ab | 244 | static const Double_t fgkMountingBlockToSensorSupport; // Distance between Mounting block and Side Sensor Support |
d7599219 | 245 | ///////////////////////////////////////////////////////////////////////// |
246 | // SSD Mounting Block Parameters (lengths are in mm and angles in degrees) | |
247 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 248 | static const Double_t fgkSSDMountingBlockLength[3]; // SSD Mounting Block Components Lengths |
249 | static const Double_t fgkSSDMountingBlockHeight[4]; // SSD Mounting Block Components Heights | |
250 | static const Double_t fgkSSDMountingBlockWidth; // SSD Mounting Block Width | |
251 | static const Double_t fgkSSDMountingBlockHoleTrapezoidAngle; // SSD Mounting Block Hole Trapezoid Angle | |
252 | static const Double_t fgkSSDMountingBlockHoleTrapezoidHeight; // SSD Mounting Block Hole Trapezoid Height | |
253 | static const Double_t fgkSSDMountingBlockHoleTrapezoidUpBasis;// SSD Mounting Block Hole Trapezoid Up Basis Length | |
254 | static const Double_t fgkSSDMountingBlockHoleTubeLength[2]; // SSD Mounting Block Hole Tube Lengths | |
255 | static const Double_t fgkSSDMountingBlockHoleTubeWidth[2]; // SSD Mounting Block Hole Tube Width | |
256 | static const Double_t fgkSSDMountingBlockHoleRadius; // SSD Mounting Block Hole radius | |
257 | static const Double_t fgkSSDMountingBlockScrewHoleEdge; // SSD Mounting Block Screw Hole Edge | |
258 | static const Double_t fgkSSDMountingBlockScrewHoleHeigth; // SSD Mounting Block Screw Hole Height | |
259 | static const Double_t fgkSSDMountingBlockScrewHoleRadius[2]; // SSD Mounting Block Screw Hole Radii | |
d7599219 | 260 | ///////////////////////////////////////////////////////////////////////// |
9b0c60ab | 261 | // SSD Mounting Block Clip Parameters (lengths are in mm and angles in degrees) |
262 | ///////////////////////////////////////////////////////////////////////// | |
263 | static const Double_t fgkMountingBlockClipLength; // SSD Mounting Block Clip Length | |
264 | static const Double_t fgkMountingBlockClipThickness; // SSD Mounting Block Clip Thickness | |
265 | static const Double_t fgkMountingBlockClibScrewRadius; // SSD Mounting Block Clip Radius | |
266 | static const Double_t fgkMountingBlockClibScrewPosition; // SSD Mounting Block Clip Screw Position | |
267 | static const Double_t fgkMountingBlockClibWidth; // SSD Mounting Block Clip | |
268 | ///////////////////////////////////////////////////////////////////////////////// | |
269 | // SSD Mounting Block Support Parameters (lengths are in mm and angles in degrees) | |
270 | ///////////////////////////////////////////////////////////////////////////////// | |
271 | static const Double_t fgkMountingBlockSupportWidth[2]; // SSD Mounting Block Support Width | |
272 | static const Double_t fgkMountingBlockSupportDownHeight; // SSD Mounting Block Support Down Heigth | |
273 | static const Double_t fgkMountingBlockSupportRadius[2]; // SSD Mounting Block Support Radius | |
274 | static const Double_t fgkMountingBlockSupportUpHeight[2]; // SSD Mounting Block Support Heigth | |
275 | static const Double_t fgkLadderSupportHeigth; // SSD Ladder Support Width | |
276 | static const Double_t fgkLadderSupportRingLay5Position; // SSD Ladder Support Ring Position Layer5 respect to ITS center | |
277 | static const Double_t fgkLadderSupportRingLay6Position; // SSD Ladder Support Ring Position Layer6 respect to ITS center | |
278 | ///////////////////////////////////////////////////////////////////////////////// | |
279 | // SSD End Cap Cover Plate Parameters (lengths are in mm and angles in degrees) | |
280 | ///////////////////////////////////////////////////////////////////////////////// | |
281 | static const Double_t fgkEndCapCoverPlateSmallHoleRadius; // End Cap Cover Plate Hole Small Radious | |
282 | static const Double_t fgkEndCapCoverPlateBigHoleRadius; // End Cap Cover Plate Hole Big Radious | |
283 | static const Double_t fgkEndCapCoverPlateThickness; // End Cap Cover Plate Thickness | |
284 | static const Double_t fgkEndCapCoverPlateSmallHoleSeparation[3]; // End Cap Cover Plate Hole Separation | |
285 | static const Double_t fgkEndCapCoverPlateLength[6]; // End Cap Cover Plate Length | |
286 | static const Double_t fgkEndCapCoverPlateWidth[3]; // End Cap Cover Plate Width | |
287 | static const Double_t fgkEndCapCoverPlateScrewRadiusMin; // End Cap Cover Plate Screw Radius Min | |
288 | static const Double_t fgkEndCapCoverPlateScrewRadiusMax; // End Cap Cover Plate Screw Radius Max | |
289 | static const Double_t fgkEndCapCoverPlateClipLength; // End Cap Cover Plate Clip Length | |
290 | static const Double_t fgkEndCapCoverPlateClipWidth; // End Cap Cover Plate Clip Width | |
291 | static const Double_t fgkEndCapCoverPlateDownClipLength; // End Cap Cover Plate Down Clip Length | |
292 | static const Double_t fgkEndCapCoverPlateDownClipWidth; // End Cap Cover Plate Down Clip Width | |
293 | ///////////////////////////////////////////////////////////////////////////////// | |
294 | // SSD End Cap Cooling Tube Parameters (lengths are in mm and angles in degrees) | |
295 | ///////////////////////////////////////////////////////////////////////////////// | |
296 | static const Double_t fgkEndCapCoolingTubeAxialRadius[2]; // End Cap Cooling Tube Axial Radius | |
297 | static const Double_t fgkEndCapCoolingTubeRadiusMin; // End Cap Cooling Tube Min Radius | |
298 | static const Double_t fgkEndCapCoolingTubeRadiusMax; // End Cap Cooling Tube Max Radius | |
299 | static const Double_t fgkEndCapCoolingTubeAngle[5]; // End Cap Cooling Tube Angle | |
300 | static const Double_t fgkEndCapCoolingTubeLength[5]; // End Cap Cooling Tube Length | |
301 | static const Double_t fgkEndCapCoolingTubeToCoverSide; // End Cap Cooling Tube Position respect to CoverSide | |
302 | ///////////////////////////////////////////////////////////////////////////////// | |
303 | // SSD End Cap Cover Side Parameters (lengths are in mm and angles in degrees) | |
304 | ///////////////////////////////////////////////////////////////////////////////// | |
305 | static const Double_t fgkEndCapSideCoverLength[5]; // End Cap Cover Side Length | |
306 | static const Double_t fgkEndCapSideCoverWidth[7]; // End Cap Cover Side Width | |
307 | static const Double_t fgkEndCapSideCoverThickness; // End Cap Cover Side Thickness | |
308 | ///////////////////////////////////////////////////////////////////////////////// | |
309 | // SSD End Cap Cards Parameters (lengths are in mm and angles in degrees) | |
310 | ///////////////////////////////////////////////////////////////////////////////// | |
311 | static const Double_t fgkEndCapCardElectBoardBackLength[3]; // End Cap Card Electronic Board Back Length | |
312 | static const Double_t fgkEndCapCardElectBoardBackWidth[2]; // End Cap Card Electronic Board Back Width | |
313 | static const Double_t fgkEndCapCardElectBoardBackThickness; // End Cap Card Electronic Board Back Thickness | |
314 | static const Double_t fgkEndCapCardElectBoardLength; // End Cap Card Electronic Board Length | |
315 | static const Double_t fgkEndCapCardElectBoardLayerWidth[2]; // End Cap Card Electronic Board Layer Width | |
316 | static const Double_t fgkEndCapCardElectBoardLayerThickness;// End Cap Card Electronic Board Layer Thickness | |
317 | static const Double_t fgkEndCapCardJMDConnectorThickness; // End Cap Card JMD Connector Thickness | |
318 | static const Double_t fgkEndCapCardJMDConnectorLength[2]; // End Cap Card JMD Connector Length | |
319 | static const Double_t fgkEndCapCardJMDConnectorWidth[2]; // End Cap Card JMD Connector Width | |
320 | static const Double_t fgkEndCapCardJMDConnectorToLayer; // End Cap Card JMD Connector to Layer Distance | |
321 | static const Double_t fgkEndCapCardCableConnectorLength[3]; // End Cap Card Cable Connector Length | |
322 | static const Double_t fgkEndCapCardCableConnectorWidth[2]; // End Cap Card Cable Connector Width | |
323 | static const Double_t fgkEndCapCardCableConnectorThickness; // End Cap Card Cable Connector Thickness | |
324 | static const Double_t fgkEndCapCardCableConnectorDistance; // End Cap Card Cable Connector Distance | |
325 | static const Double_t fgkEndCapCardCableConnectorToLayer; // End Cap Card Cable Connector To Layer Distance | |
326 | static const Double_t fgkEndCapStripConnectionLength; // End Cap Strip Connection Length | |
327 | static const Double_t fgkEndCapStripConnectionThickness; // End Cap Strip Connection Thickness | |
328 | static const Double_t fgkEndCapStripConnectionWidth; // End Cap Strip Connection Width | |
329 | static const Double_t fgkEndCapInterfaceCardBLength[7]; // End Cap Interface CardB Length | |
330 | static const Double_t fgkEndCapInterfaceCardBWidth[5]; // End Cap Interface CardB Width | |
331 | static const Double_t fgkEndCapInterfaceCardBThickness; // End Cap Interface CardB Thickness | |
332 | static const Double_t fgkEndCapInterfaceElectBoardCardBThickness; // End Cap Interface Elect Board CardB Thickness | |
333 | static const Double_t fgkEndCapInterfaceCardBJMDConnectorSeparation; // End Cap Interface CardB JMD Connector Separation | |
334 | static const Double_t fgkEndCapStiffenerLength; // End Cap Stiffener Length | |
335 | static const Double_t fgkEndCapStiffenerWidth; // End Cap Stiffener Width | |
336 | static const Double_t fgkEndCapStiffenerThickness; // End Cap Stiffener Thickness | |
337 | static const Double_t fgkEndCapEffectiveCableRadiusMin; // End Cap Effective Cable Radius Min | |
338 | static const Double_t fgkEndCapEffectiveCableRadiusMax; // End Cap Effective Cable Radius Max | |
339 | ///////////////////////////////////////////////////////////////////////////////// | |
340 | // SSD End Cap SupportLayer5/6 Side Parameters (lengths are in mm and angles in degrees) | |
341 | ///////////////////////////////////////////////////////////////////////////////// | |
342 | static const Double_t fgkEndCapLay5SupportLength; // End Cap Layer5 Support Length | |
343 | static const Double_t fgkEndCapLay5SupportMiddleRadius; // End Cap Layer5 Support Middle Radius | |
344 | static const Double_t fgkEndCapLay5SupportLowRadius; // End Cap Layer5 Support Low Radius | |
345 | static const Double_t fgkEndCapLay5SupportHighWidth; // End Cap Layer5 High Radius | |
346 | static const Double_t fgkEndCapLay5SupportLowWidth; // End Cap Layer5 Low Width | |
347 | static const Double_t fgkEndCapSupportLength[2]; // End Cap Layer5/6 Support Length | |
348 | static const Double_t fgkEndCapSupportMiddleRadius[2]; // End Cap Layer5/6 Support Middle Radius | |
349 | static const Double_t fgkEndCapSupportLowRadius[2]; // End Cap Layer5/6 Support Low Radius | |
350 | static const Double_t fgkEndCapSupportHighWidth; // End Cap Layer5/6 High Radius | |
351 | static const Double_t fgkEndCapSupportLowWidth[2]; // End Cap Layer5/6 Low Width | |
352 | static const Double_t fgkEndCapSupportCenterLay5ITSPosition; // End Cap Support Center ITS Position Layer 5 | |
353 | static const Double_t fgkEndCapSupportCenterLay5Position; // End Cap Support Position Respect Z Axis Origin Layer 5 | |
354 | static const Double_t fgkEndCapSupportCenterLay6ITSPosition; // End Cap Support Center ITS Position Layer 6 | |
355 | static const Double_t fgkEndCapSupportCenterLay6Position; // End Cap Support Position Respect Z Axis Origin Layer 6 | |
356 | ///////////////////////////////////////////////////////////////////////////////// | |
357 | // SSD End Cap Kapton Foil Parameters (lengths are in mm and angles in degrees) | |
358 | //////////////////////////////////////////////////////////////////////////////// | |
359 | static const Double_t fgkEndCapKaptonFoilThickness; // End Cap Kapton Foil Thickness | |
360 | static const Double_t fgkEndCapKaptonFoilLength; // End Cap Kapton Foil Length | |
361 | static const Double_t fgkEndCapKaptonFoilWidth ; // End Cap Kapton Foil Width | |
362 | ///////////////////////////////////////////////////////////////////////// | |
47f8de53 | 363 | // SSD Cone |
364 | ///////////////////////////////////////////////////////////////////////// | |
365 | static const Double_t fgkSSDLowerPConeRadius; // SSD Cone Lower Radius | |
366 | static const Double_t fgkSSDPConeAngle; // SSD Cone Angle | |
367 | static const Double_t fgkSSDPConeZLength[2]; // SSD Cone ZLength | |
368 | static const Double_t fgkSSDPConeLittleHoleRadius; // SSD Cone Little Hole Radius | |
369 | static const Double_t fgkSSDPConeLittleHoleLength; // SSD Cone Little Hole Length | |
370 | static const Double_t fgkSSDConeMiddleRadius; // SSD Cone Middle Radius | |
371 | static const Double_t fgkSSDPConeMiddleLength; // SSD Cone Middle Length | |
372 | static const Double_t fgkSSDPConeMiddleWidth; // SSD Cone Middle Width | |
373 | static const Double_t fgkSSDPConeUpRadius; // SSD Cone Up Radius | |
374 | static const Double_t fgkSSDPConeUpMaxRadius; // SSD Cone Up Max Radius | |
375 | static const Double_t fgkSSDPConeUpMiddleRadius; // SSD Cone Up Middle Radius | |
376 | static const Double_t fgkSSDPConeDownRadius; // SSD Cone Down Radius | |
377 | static const Double_t fgkSSDPConeTrapezoidAngle; // SSD Cone Trapezoid Angle | |
378 | static const Double_t fgkSSDPConeTrapezoidBasis; // SSD Cone Trapezoid Basis | |
379 | static const Double_t fgkSSDPConeExternalRadius; // SSD Cone External Radius | |
380 | static const Double_t fgkSSDPConeRadiusWidth; // SSD Cone Radius Width | |
381 | static const Double_t fgkSSDPConeLength; // SSD Cone Length | |
382 | static const Double_t fgkSSDCentralSupportLength; //SSD Central Support Length | |
383 | static const Double_t fgkSSDCentralSupportRadius; // SSD Central Support Radius | |
384 | static const Double_t fgkSSDCentralSupportWidth; // SSD Central Support Width | |
385 | static const Double_t fgkSSDCentralAL3SupportLength; // SSD Central Support Length | |
386 | static const Double_t fgkSSDCentralAL3SupportWidth; // SSD Central Support Width | |
387 | ///////////////////////////////////////////////////////////////////////// | |
388 | // SSD Cables e Patch Panel | |
389 | ///////////////////////////////////////////////////////////////////////// | |
390 | static const Double_t fgkSSDCablesLay5TubeRadiusMin; // Radius Min Cable Tube Layer 5 | |
391 | static const Double_t fgkSSDCablesLay6TubeRadiusMin; // Radius Min Cable Tube Layer 6 | |
392 | static const Double_t fgkSSDCablesLay5RightSideHeight; // Width Lay 5 Cables to be fixed in order to reproduce material budget | |
393 | static const Double_t fgkSSDCablesLay6RightSideHeight; // // Width Lay 5 Cables to be fixed in order to reproduce material budget | |
394 | static const Double_t fgkSSDCableAngle; // Angle Cable | |
395 | static const Double_t fgkSSDCablesLay5RightSideWaterHeight; // Width Lay 5 Water Cables to be fixed in order to reproduce material budget | |
396 | static const Double_t fgkSSDCablesPatchPanel2RB26Angle[2]; // Angle Position Patch Panel RB26 | |
397 | static const Double_t fgkSSDCablesPatchPanel2RB24Angle[2]; // Angle Position Patch Panel RB24 | |
398 | static const Double_t fgkSSDPatchPanel2RB26ITSDistance; // Patch Panel RB26 Position | |
399 | static const Double_t fgkSSDPatchPanel2RB24ITSDistance; // Patch Panel RB24 Position | |
400 | static const Double_t fgkSSDPatchPanel2RB26Radius; // Patch Panel Radius | |
401 | static const Double_t fgkSSDPatchPanel2RB24Radius; // Patch Panel Radius | |
402 | static const Double_t fgkSSDPatchPanelHeigth; // Patch Panel Height | |
403 | static const Double_t fgkSSDCableMaterialBudgetHeight; // SSD Cable Material Budget | |
404 | ///////////////////////////////////////////////////////////////////////// | |
bf210566 | 405 | // Private methods for private members generation |
406 | ///////////////////////////////////////////////////////////////////////// | |
47f8de53 | 407 | |
bf210566 | 408 | void CreateTransformationMatrices(); // Method setting the transformation matrices |
409 | void CreateBasicObjects(); // Method creating the basic objects of ssd geometry | |
410 | void SetSSDSensor(); // Method setting the SSD Layer 5 and 6 sensors | |
411 | TList* GetCarbonFiberSupportList(); // Method generating CarbonFiberSupport | |
412 | TGeoVolume* GetCarbonFiberJunction(Double_t width); // Method generating | |
413 | // CarbonFiberJunction | |
414 | TList* GetCarbonFiberLowerSupportList(); | |
415 | // Method generating CarbonFiberLowerSupport | |
416 | TGeoVolume* GetSSDSensorSupport(Double_t length, Double_t height, | |
417 | Double_t width, Double_t* thickness) const; // | |
418 | // Method generating SSDSensorSupport | |
419 | TGeoVolume* GetCoolingTubeSupport(Int_t nedges); // Method generating CoolingTubeSupport | |
420 | TList* GetSSDHybridParts(); // Method setting Hybrid Components | |
421 | TGeoVolume* GetCoolingBlockSystem(); // Method generating Cooling Block System | |
422 | TGeoVolume* GetSSDStiffenerFlex()const; // Method generating StiffenerFlex | |
423 | TGeoVolume* GetSSDEndFlex(); // Method generating EndFlex | |
424 | TGeoVolume* GetSSDMountingBlock(); // Method generating Mounting Block | |
9b0c60ab | 425 | TGeoVolume* GetMountingBlockClip() const; // Method generating Mounting Block Clip |
bf210566 | 426 | TList* GetCoolingTubeList()const; // Method generating list of Tubes |
427 | TGeoVolume* GetSSDCoolingBlock(Int_t nedges); | |
428 | // Method generating StiffenerFlex | |
429 | TGeoVolume* GetSSDChipCables(Double_t SSDChipCablesHeigth, Int_t nedges); | |
430 | // Method setting ChipCables | |
431 | TList* GetSSDChipSystem(); // Method setting Chip System | |
432 | TGeoVolume* GetSSDChips() const; // Method generating Chips | |
433 | TList* GetLadderCableSegment(Double_t ssdendladdercablelength); | |
434 | // Method generating LadderCableSegment | |
435 | TGeoVolume* GetLadderCable(Int_t n, Double_t ssdendladdercablelength); | |
436 | // Method generating Ladder Cable | |
437 | TGeoVolume* GetLadderCableAssembly(Int_t n, Double_t ssdendladdercablelength); | |
438 | // Method generating Ladder Cable Assembly | |
439 | TList* GetLadderCableAssemblyList(Int_t n, Double_t ssdendladdercablelength); | |
440 | // Method generating Ladder Cable List | |
9b0c60ab | 441 | TList* GetMountingBlockSupport(Int_t nedges); // Get Mounting Block Support |
442 | void SetLadderSupport(Int_t nedges); // It generates the ladder support | |
443 | TGeoVolume* GetEndCapCoolingTube(); // End Cap Cooling Tube | |
444 | TGeoVolume* GetEndCapCoverPlate(); // End Cap Cover Plate | |
445 | TGeoVolume* GetEndCapSideCover() const; // End Cap Side Cover | |
446 | TGeoVolume** GetEndCapCards() const; // End Cap Cards | |
447 | TGeoVolume** EndCapSupport(); // End Cap Support Layer 5 and Layer 6 | |
448 | void SetEndCapSupportAssembly(); // EndCap Support + End Cap Layer 5 and 6 | |
449 | TGeoVolume* GetEndCapEffectiveCables(Double_t radiusmin, Double_t radiusmax, | |
450 | Double_t width,Int_t ncables,char* volname); // End Cap Effective HV Cables | |
bf210566 | 451 | TGeoXtru* GetArcShape(Double_t phi, Double_t rmin, |
452 | Double_t rmax, Int_t nedges, Double_t height); | |
453 | //Auxiliary Method for Arc Shape | |
454 | TGeoArb8* GetArbShape(TVector3* vertexpos[],Double_t* width, | |
455 | Double_t height,char* shapename,Int_t isign = 1) const; | |
456 | // Method generating an Arb shape | |
9b0c60ab | 457 | TGeoXtru* GetScrewShape(Double_t* radius,Int_t* edgesnumber,Double_t* section) const;// Method Generating the Screw Shape |
458 | TGeoXtru* GetHoleShape(Double_t radius, Int_t nedges, Double_t *section) const;// Method Generating the Hole Shape | |
bf210566 | 459 | TVector3* GetReflection(TVector3* vector,Double_t* param) const; |
460 | // Given an axis specified by param, | |
461 | // it gives the reflection of the point respect to the axis | |
462 | TGeoHMatrix* AddTranslationToHMatrix(TGeoHMatrix* ct,Double_t dx,Double_t dy, | |
463 | Double_t dz) const; | |
464 | // add (dx,dy,dz) translation to a initial TGeoCombiTrans | |
d7599219 | 465 | ///////////////////////////////////////////////////////////////////////// |
bf210566 | 466 | // Private members |
44285dfa | 467 | ///////////////////////////////////////////////////////////////////////// |
bf210566 | 468 | // Materials |
44285dfa | 469 | ///////////////////////////////////////////////////////////////////////// |
bf210566 | 470 | TGeoMedium* fSSDChipMedium; // SSD Module Chip Medium |
471 | TGeoMedium* fSSDChipGlueMedium; // SSD Module Chip Glue Layer Medium | |
472 | TGeoMedium* fSSDStiffenerMedium; // SSDStiffener Medium | |
473 | TGeoMedium* fSSDStiffenerConnectorMedium; // SSD Stiffener Connector Medium | |
474 | TGeoMedium* fSSDStiffener0603CapacitorMedium; // SSD Stiffener Capacitor 0603 Medium | |
475 | TGeoMedium* fSSDStiffener1812CapacitorMedium; // SSD Stiffener Capacitor 1812 Medium | |
476 | TGeoMedium* fSSDStiffenerHybridWireMedium; // SSD Stiffener Wire Medium | |
477 | TGeoMedium* fSSDKaptonFlexMedium; // SSD Flex Kapton Layer Medium | |
478 | TGeoMedium* fSSDAlTraceFlexMedium; // SSD Flex Al Layer Medium | |
479 | TGeoMedium* fSSDAlTraceLadderCableMedium; // SSD Ladder Cable Al Layer Medium | |
480 | TGeoMedium* fSSDKaptonLadderCableMedium; // SSD Ladder Cable Kapton Layer Medium | |
481 | TGeoMedium* fSSDKaptonChipCableMedium; // SSD Chip Cables Kapton Layer Medium | |
482 | TGeoMedium* fSSDAlTraceChipCableMedium; // SSD Chip Cables Al Layer Medium | |
483 | TGeoMedium* fSSDAlCoolBlockMedium; // SSD Cooling Block Al Medium | |
484 | TGeoMedium* fSSDSensorMedium; // SSD Sensor Medium | |
485 | TGeoMedium* fSSDSensorSupportMedium; // SSD Sensor Support Medium | |
486 | TGeoMedium* fSSDCarbonFiberMedium; // SSD Carbon Fiber Medium | |
487 | TGeoMedium* fSSDTubeHolderMedium; // Cooling Tube Support Medium | |
488 | TGeoMedium* fSSDCoolingTubeWater; // Medium for Inner Part of Cooling Tube | |
489 | TGeoMedium* fSSDCoolingTubePhynox; // Medium for Cooling Tube | |
9b0c60ab | 490 | TGeoMedium* fSSDSupportRingAl; // Medium for Support Ring |
bf210566 | 491 | TGeoMedium* fSSDMountingBlockMedium; // Medium for SSD Mounting Block |
47f8de53 | 492 | TGeoMedium* fSSDRohaCellCone; // Medium for SSD Ring Cone Support |
bf210566 | 493 | TGeoMedium* fSSDAir; // SSD Air |
47f8de53 | 494 | TGeoMedium* fSSDCopper; // Copper for SSD Cables |
bf210566 | 495 | ///////////////////////////////////////////////////////////////////////// |
496 | Bool_t fCreateMaterials; // Bool variable which verifies if materials have been created | |
497 | Bool_t fTransformationMatrices; // Bool variable which verifies if matrices have been allocated | |
498 | Bool_t fBasicObjects; // Bool variable which verifies if basic objects have been allocated | |
499 | ///////////////////////////////////////////////////////////////////////// | |
500 | // Carbon Fiber Support Matrices and Objects | |
501 | //////////////////////////////////////////// | |
502 | static const Int_t fgkcarbonfibersupportnumber = 2; // Support Number | |
503 | TGeoVolume* fcarbonfibersupport[fgkcarbonfibersupportnumber]; // Support | |
504 | TGeoHMatrix* fcarbonfibersupportmatrix[fgkcarbonfibersupportnumber]; // Support Matrix | |
505 | ///////////////////////// | |
506 | // Carbon Fiber Junction | |
507 | //////////////////////// | |
508 | static const Int_t fgkcarbonfiberjunctionumber = 3; // Carbon Fiber Number | |
509 | TGeoVolume* fcarbonfiberjunction; // Carbon Fiber | |
510 | TGeoHMatrix* fcarbonfiberjunctionmatrix[fgkcarbonfiberjunctionumber]; // Carbon Fiber Matrix | |
511 | ///////////////////////////// | |
512 | // Carbon Fiber Lower Support | |
513 | ///////////////////////////// | |
514 | static const Int_t fgkcarbonfiberlowersupportnumber = 2; // Carbon Fiber Lower Support Number | |
515 | TGeoVolume* fcarbonfiberlowersupport[fgkcarbonfiberlowersupportnumber]; // Carbon Fiber Lower Support | |
516 | TGeoTranslation* fcarbonfiberlowersupportrans[fgkcarbonfiberlowersupportnumber];// Carbon Fiber Lower Support Translation | |
517 | ///////////////////////////// | |
518 | // SSD Sensor Support | |
519 | ///////////////////////////// | |
520 | static const Int_t fgkvolumekind = 2; // volumekind = 0 : side ssd support | |
521 | // volumekind = 1 : central ssd support | |
522 | static const Int_t fgkssdsensorsupportnumber = 3; // SSD Sensor Support Number | |
523 | TGeoVolume** fssdsensorsupport[fgkvolumekind]; // SSD Sensor | |
524 | TGeoHMatrix* fssdsensorsupportmatrix[fgkssdsensorsupportnumber]; // SSD Sensor Matrix | |
525 | ///////////////////////////////////////////////////////////// | |
526 | // SSD Cooling Tube Support | |
527 | ///////////////////////////////////////////////////////////// | |
528 | static const Int_t fgkcoolingtubesupportnumber = 2; // Cooling Tube Support Number | |
529 | TGeoVolume* fcoolingtubesupport; // Cooling Tube Support | |
530 | TGeoHMatrix* fcoolingtubesupportmatrix[fgkcoolingtubesupportnumber]; // Cooling Tube Support Matrix | |
531 | ///////////////////////////////////////////////////////////// | |
532 | // SSD Hybrid | |
533 | ///////////////////////////////////////////////////////////// | |
534 | static const Int_t fgkhybridcompnumber = 3; // Hybrid number | |
535 | TGeoVolume* fssdhybridcomponent[fgkhybridcompnumber]; // Hybrid Components | |
536 | TGeoHMatrix* fhybridmatrix; // Hybrid Matrix | |
537 | ///////////////////////////////////////////////////////////// | |
538 | // SSD Cooling Block System | |
539 | ///////////////////////////////////////////////////////////// | |
540 | static const Int_t fgkcoolingblocknumber = 4; // Cooling Block Number | |
541 | TGeoVolume* fssdcoolingblocksystem; // Cooling Block | |
542 | TGeoHMatrix* fcoolingblocksystematrix; // Cooling Block Matrix | |
543 | TGeoHMatrix* fcoolingblockmatrix[fgkcoolingblocknumber]; // Cooling System Matrix | |
544 | ///////////////////////////////////////////////////////////// | |
545 | // SSD Flex | |
546 | ///////////////////////////////////////////////////////////// | |
547 | static const Int_t fgkflexnumber = 2; // Flex Number | |
548 | TGeoVolume* fssdstiffenerflex; // Stiffener Flex | |
549 | TGeoVolume* fssdendflex; // End flex | |
550 | TGeoHMatrix* fstiffenerflexmatrix[fgkflexnumber]; // Stiffener Flex Matrix | |
551 | TGeoHMatrix* fendflexmatrix[fgkflexnumber]; // End Flex Matrix | |
552 | ///////////////////////////////////////// | |
553 | // Cooling Tube | |
554 | ///////////////////////////////////////// | |
555 | static const Int_t fgkcoolingtubenumber = 3; // Coling Tube Number | |
556 | TGeoHMatrix** fcoolingtubematrix[fgkcoolingtubenumber+1]; // Cooling Tube Matrix | |
9b0c60ab | 557 | TGeoVolume* fcoolingtube[fgkcoolingtubenumber]; // Ladder Cooling Tube |
558 | static const Int_t fgkendladdercoolingtubenumber = 5; // End Ladder Cooling Tube Number | |
559 | TGeoVolume* fendladdercoolingtube[fgkendladdercoolingtubenumber]; // End Ladder Cooling Tube | |
560 | TGeoHMatrix** fendladdercoolingtubematrix[2]; //End ladder cooling tube matrix | |
bf210566 | 561 | ///////////////////////////////////////// |
562 | // End Ladder Components | |
563 | ///////////////////////////////////////// | |
564 | TGeoVolumeAssembly* fendladdersegment[2]; // End Ladder Segment | |
565 | TGeoHMatrix** fendladdersegmentmatrix[2]; // End Ladder Matrix | |
9b0c60ab | 566 | ///////////////////////////////////////////////////////////// |
567 | // End Ladder SSD Cooling Tube Support | |
568 | ///////////////////////////////////////////////////////////// | |
569 | TGeoHMatrix*** fendladdercoolingtubesupportmatrix; //End ladder cooling tube support matrix | |
bf210566 | 570 | /////////////////////////////////// |
571 | // End Ladder Carbon Fiber Junction | |
572 | /////////////////////////////////// | |
573 | static const Int_t fgkendlabbercarbonfiberjunctionumber = 2; // End Ladder Carbon fiber Junction Number | |
574 | TGeoVolume** fendladdercarbonfiberjunction[fgkendlabbercarbonfiberjunctionumber]; // End Ladder Carbon fiber Junction Volumes | |
575 | static const Int_t fgkendladdercabonfiberjunctionmatrixnumber = 3; // End Ladder Carbon fiber Junction Matrix Number | |
576 | TGeoHMatrix** fendladdercarbonfiberjunctionmatrix[fgkendlabbercarbonfiberjunctionumber]; // End Ladder Carbon fiber Junction Matrix | |
577 | /////////////////////////////////// | |
578 | // End Ladder Carbon Fiber Support | |
579 | /////////////////////////////////// | |
580 | static const Int_t fgkendladdercarbonfibermatrixnumber = 2; // End Ladder Carbon fiber Matrix Number | |
581 | TGeoHMatrix** fendladdercarbonfibermatrix[fgkendladdercarbonfibermatrixnumber]; // End Ladder Carbon fiber Matrix | |
582 | /////////////////////////////////// | |
583 | // End Ladder SSD Mounting Block | |
584 | /////////////////////////////////// | |
585 | static const Int_t fgkendladdermountingblocknumber = 2; // Mounting Block Number | |
586 | TGeoVolume* fendladdermountingblock; // Mounting Block | |
9b0c60ab | 587 | TGeoVolume* fendladdermountingblockclip; // Mounting Block Clip |
588 | TGeoCombiTrans* fendladdermountingblockcombitrans[fgkendladdermountingblocknumber]; // End Ladder Mounting Block CombiTrans | |
589 | TGeoHMatrix** fendladdermountingblockclipmatrix[fgkendladdermountingblocknumber]; // End Ladder Mounting Block Clip HMatrix | |
bf210566 | 590 | /////////////////////////////////// |
591 | // End Ladder Lower Support | |
592 | /////////////////////////////////// | |
593 | static const Int_t fgkendladderlowersuppnumber = 2; // End Ladder Lower Support Number | |
594 | TGeoTranslation* fendladderlowersupptrans[fgkendladderlowersuppnumber+1]; // End Ladder Lower Support Translations | |
d7599219 | 595 | ///////////////////////////////////////////////////////////////////////// |
596 | // LadderCables | |
597 | ///////////////////////////////////////////////////////////////////////// | |
bf210566 | 598 | static const Int_t fgkladdercablematrixnumber = 4; // Number of TGeoCombiTrans |
599 | // for positioning Ladder Cable volumes | |
600 | static const Int_t fgkladdercablesnumber = 2; // Number of Ladder Cables Layers | |
601 | TGeoHMatrix **fladdercablematrix[fgkladdercablesnumber]; // TGeoCombiTrans for positioning | |
602 | // Ladder Cables volumes | |
603 | /////////////////////////////////// | |
604 | // Ladder Segment | |
605 | /////////////////////////////////// | |
606 | static const Int_t fgkladdersegmentnumber = 2; // Ladder Segment Kinds Number | |
607 | TGeoVolumeAssembly* fladdersegment[fgkladdersegmentnumber]; // Ladder Segment | |
608 | /////////////////////////////////// | |
609 | // Ladder | |
610 | /////////////////////////////////// | |
611 | static const Int_t fgkladdernumber = 2; // Ladder Number | |
612 | TGeoVolume* fladder[fgkladdernumber]; //fladder[0]: ladder of Layer 5 | |
613 | //fladder[1]: ladder of Layer 6 | |
ca86fdb4 | 614 | // TGeoVolumeAssembly* fladder[fgkladdernumber]; |
bf210566 | 615 | TGeoHMatrix** fladdermatrix[fgkladdernumber]; // Ladder Matrix |
616 | /////////////////////////////////// | |
617 | // SSD Sensor | |
618 | /////////////////////////////////// | |
619 | TGeoVolume* fSSDSensor5; // Layer 5 SSD Sensor | |
620 | TGeoVolume* fSSDSensor6; // Layer 6 SSD Sensor | |
621 | TGeoHMatrix** fssdsensormatrix[fgkladdernumber]; // SSD Sensor Matrix | |
622 | /////////////////////////////////// | |
623 | // SSD Layer | |
624 | /////////////////////////////////// | |
625 | static const Int_t fgklayernumber = 2; // Layer Number | |
e5bf64ae | 626 | TGeoVolumeAssembly* fSSDLayer5; // SSD Layer 5 |
627 | TGeoVolumeAssembly* fSSDLayer6; // SSD Layer 6 | |
bf210566 | 628 | TGeoHMatrix** flayermatrix[fgklayernumber]; // Layer Transformations |
d7599219 | 629 | ///////////////////////////////////////////////////////////////////////// |
630 | // Mother Volume | |
631 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 632 | TGeoVolume *fMotherVol; // Mother volume for ITS Layer5 and Layer6 |
633 | TGeoVolume* GetMotherVolume() const { return fMotherVol;}; // Method returning Mother Volume | |
d7599219 | 634 | ///////////////////////////////////////////////////////////////////////// |
9b0c60ab | 635 | // Ladder Support |
636 | ///////////////////////////////////////////////////////////////////////// | |
637 | TGeoVolume* fLay5LadderSupport[2]; // Up and Down parts of Layer5 Ladder Support | |
638 | TGeoVolume* fLay6LadderSupport[2]; // Up and Down parts of Layer6 Ladder Support | |
639 | TGeoVolumeAssembly* fLay5LadderSupportRing; // Layer5 Ladder Support Ring | |
640 | TGeoVolumeAssembly* fLay6LadderSupportRing; // Layer6 Ladder Support Ring | |
641 | ///////////////////////////////////////////////////////////////////////// | |
642 | // End Cap Support + End Cap Assembly | |
643 | ///////////////////////////////////////////////////////////////////////// | |
e5bf64ae | 644 | TGeoVolume** fgkEndCapSupportSystem; // End Cap Support + End Cap Assembly |
9b0c60ab | 645 | ///////////////////////////////////////////////////////////////////////// |
47f8de53 | 646 | // SSD Cone |
647 | ///////////////////////////////////////////////////////////////////////// | |
648 | TGeoVolumeAssembly* fSSDCone; // SSD Cone | |
649 | ///////////////////////////////////////////////////////////////////////// | |
d7599219 | 650 | // Color Display |
651 | ///////////////////////////////////////////////////////////////////////// | |
44285dfa | 652 | Int_t fColorCarbonFiber; // display colors |
653 | Int_t fColorRyton; // === | |
654 | Int_t fColorPhynox; // === | |
655 | Int_t fColorSilicon; // === | |
656 | Int_t fColorAl; // === | |
657 | Int_t fColorKapton; // === | |
658 | Int_t fColorPolyhamide; // === | |
659 | Int_t fColorStiffener; // === | |
660 | Int_t fColorEpoxy; // === | |
bf210566 | 661 | Int_t fColorWater; // === |
662 | Int_t fColorG10; // === | |
9b0c60ab | 663 | ClassDef(AliITSv11GeometrySSD, 3) // ITS v11 SSD geometry |
d7599219 | 664 | }; |
665 | #endif |