#include "AliITS.h"
#include "AliITSDetTypeSim.h"
-#include "AliITSgeom.h"
#include "AliITShit.h"
#include "AliITSCalibrationSDD.h"
#include "AliITSsegmentationSDD.h"
CreateOldGeometry();
- TGeoVolume *vITS = geoManager->GetVolume("ITSV");
+ TGeoVolume *vITSV = geoManager->GetVolume("ITSV");
+ TGeoVolume *vITSS = geoManager->GetVolume("ITSS");
const Char_t *cvsDate="$Date$";
const Int_t kLength=100;
Char_t vstrng[kLength];
if(fInitGeom.WriteVersionString(vstrng,kLength,(AliITSVersion_t)IsVersion(),
- fMinorVersion,cvsDate,cvsRevision))
- vITS->SetTitle(vstrng);
+ fMinorVersion,cvsDate,cvsRevision)) {
+ vITSV->SetTitle(vstrng);
+ vITSS->SetTitle(vstrng);
+ }
if (AliITSInitGeometry::SPDIsTGeoNative()) {
- fSPDgeom->SPDSector(vITS);
+ fSPDgeom->SPDSector(vITSV);
}
if (AliITSInitGeometry::SDDIsTGeoNative()) {
- fSDDgeom->Layer3(vITS);
- fSDDgeom->Layer4(vITS);
- fSDDgeom->ForwardLayer3(vITS);
- fSDDgeom->ForwardLayer4(vITS);
+ fSDDgeom->Layer3(vITSV);
+ fSDDgeom->Layer4(vITSV);
+ fSDDgeom->ForwardLayer3(vITSV);
+ fSDDgeom->ForwardLayer4(vITSV);
}
if (AliITSInitGeometry::SSDIsTGeoNative()) {
- fSSDgeom->Layer5(vITS);
- fSSDgeom->Layer6(vITS);
- fSSDgeom->LadderSupportLayer5(vITS);
- fSSDgeom->LadderSupportLayer6(vITS);
- fSSDgeom->EndCapSupportSystemLayer6(vITS);
- fSSDgeom->EndCapSupportSystemLayer5(vITS);
+ fSSDgeom->Layer5(vITSV);
+ fSSDgeom->Layer6(vITSV);
+ fSSDgeom->LadderSupportLayer5(vITSV);
+ fSSDgeom->LadderSupportLayer6(vITSV);
+ fSSDgeom->EndCapSupportSystemLayer6(vITSV);
+ fSSDgeom->EndCapSupportSystemLayer5(vITSV);
}
if (AliITSInitGeometry::SPDshieldIsTGeoNative())
- fSupgeom->SPDCone(vITS);
+ fSupgeom->SPDCone(vITSV);
if (AliITSInitGeometry::SDDconeIsTGeoNative())
- fSupgeom->SDDCone(vITS);
+ fSupgeom->SDDCone(vITSV);
if (AliITSInitGeometry::SSDconeIsTGeoNative())
- fSupgeom->SSDCone(vITS);
+ fSupgeom->SSDCone(vITSV);
if (AliITSInitGeometry::ServicesAreTGeoNative()) {
- fSDDgeom->SDDCables(vITS);
- fSSDgeom->SSDCables(vITS);
- fSupgeom->ServicesCableSupport(vITS);
+ fSDDgeom->SDDCables(vITSV);
+ fSSDgeom->SSDCables(vITSV);
+ fSupgeom->ServicesCableSupport(vITSS);
+ }
+
+ if (AliITSInitGeometry::SupportIsTGeoNative()) {
+ fSupgeom->ITSTPCSupports(vITSS);
}
}
dgh[50] = 85.;
// gMC->Gsvolu("ITSV", "PCON", idtmed[205], dgh, 51);
new TGeoVolumeAssembly("ITSV");
+ new TGeoVolumeAssembly("ITSS");
// --- Place the ghost volume in its mother volume (ALIC) and make it
// invisible
// gMC->Gspos("ITSV", 1, "ALIC", 0., 0., 0., 0, "ONLY");
//gMC->Gspos("ITSV", 1, "ALIC", 0., 0., 0., idrotm[199], "MANY");
- //gMC->Gsatt("ITSV", "SEEN", 0);
+ //gGeoManager->SetVolumeAttribute("ITSV", "SEEN", 0);
//gMC->Gspos("ITSV", 1, "ALIC", 0., 0., 0., 0, "MANY"); //=== LG
gMC->Gspos("ITSV", 1, "ALIC", 0., 0., 0., 0, "ONLY"); //=== LG
+ gMC->Gspos("ITSS", 1, "ALIC", 0., 0., 0., 0, "ONLY"); //=== MS
// --- Define ghost volume containing the six layers and fill it with air
// --- Place the ghost volume in its mother volume (ITSV) and make it
// invisible
//gMC->Gspos("ITSD", 1, "ITSV", 0., 0., 0., 0, "ONLY");
- //gMC->Gsatt("ITSD", "SEEN", 0);
+ //gGeoManager->SetVolumeAttribute("ITSD", "SEEN", 0);
//======================================================================
// Let's make ITSD an assembly, because we can then add the new geometry
dgh[1] = 59.;
dgh[2] = 0.6;
gMC->Gsvolu("ICYL", "TUBE", idtmed[210], dgh, 3);
- gMC->Gspos("ICYL", 1, "ITSV", 0., 0., -74.1,idrotm[199], "ONLY");
- gMC->Gspos("ICYL", 2, "ITSV", 0., 0., 74.1, 0, "ONLY");
+ gMC->Gspos("ICYL", 1, "ITSS", 0., 0., -74.1,idrotm[199], "ONLY");
+ gMC->Gspos("ICYL", 2, "ITSS", 0., 0., 74.1, 0, "ONLY");
// --- DEFINE SUPPORTS FOR RAILS ATTACHED TO THE CYLINDERS
dgh[1] = 3.;
dgh[2] = 5.;// 5. comes from the fact that the volume has to be 567.6/2 cm^3
gMC->Gsvolu("ISR1", "TUBE", idtmed[284], dgh, 3);
- gMC->Gspos("ISR1", 1, "ITSV", 53.4292, 10.7053, -79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 2, "ITSV", 53.4292, -10.7053, -79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 3, "ITSV", -53.4292, 10.7053, -79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 4, "ITSV", -53.4292, -10.7053, -79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 5, "ITSV", 53.4292, 10.7053, 79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 6, "ITSV", 53.4292, -10.7053, 79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 7, "ITSV", -53.4292, 10.7053, 79.75,idrotm[199],"ONLY");
- gMC->Gspos("ISR1", 8, "ITSV", -53.4292, -10.7053, 79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 1, "ITSS", 53.4292, 10.7053, -79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 2, "ITSS", 53.4292, -10.7053, -79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 3, "ITSS", -53.4292, 10.7053, -79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 4, "ITSS", -53.4292, -10.7053, -79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 5, "ITSS", 53.4292, 10.7053, 79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 6, "ITSS", 53.4292, -10.7053, 79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 7, "ITSS", -53.4292, 10.7053, 79.75,idrotm[199],"ONLY");
+ gMC->Gspos("ISR1", 8, "ITSS", -53.4292, -10.7053, 79.75,idrotm[199],"ONLY");
// --- DEFINE SUPPORTS FOR RAILS ATTACHED TO THE ABSORBER
dgh[1] = 12.;
dgh[2] = 5.;
gMC->Gsvolu("ISR2", "BOX ", idtmed[210], dgh, 3);
- gMC->Gspos("ISR2", 1, "ITSV", -53.5, 0., 125.5, 0, "ONLY");
+ gMC->Gspos("ISR2", 1, "ITSS", -53.5, 0., 125.5, 0, "ONLY");
gMC->Gsvolu("ISR3", "BOX ", idtmed[210], dgh, 3);
- gMC->Gspos("ISR3", 1, "ITSV", 53.5, 0., 125.5, 0, "ONLY");
+ gMC->Gspos("ISR3", 1, "ITSS", 53.5, 0., 125.5, 0, "ONLY");
dgh[0] = 5.-2.;
dgh[1] = 12.-2.;
dgh[1] = 5.;
dgh[2] = 2.;
gMC->Gsvolu("ISR6", "TUBE", idtmed[210], dgh, 3);
- gMC->Gspos("ISR6", 1, "ITSV", 0., 54., 77., 0, "ONLY");
- gMC->Gspos("ISR6", 2, "ITSV", 0., 54., -77., 0, "ONLY");
- gMC->Gspos("ISR6", 3, "ITSV", 0., -54., -77., 0, "ONLY");
+ gMC->Gspos("ISR6", 1, "ITSS", 0., 54., 77., 0, "ONLY");
+ gMC->Gspos("ISR6", 2, "ITSS", 0., 54., -77., 0, "ONLY");
+ gMC->Gspos("ISR6", 3, "ITSS", 0., -54., -77., 0, "ONLY");
}
Float_t wINOX[9]={0.0003,0.02,0.01,0.00045,0.0003,0.12,0.17,0.025,0.654};
Float_t dINOX = 8.03;
+ //AISI 304 L (from F.Tosello's web page - M.S. 18 Oct 10)
+
+ Float_t a304L[8]={12.0107,54.9380, 28.0855,30.9738,32.066,58.6928,51.9961,55.845};
+ Float_t z304L[8]={6.,25.,14.,15.,16., 28.,24.,26.};
+ Float_t w304L[8]={0.0003,0.02,0.01,0.00045,0.003,0.0925,0.19,0.6865};
+ Float_t d304L = 8.03;
+
//SDD HV microcable
Float_t aHVm[5]={12.0107,1.00794,14.0067,15.9994,26.981538};
Float_t wALVm[5]={0.392653705471,0.0128595919215,0.041626868025,0.118832707289, 0.431909};
Float_t dALVm = 2.0502;
- //X7R capacitors
+ //X7R capacitors - updated from F.Tosello's web page - M.S. 18 Oct 10
+
+ Float_t aX7R[6]={137.327,47.867,15.9994,58.6928,63.5460,118.710};
+ Float_t zX7R[6]={56.,22.,8.,28.,29.,50.};
+ Float_t wX7R[6]={0.524732,0.176736,0.179282,0.079750,0.019750,0.019750};
+ Float_t dX7R = 6.07914;
+
+ //X7R weld, i.e. Sn 60% Pb 40% (from F.Tosello's web page - M.S. 15 Oct 10)
- Float_t aX7R[7]={137.327,47.867,15.9994,58.6928,63.5460,118.710,207.2};
- Float_t zX7R[7]={56.,22.,8.,28.,29.,50.,82.};
- Float_t wX7R[7]={0.251639432,0.084755042,0.085975822,0.038244751,0.009471271,0.321736471,0.2081768};
- Float_t dX7R = 7.14567;
+ Float_t aX7Rweld[2]={118.71 , 207.20};
+ Float_t zX7Rweld[2]={ 50. , 82. };
+ Float_t wX7Rweld[2]={ 0.60 , 0.40};
+ Float_t dX7Rweld = 8.52358;
// AIR
Float_t wInAl[5] = {.816164, .131443,.0330906,.0183836,.000919182};
Float_t dInAl = 3.075;
+ // Aluminum alloy with 12% Copper - 21 Oct 10
+
+ Float_t aAlCu12[2] = {26.9815, 63.546};
+ Float_t zAlCu12[2] = {13. , 29. };
+ Float_t wAlCu12[2] = { 0.88 , 0.12 };
+ Float_t dAlCu12 = 2.96;
+
// Kapton
Float_t aKapton[4]={1.00794,12.0107, 14.010,15.9994};
Float_t wPVC[3] = { 2. , 3. , 1. };
Float_t dPVC = 1.3;
+ // PBT (Polybutylene terephthalate = C12-H12-O4) - 01 Sep 10
+ Float_t aPBT[3] = { 12.0107, 1.00794, 15.9994};
+ Float_t zPBT[3] = { 6. , 1. , 8. };
+ Float_t wPBT[3] = { 12. ,12. , 4. };
+ Float_t dPBT = 1.31;
+
+ // POLYAX (POLYAX = C37-H24-O6-N2) - 03 Sep 10
+ Float_t aPOLYAX[4] = { 12.0107, 1.00794, 15.9994, 14.00674};
+ Float_t zPOLYAX[4] = { 6. , 1. , 8. , 7. };
+ Float_t wPOLYAX[4] = { 37. ,24. , 6. , 2. };
+ Float_t dPOLYAX = 1.27;
+
+ // PPS (PPS = C6-H4-S) - 05 Sep 10
+ Float_t aPPS[3] = { 12.0107, 1.00794, 32.066};
+ Float_t zPPS[3] = { 6. , 1. , 16. };
+ Float_t wPPS[3] = { 6. , 4. , 1. };
+ Float_t dPPS = 1.35;
+
+ // Megolon (Polyolefin = (C-H2)n) - 20 Oct 10
+ Float_t aMegolon[2] = { 12.0107, 1.00794};
+ Float_t zMegolon[2] = { 6. , 1. };
+ Float_t wMegolon[2] = { 1. , 2. };
+ Float_t dMegolon = 1.51; // Mean of various types
+
+ // Standard glass (from glassproperties.com/glasses - M.S. 21 Oct 10)
+ Float_t aStdGlass[7] = {15.9994 ,28.0855 ,22.98977 ,40.078 ,
+ 24.305 ,26.981539,39.0983 };
+ Float_t zStdGlass[7] = { 8. ,14. ,11. ,20. ,
+ 12. ,13. ,19. };
+ Float_t wStdGlass[7] = { 0.468377, 0.348239, 0.096441, 0.071469,
+ 0.006030, 0.005293, 0.004151};
+ Float_t dStdGlass = 2.53;
+
+ // Glass Fiber (from F.Tosello's web page - M.S. 15 Oct 10)
+ Float_t aGlass[11] = {15.9994 ,28.0855 ,40.078 ,26.981539,10.811 ,
+ 24.305 ,39.0983 ,22.98977 ,18.9984 ,47.867 ,55.845};
+ Float_t zGlass[11] = { 8. ,14. ,20 ,13 , 5 ,
+ 12. ,19 ,11 , 9 ,22 ,26 };
+ Float_t wGlass[11] = { 0.473610, 0.252415, 0.135791, 0.068803, 0.023293,
+ 0.015076, 0.008301, 0.007419, 0.007000, 0.004795, 0.003497};
+ Float_t dGlass = 2.61;
+
+ // Ryton R-4 04 (from F.Tosello's web page - M.S. 15 Oct 10)
+ Float_t aRyton[14] = {15.9994 ,28.0855 ,40.078 ,26.981539,10.811 ,
+ 24.305 ,39.0983 ,22.98977 ,18.9984 ,47.867 ,
+ 55.845 ,12.0107 , 1.00794 ,32.066 };
+ Float_t zRyton[14] = { 8. ,14. ,20. ,13. , 5. ,
+ 12. ,19. ,11. , 9. ,22. ,
+ 26. , 6. , 1. ,16. };
+ Float_t wRyton[14] = { 0.189445, 0.100966, 0.054316, 0.027521, 0.009317,
+ 0.006030, 0.003320, 0.002968, 0.002800, 0.001918,
+ 0.001399, 0.399760, 0.022365, 0.177875};
+ Float_t dRyton = 1.65;
+
+ // Plexiglas (Poly(methyl methacrylate) (C5O2H8)n - M.S. 05 nov 10)
+ Float_t aPlexy[3] = { 12.0107, 15.9994, 1.00794};
+ Float_t zPlexy[3] = { 6. , 8. , 1. };
+ Float_t wPlexy[3] = { 5. , 2. , 8. };
+ Float_t dPlexy = 1.18;
+
//SSD NiSn capacitor ends
Float_t aNiSn[2] = { 56.6934,118.710};
Float_t zNiSn[2] = { 28., 50.};
AliMixture(27,"GEN Air$",aAir,zAir,dAir,4,wAir);
AliMedium(27,"GEN Air$",27,0,ifield,fieldm,tmaxfdAir,stemaxAir,deemaxAir,epsilAir,stminAir);
+ AliMixture(35,"PLEXYGLAS$",aPlexy,zPlexy,dPlexy,-3,wPlexy);
+ AliMedium(35,"PLEXYGLAS$",35,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(36,"STDGLASS$",aStdGlass,zStdGlass,dStdGlass,7,wStdGlass);
+ AliMedium(36,"STDGLASS$",36,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(37,"ALCU12$",aAlCu12,zAlCu12,dAlCu12,2,wAlCu12);
+ AliMedium(37,"ALCU12$",37,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(38,"MEGOLON$",aMegolon,zMegolon,dMegolon,-2,wMegolon);
+ AliMedium(38,"MEGOLON$",38,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(39,"RYTON$",aRyton,zRyton,dRyton,14,wRyton);
+ AliMedium(39,"RYTON$",39,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(40,"GLASS FIBER$",aGlass,zGlass,dGlass,11,wGlass);
+ AliMedium(40,"GLASS FIBER$",40,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(41,"AISI304L$",a304L,z304L,d304L,8,w304L);
+ AliMedium(41,"AISI304L$",41,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMaterial(42,"NICKEL$",0.58693E+02,0.28000E+02,0.89080E+01,0.14200E+01,0.99900E+03);
+ AliMedium(42,"NICKEL$",42,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(43,"SDD X7R weld$",aX7Rweld,zX7Rweld,dX7Rweld,2,wX7Rweld);
+ AliMedium(43,"SDD X7R weld$",43,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(44,"PPS$",aPPS,zPPS,dPPS,-3,wPPS);
+ AliMedium(44,"PPS$",44,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(45,"POLYAX$",aPOLYAX,zPOLYAX,dPOLYAX,-4,wPOLYAX);
+ AliMedium(45,"POLYAX$",45,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ AliMixture(46,"PBT$",aPBT,zPBT,dPBT,-3,wPBT);
+ AliMedium(46,"PBT$",46,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
AliMixture(47,"PVC$",aPVC,zPVC,dPVC,-3,wPVC);
AliMedium(47,"PVC$",47,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
AliMixture(76,"SPDBUS(AL+KPT+EPOX)$",aSPDbus,zSPDbus,dSPDbus,5,wSPDbus);
AliMedium(76,"SPDBUS(AL+KPT+EPOX)$",76,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
- AliMixture(77,"SDD X7R capacitors$",aX7R,zX7R,dX7R,7,wX7R);
+ AliMixture(77,"SDD X7R capacitors$",aX7R,zX7R,dX7R,6,wX7R);
AliMedium(77,"SDD X7R capacitors$",77,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
AliMixture(78,"SDD ruby sph. Al2O3$",aAlOxide,zAlOxide,dAlOxide,2,wAlOxide);
deemax,epsil,stmin);
- // Anticorodal: Aliminum alloy for tray ring support on Side A
- den = 2.710301;
- AliMaterial(93,"ANTICORODAL$",0.26982E+02,0.13000E+02,den,0.89000E+01,0.99900E+03);
+ // Anticorodal (Aliminum alloy) - 08 nov 10
+ // A,Z from Root TGeoElementTable, W from Web sites
+ zZ[0] = 13.0; aA[0] = 26.9815; // Aluminium
+ zZ[1] = 29.0; aA[1] = 63.546 ; // Copper
+ zZ[2] = 26.0; aA[2] = 55.845 ; // Iron
+ zZ[3] = 25.0; aA[3] = 54.938 ; // Manganese
+ zZ[4] = 12.0; aA[4] = 24.305 ; // Magnesium
+ zZ[5] = 14.0; aA[5] = 28.0855; // Silicon
+ zZ[6] = 30.0; aA[6] = 65.39 ; // Zinc
+ zZ[7] = 24.0; aA[7] = 51.9961; // Chromium
+ zZ[8] = 22.0; aA[8] = 47.867 ; // Titanium
+
+ wW[1] = 0.001000;//Cu
+ wW[2] = 0.005000;//Fe
+ wW[3] = 0.007000;//Mn - mean value
+ wW[4] = 0.009000;//Mg - mean value
+ wW[5] = 0.001000;//Si - mean value
+ wW[6] = 0.002000;//Zn
+ wW[7] = 0.002500;//Cr
+ wW[8] = 0.001000;//Ti
+
+ Double_t totFrac = 0;
+ for (Int_t j=1; j<9; j++)
+ totFrac += wW[j];
+ wW[0] = 1. - totFrac;//Al - the remainder
+
+ den = 2.69;
+ AliMixture(93,"ANTICORODAL$",aA,zZ,den,+9,wW);
AliMedium(93,"ANTICORODAL$",93,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
-
-}
-//______________________________________________________________________
-void AliITSv11Hybrid::InitAliITSgeom() const {
- // Based on the geometry tree defined in Geant 3.21, this
- // routine initilizes the Class AliITSgeom from the Geant 3.21 ITS geometry
- // sturture.
- // Inputs:
- // none.
- // Outputs:
- // none.
- // Return:
- // none.
-
- Error("InitAliITSgeom", "QQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQq Im I used?");
-
- /*
- const Int_t knlayers = 6;
- const Int_t kndeep = 3;
- const AliITSDetector kidet[knlayers]={kSPD,kSPD,kSDD,kSDD,kSSD,kSSD};
- const TString knames[2][knlayers] = {
- {"/ALIC_1/ITSV_1/ITSD_1/IT12_1/I12A_%d/I10A_%d/I103_%d/I101_1/ITS1_1", // lay=1
- "/ALIC_1/ITSV_1/ITSD_1/IT12_1/I12A_%d/I20A_%d/I1D3_%d/I1D1_1/ITS2_1", // lay=2
- "/ALIC_1/ITSV_1/ITSD_1/IT34_1/I004_%d/I302_%d/ITS3_%d", // lay=3
- "/ALIC_1/ITSV_1/ITSD_1/IT34_1/I005_%d/I402_%d/ITS4_%d", // lay=4
- "/ALIC_1/ITSV_1/ITSD_1/IT56_1/I565_%d/I562_%d/ITS5_%d", // lay=5
- "/ALIC_1/ITSV_1/ITSD_1/IT56_1/I569_%d/I566_%d/ITS6_%d"},// lay=6
- {"/ALIC_1/ITSV_1/ITSD_1/IT12_1/I12B_%d/I10B_%d/I107_%d/I101_1/ITS1_1", // lay=1
- "/ALIC_1/ITSV_1/ITSD_1/IT12_1/I12B_%d/I20B_%d/I1D7_%d/I1D1_1/ITS2_1", // lay=2
- "/ALIC_1/ITSV_1/ITSD_1/IT34_1/I004_%d/I302_%d/ITS3_%d", // lay=3
- "/ALIC_1/ITSV_1/ITSD_1/IT34_1/I005_%d/I402_%d/ITS4_%d", // lay=4
- "/ALIC_1/ITSV_1/ITSD_1/IT56_1/I565_%d/I562_%d/ITS5_%d", // lay=5
- "/ALIC_1/ITSV_1/ITSD_1/IT56_1/I569_%d/I566_%d/ITS6_%d"}
- };
- const Int_t kitsGeomTreeCopys[knlayers][kndeep]= {{10, 2, 4},// lay=1
- {10, 4, 4},// lay=2
- {14, 6, 1},// lay=3
- {22, 8, 1},// lay=4
- {34,22, 1},// lay=5
- {38,25, 1}};//lay=6
- Int_t nlad[knlayers],ndet[knlayers];
- Int_t mod,lay,lad=0,det=0,i,j,k,cp0,cp1,cp2;
- TString path,shapeName;
- TGeoHMatrix materix;
- Double_t trans[3]={3*0.0},rot[10]={9*0.0,1.0};
- TArrayD shapePar;
- TArrayF shapeParF;
- Bool_t shapeDefined[3]={kFALSE,kFALSE,kFALSE};
-
- AliDebug(1,"Reading Geometry transformation directly from Modler.");
- mod = 0;
- for(i=0;i<knlayers;i++){
- k = 1;
- for(j=0;j<kndeep;j++) if(kitsGeomTreeCopys[i][j]!=0)
- k *= TMath::Abs(kitsGeomTreeCopys[i][j]);
- mod += k;
- } // end for i
-
- SetITSgeom(0);
- nlad[0]=20;nlad[1]=40;nlad[2]=14;nlad[3]=22;nlad[4]=34;nlad[5]=38;
- ndet[0]= 4;ndet[1]= 4;ndet[2]= 6;ndet[3]= 8;ndet[4]=22;ndet[5]=25;
- AliITSgeom* geom = new AliITSgeom(0,6,nlad,ndet,mod);
- SetITSgeom(geom);
- mod = 0;
- for(lay=1;lay<=knlayers;lay++){
- for(cp0=1;cp0<=kitsGeomTreeCopys[lay-1][0];cp0++){
- for(cp1=1;cp1<=kitsGeomTreeCopys[lay-1][1];cp1++){
- for(cp2=1;cp2<=kitsGeomTreeCopys[lay-1][2];cp2++){
- path.Form(knames[fMinorVersion-1][lay-1].Data(),
- cp0,cp1,cp2);
- switch (lay){
- case 1:{
- det = cp2;
- lad = cp1+2*(cp0-1);
- }break;
- case 2:{
- det = cp2;
- lad = cp1+4*(cp0-1);
- } break;
- case 3: case 4: case 5: case 6:{
- det = cp1;
- lad = cp0;
- } break;
- } // end switch
- //AliInfo(Form("path=%s lay=%d lad=%d det=%d",
- // path.Data(),lay,lad,det));
- gMC->GetTransformation(path.Data(),materix);
- gMC->GetShape(path.Data(),shapeName,shapePar);
- shapeParF.Set(shapePar.GetSize());
- for(i=0;i<shapePar.GetSize();i++) shapeParF[i]=shapePar[i];
- geom->CreateMatrix(mod,lay,lad,det,kidet[lay-1],trans,rot);
- geom->SetTrans(mod,materix.GetTranslation());
- geom->SetRotMatrix(mod,materix.GetRotationMatrix());
- geom->GetGeomMatrix(mod)->SetPath(path.Data());
- switch (lay){
- case 1: case 2:
- if(!shapeDefined[kSPD]){
- geom->ReSetShape(kSPD,new AliITSgeomSPD425Short(
- shapeParF.GetSize(),shapeParF.GetArray()));
- shapeDefined[kSPD] = kTRUE;
- }break;
- case 3: case 4:
- if(!shapeDefined[kSDD]){
- geom->ReSetShape(kSDD,new AliITSgeomSDD256(
- shapeParF.GetSize(),shapeParF.GetArray()));
- shapeDefined[kSDD] = kTRUE;
- }break;
- case 5: case 6:
- if(!shapeDefined[kSSD]){
- geom->ReSetShape(kSSD,new AliITSgeomSSD75and275(
- shapeParF.GetSize(),shapeParF.GetArray()));
- shapeDefined[kSSD] = kTRUE;
- }break;
- default:{
- }break;
- } // end switch
- mod++;
- } /// end for cp2
- } // end for cp1
- } // end for cp0
- } // end for lay
- return;
- */
+ // Hokotol (another Aluminium alloy) - 08 nov 10
+ // A,Z from Root TGeoElementTable, W from Web sites
+ zZ[0] = 13.0; aA[0] = 26.9815; // Aluminium
+ zZ[1] = 29.0; aA[1] = 63.546 ; // Copper
+ zZ[2] = 26.0; aA[2] = 55.845 ; // Iron
+ zZ[3] = 25.0; aA[3] = 54.938 ; // Manganese
+ zZ[4] = 12.0; aA[4] = 24.305 ; // Magnesium
+ zZ[5] = 14.0; aA[5] = 28.0855; // Silicon
+ zZ[6] = 30.0; aA[6] = 65.39 ; // Zinc
+ zZ[7] = 24.0; aA[7] = 51.9961; // Chromium
+ zZ[8] = 22.0; aA[8] = 47.867 ; // Titanium
+ zZ[9] = 40.0; aA[9] = 91.224 ; // Zirconium
+
+ wW[1] = 0.020500;//Cu - mean value
+ wW[2] = 0.000300;//Fe
+ wW[3] = 0.022000;//Mn - mean value
+ wW[4] = 0.001000;//Mg - mean value
+ wW[5] = 0.002000;//Si - mean value
+ wW[6] = 0.066500;//Zn
+ wW[7] = 0.005000;//Cr
+ wW[8] = 0.000600;//Ti
+ wW[9] = 0.001650;//Zr - mean value
+
+ totFrac = 0;
+ for (Int_t j=1; j<10; j++)
+ totFrac += wW[j];
+ wW[0] = 1. - totFrac;//Al - the remainder
+
+ den = 2.69;
+ AliMixture(34,"HOKOTOL$",aA,zZ,den,+10,wW);
+ AliMedium(34,"HOKOTOL$",34,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
+ // Ergal (7075) (yet another Aluminium alloy) - 09 nov 10
+ // A,Z from Root TGeoElementTable, W from Web sites
+ zZ[0] = 13.0; aA[0] = 26.9815; // Aluminium
+ zZ[1] = 29.0; aA[1] = 63.546 ; // Copper
+ zZ[2] = 26.0; aA[2] = 55.845 ; // Iron
+ zZ[3] = 25.0; aA[3] = 54.938 ; // Manganese
+ zZ[4] = 12.0; aA[4] = 24.305 ; // Magnesium
+ zZ[5] = 14.0; aA[5] = 28.0855; // Silicon
+ zZ[6] = 30.0; aA[6] = 65.39 ; // Zinc
+ zZ[7] = 24.0; aA[7] = 51.9961; // Chromium
+ zZ[8] = 22.0; aA[8] = 47.867 ; // Titanium
+
+ wW[1] = 0.016000;//Cu - mean value
+ wW[2] = 0.005000;//Fe
+ wW[3] = 0.003000;//Mn
+ wW[4] = 0.025000;//Mg - mean value
+ wW[5] = 0.004000;//Si
+ wW[6] = 0.056000;//Zn - mean value
+ wW[7] = 0.002300;//Cr - mean value
+ wW[8] = 0.002000;//Ti
+
+ totFrac = 0;
+ for (Int_t j=1; j<9; j++)
+ totFrac += wW[j];
+ wW[0] = 1. - totFrac;//Al - the remainder
+
+ den = 2.69;
+ AliMixture(33,"ERGAL$",aA,zZ,den,+9,wW);
+ AliMedium(33,"ERGAL$",33,0,ifield,fieldm,tmaxfd,stemax,deemax,epsil,stmin);
+
}
//______________________________________________________________________
}// end if
return;
}
-//______________________________________________________________________
-void AliITSv11Hybrid::DrawModule() const{
- // Draw a shaded view of the FMD version 10.
- // Inputs:
- // none.
- // Outputs:
- // none.
- // Return:
- // none.
-
- // Set everything unseen
- gMC->Gsatt("*", "seen", -1);
- //
- // Set ALIC mother visible
- gMC->Gsatt("ALIC","SEEN",0);
- //
- // Set the volumes visible
- gMC->Gsatt("ITSD","SEEN",0);
- gMC->Gsatt("ITS1","SEEN",1);
- gMC->Gsatt("ITS2","SEEN",1);
- gMC->Gsatt("ITS3","SEEN",1);
- gMC->Gsatt("ITS4","SEEN",1);
- gMC->Gsatt("ITS5","SEEN",1);
- gMC->Gsatt("ITS6","SEEN",1);
- //
- gMC->Gsatt("IPCB","SEEN",1);
- gMC->Gsatt("ICO2","SEEN",1);
- gMC->Gsatt("ICER","SEEN",0);
- gMC->Gsatt("ISI2","SEEN",0);
- gMC->Gsatt("IPLA","SEEN",0);
- gMC->Gsatt("ICO3","SEEN",0);
- gMC->Gsatt("IEPX","SEEN",0);
- gMC->Gsatt("ISI3","SEEN",1);
- gMC->Gsatt("ISUP","SEEN",0);
- gMC->Gsatt("ICHO","SEEN",0);
- gMC->Gsatt("ICMO","SEEN",0);
- gMC->Gsatt("ICMD","SEEN",0);
- gMC->Gsatt("ICCO","SEEN",1);
- gMC->Gsatt("ICCM","SEEN",0);
- gMC->Gsatt("ITMD","SEEN",0);
- gMC->Gsatt("ITTT","SEEN",1);
- //
- gMC->Gdopt("hide", "on");
- gMC->Gdopt("shad", "on");
- gMC->Gsatt("*", "fill", 7);
- gMC->SetClipBox(".");
- gMC->SetClipBox("*", 0, 300, -300, 300, -300, 300);
- gMC->DefaultRange();
- gMC->Gdraw("alic", 40, 30, 0, 11, 10, .07, .07);
- gMC->Gdhead(1111, "Inner Tracking System Version 1");
- gMC->Gdman(17, 6, "MAN");
-}
-
//______________________________________________________________________
void AliITSv11Hybrid::StepManager(){
// Called for every step in the ITS, then calles the AliITShit class