| 1 | #include "PamVMCDetND.h" | 
| 2 | #include <TGeoMaterial.h> | 
| 3 | ClassImp(PamVMCDetND) | 
| 4 |  | 
| 5 | void  PamVMCDetND::DefineGeometry(){ | 
| 6 |  | 
| 7 |  | 
| 8 | TGeoMaterial *m=0; | 
| 9 | TGeoMixture *x=0; | 
| 10 | TString s = "ALUMINIUM"; | 
| 11 | m = GetMat(s); | 
| 12 | if(!m){ | 
| 13 | m = new TGeoMaterial(s,26.98,13,2.7); | 
| 14 | m->SetUniqueID(   9); | 
| 15 | } | 
| 16 |  | 
| 17 | s = "IRON"; | 
| 18 | m = GetMat(s); | 
| 19 | if(!m){ | 
| 20 | m = new TGeoMaterial(s,55.85,26,7.87); | 
| 21 | m->SetUniqueID(  10); | 
| 22 | } | 
| 23 |  | 
| 24 | s = "N2GAS"; | 
| 25 | m = GetMat(s); | 
| 26 | if (!m){ | 
| 27 | m = new TGeoMaterial(s,14.01,7,0.1250000E-02); | 
| 28 | m->SetUniqueID(  19); | 
| 29 | } | 
| 30 |  | 
| 31 |  | 
| 32 | s = "CADMIUM"; | 
| 33 | m = GetMat(s); | 
| 34 | if(!m){ | 
| 35 | m = new TGeoMaterial(s,112.411,48,8.65); | 
| 36 | m->SetUniqueID(  31); | 
| 37 | } | 
| 38 |  | 
| 39 | s = "He3"; | 
| 40 | m = GetMat(s); | 
| 41 | if(!m){ | 
| 42 | // m = new TGeoMaterial(s,3,2,0.1246000E-02); | 
| 43 | m = new TGeoMaterial(s,3,2,0.1246e-2); | 
| 44 | // m->SetState(TGeoMaterial::EGeoMaterialState(3)); | 
| 45 | //m->SetPressure(7*STP_pressure); | 
| 46 | m->SetUniqueID(  33); | 
| 47 | } | 
| 48 |  | 
| 49 | s = "POLYETHYLENE"; | 
| 50 | x = (TGeoMixture*)GetMat(s); | 
| 51 | if(!x){ | 
| 52 | x = new TGeoMixture(s,2,  0.930000    ); | 
| 53 | x->SetUniqueID(  34); | 
| 54 | x->DefineElement(0,12.011,6,0.8562844); | 
| 55 | x->DefineElement(1,1.00794,1,0.1437155); | 
| 56 | } | 
| 57 |  | 
| 58 | TGeoMedium *n =0; | 
| 59 |  | 
| 60 | s="ALUMINIUM"; | 
| 61 | n = (GetMed(s))?GetMed(s): new TGeoMedium(s,1,9,-1,1,40,1,100,0.5000000E-01,0.136283,0.5000000E-03); | 
| 62 |  | 
| 63 | s = "N2 GAS"; | 
| 64 | n = (GetMed(s))?GetMed(s): new TGeoMedium(s,3,19,-1,1,40,1,0.5000000E-01,0.5000000E-01,0.1000000E-02,0.5000000E-03); | 
| 65 |  | 
| 66 | s = "IRON"; | 
| 67 | n = (GetMed(s))?GetMed(s): new TGeoMedium(s,27,10,-1,1,40,1,100,0.5000000E-01,0.2491200E-02,0.5000000E-03); | 
| 68 |  | 
| 69 | s = "CADMIUM"; | 
| 70 | n = (GetMed(s))?GetMed(s):  new TGeoMedium(s,21,31,-1,1,40,1,0.5000000E-01,0.5000000E-01,0.5000000E-03,0.5000000E-03); | 
| 71 |  | 
| 72 | s = "He3"; | 
| 73 | n = (GetMed(s))?GetMed(s):  new TGeoMedium(s,22,33,-1,1,40,1,0.5000000E-01,0.5000000E-01,0.1840000E-01,0.5000000E-03); | 
| 74 |  | 
| 75 | s = "POLYETHYLENE"; | 
| 76 | n = (GetMed(s))?GetMed(s):  new TGeoMedium(s,23,34,-1,1,40,1,100,0.5000000E-01,0.2000000E-01,0.5000000E-03); | 
| 77 |  | 
| 78 | TGeoVolume *v = 0; | 
| 79 |  | 
| 80 | s = "NDBO"; | 
| 81 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),27.5,30.,7.5); | 
| 82 | s = "NDBX"; | 
| 83 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("ALUMINIUM"),21.45,21.45,7.); | 
| 84 | s = "NDCD"; | 
| 85 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("CADMIUM"),21.25,21.25,6.9); | 
| 86 | s = "NDBI"; | 
| 87 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),21.2,21.2,6.875); | 
| 88 | s = "NDTU"; | 
| 89 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeTube(s,GetMed("IRON"),0.,0.925,10.); // orig (s,GetMed("IRON"),0.92,0.925,10) | 
| 90 | s = "NDTI"; | 
| 91 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeTube(s,GetMed("He3"),0.,0.92,9.99); // orig (s,GetMed("He3"),0,0.92,10) | 
| 92 | s = "NDPB"; | 
| 93 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("POLYETHYLENE"),21.2,21.2,1.); | 
| 94 | s = "NDCO"; | 
| 95 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("ALUMINIUM"),27.5,30.,0.5); | 
| 96 | s = "NDBS"; | 
| 97 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("ALUMINIUM"),15,4.275,7.); | 
| 98 | s = "NDSS"; | 
| 99 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),14.8,4.075,6.8); | 
| 100 | s = "NDCI"; | 
| 101 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),21.2,11.3,0.325); | 
| 102 | s = "NDCM"; | 
| 103 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),21.2,4.25,0.325); | 
| 104 | s = "NDCE"; | 
| 105 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),14.6,2.875,0.325); | 
| 106 | s = "NDSI"; | 
| 107 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),1.,7.26,0.325); | 
| 108 | s = "NDSM"; | 
| 109 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),1.,5.8,0.325); | 
| 110 | s = "NDSE"; | 
| 111 | v = (GetVol(s))?GetVol(s): gGeoManager->MakeBox(s,GetMed("N2 GAS"),4.2,1.05,0.325); | 
| 112 |  | 
| 113 |  | 
| 114 | GetVol("NDBO")->AddNode(GetVol("NDBX"),1,new TGeoTranslation(0.,0.,-0.5)); | 
| 115 | GetVol("NDBX")->AddNode(GetVol("NDCD"),1,new TGeoTranslation(0.,0.,0.1)); | 
| 116 | GetVol("NDCD")->AddNode(GetVol("NDBI"),1,new TGeoTranslation(0.,0.,0.25E-01)); | 
| 117 | GetVol("NDBI")->AddNode(GetVol("NDTU"),1,new TGeoCombiTrans(-19.975,0.,0.5E-01,GetRot("rot2")));//FLUKA off | 
| 118 | GetVol("NDTU")->AddNode(GetVol("NDTI"),1,gGeoIdentity);//FLUKA off | 
| 119 | GetVol("NDBI")->AddNode(GetVol("NDTU"),2,new TGeoCombiTrans(-17.625,0.,0.5E-01,GetRot("rot2"))); | 
| 120 | GetVol("NDBI")->AddNode(GetVol("NDTU"),3,new TGeoCombiTrans(-15.275,0.,0.5E-01,GetRot("rot2"))); | 
| 121 | GetVol("NDBI")->AddNode(GetVol("NDTU"),4,new TGeoCombiTrans(-12.925,0.,0.5E-01,GetRot("rot2"))); | 
| 122 | GetVol("NDBI")->AddNode(GetVol("NDTU"),5,new TGeoCombiTrans(-10.575,0.,0.5E-01,GetRot("rot2"))); | 
| 123 | GetVol("NDBI")->AddNode(GetVol("NDTU"),6,new TGeoCombiTrans(-8.225,0.,0.5E-01,GetRot("rot2"))); | 
| 124 | GetVol("NDBI")->AddNode(GetVol("NDTU"),7,new TGeoCombiTrans(-5.875,0.,0.5E-01,GetRot("rot2"))); | 
| 125 | GetVol("NDBI")->AddNode(GetVol("NDTU"),8,new TGeoCombiTrans(-3.525,0.,0.5E-01,GetRot("rot2"))); | 
| 126 | GetVol("NDBI")->AddNode(GetVol("NDTU"),9,new TGeoCombiTrans(-1.175,0.,0.5E-01,GetRot("rot2"))); | 
| 127 | GetVol("NDBI")->AddNode(GetVol("NDTU"),10,new TGeoCombiTrans(1.175,0.,0.5E-01,GetRot("rot2"))); | 
| 128 | GetVol("NDBI")->AddNode(GetVol("NDTU"),11,new TGeoCombiTrans(3.525,0.,0.5E-01,GetRot("rot2"))); | 
| 129 | GetVol("NDBI")->AddNode(GetVol("NDTU"),12,new TGeoCombiTrans(5.875,0.,0.5E-01,GetRot("rot2"))); | 
| 130 | GetVol("NDBI")->AddNode(GetVol("NDTU"),13,new TGeoCombiTrans(8.225,0.,0.5E-01,GetRot("rot2"))); | 
| 131 | GetVol("NDBI")->AddNode(GetVol("NDTU"),14,new TGeoCombiTrans(10.575,0.,0.5E-01,GetRot("rot2"))); | 
| 132 | GetVol("NDBI")->AddNode(GetVol("NDTU"),15,new TGeoCombiTrans(12.925,0.,0.5E-01,GetRot("rot2"))); | 
| 133 | GetVol("NDBI")->AddNode(GetVol("NDTU"),16,new TGeoCombiTrans(15.275,0.,0.5E-01,GetRot("rot2"))); | 
| 134 | GetVol("NDBI")->AddNode(GetVol("NDTU"),17,new TGeoCombiTrans(17.625,0.,0.5E-01,GetRot("rot2"))); | 
| 135 | GetVol("NDBI")->AddNode(GetVol("NDTU"),18,new TGeoCombiTrans(19.975,0.,0.5E-01,GetRot("rot2"))); | 
| 136 | GetVol("NDBI")->AddNode(GetVol("NDTU"),19,new TGeoCombiTrans(-19.975,0.,3.9,GetRot("rot2"))); | 
| 137 | GetVol("NDBI")->AddNode(GetVol("NDTU"),20,new TGeoCombiTrans(-17.625,0.,3.9,GetRot("rot2"))); | 
| 138 | GetVol("NDBI")->AddNode(GetVol("NDTU"),21,new TGeoCombiTrans(-15.275,0.,3.9,GetRot("rot2"))); | 
| 139 | GetVol("NDBI")->AddNode(GetVol("NDTU"),22,new TGeoCombiTrans(-12.925,0.,3.9,GetRot("rot2"))); | 
| 140 | GetVol("NDBI")->AddNode(GetVol("NDTU"),23,new TGeoCombiTrans(-10.575,0.,3.9,GetRot("rot2"))); | 
| 141 | GetVol("NDBI")->AddNode(GetVol("NDTU"),24,new TGeoCombiTrans(-8.225,0.,3.9,GetRot("rot2"))); | 
| 142 | GetVol("NDBI")->AddNode(GetVol("NDTU"),25,new TGeoCombiTrans(-5.875,0.,3.9,GetRot("rot2"))); | 
| 143 | GetVol("NDBI")->AddNode(GetVol("NDTU"),26,new TGeoCombiTrans(-3.525,0.,3.9,GetRot("rot2"))); | 
| 144 | GetVol("NDBI")->AddNode(GetVol("NDTU"),27,new TGeoCombiTrans(-1.175,0.,3.9,GetRot("rot2"))); | 
| 145 | GetVol("NDBI")->AddNode(GetVol("NDTU"),28,new TGeoCombiTrans(1.175,0.,3.9,GetRot("rot2"))); | 
| 146 | GetVol("NDBI")->AddNode(GetVol("NDTU"),29,new TGeoCombiTrans(3.525,0.,3.9,GetRot("rot2"))); | 
| 147 | GetVol("NDBI")->AddNode(GetVol("NDTU"),30,new TGeoCombiTrans(5.875,0.,3.9,GetRot("rot2"))); | 
| 148 | GetVol("NDBI")->AddNode(GetVol("NDTU"),31,new TGeoCombiTrans(8.225,0.,3.9,GetRot("rot2"))); | 
| 149 | GetVol("NDBI")->AddNode(GetVol("NDTU"),32,new TGeoCombiTrans(10.575,0.,3.9,GetRot("rot2"))); | 
| 150 | GetVol("NDBI")->AddNode(GetVol("NDTU"),33,new TGeoCombiTrans(12.925,0.,3.9,GetRot("rot2"))); | 
| 151 | GetVol("NDBI")->AddNode(GetVol("NDTU"),34,new TGeoCombiTrans(15.275,0.,3.9,GetRot("rot2"))); | 
| 152 | GetVol("NDBI")->AddNode(GetVol("NDTU"),35,new TGeoCombiTrans(17.625,0.,3.9,GetRot("rot2"))); | 
| 153 | GetVol("NDBI")->AddNode(GetVol("NDTU"),36,new TGeoCombiTrans(19.975,0.,3.9,GetRot("rot2"))); | 
| 154 | GetVol("NDBI")->AddNode(GetVol("NDPB"),1,new TGeoTranslation(0.,0.,-5.875)); | 
| 155 | GetVol("NDBI")->AddNode(GetVol("NDPB"),2,new TGeoTranslation(0.,0.,-3.875)); | 
| 156 | GetVol("NDBI")->AddNode(GetVol("NDPB"),3,new TGeoTranslation(0.,0.,-1.875)); | 
| 157 | GetVol("NDBI")->AddNode(GetVol("NDPB"),4,new TGeoTranslation(0.,0.,1.975)); | 
| 158 | GetVol("NDBI")->AddNode(GetVol("NDPB"),5,new TGeoTranslation(0.,0.,5.825)); | 
| 159 | GetVol("NDBO")->AddNode(GetVol("NDCO"),1,new TGeoTranslation(0.,0.,7.)); | 
| 160 | GetVol("NDCO")->AddNode(GetVol("NDCM"),1,new TGeoTranslation(0.,-16.95,0.175)); | 
| 161 | GetVol("NDCO")->AddNode(GetVol("NDCM"),2,new TGeoTranslation(0.,16.95,0.175)); | 
| 162 | GetVol("NDCO")->AddNode(GetVol("NDCI"),1,new TGeoTranslation(0.,0.,0.175)); | 
| 163 | GetVol("NDCO")->AddNode(GetVol("NDCE"),1,new TGeoTranslation(0.,-25.475,0.175)); | 
| 164 | GetVol("NDCO")->AddNode(GetVol("NDCE"),2,new TGeoTranslation(0.,25.475,0.175)); | 
| 165 | GetVol("NDCO")->AddNode(GetVol("NDSM"),1,new TGeoTranslation(-23.6,-14.6,0.175)); | 
| 166 | GetVol("NDCO")->AddNode(GetVol("NDSM"),2,new TGeoTranslation(23.6,-14.6,0.175)); | 
| 167 | GetVol("NDCO")->AddNode(GetVol("NDSM"),3,new TGeoTranslation(-23.6,14.6,0.175)); | 
| 168 | GetVol("NDCO")->AddNode(GetVol("NDSM"),4,new TGeoTranslation(23.6,14.6,0.175)); | 
| 169 | GetVol("NDCO")->AddNode(GetVol("NDSI"),1,new TGeoTranslation(-23.6,0.,0.175)); | 
| 170 | GetVol("NDCO")->AddNode(GetVol("NDSI"),2,new TGeoTranslation(23.6,0.,0.175)); | 
| 171 | GetVol("NDCO")->AddNode(GetVol("NDSE"),1,new TGeoTranslation(-20.4,-23.65,0.175)); | 
| 172 | GetVol("NDCO")->AddNode(GetVol("NDSE"),2,new TGeoTranslation(20.4,-23.65,0.175)); | 
| 173 | GetVol("NDCO")->AddNode(GetVol("NDSE"),3,new TGeoTranslation(-20.4,23.65,0.175)); | 
| 174 | GetVol("NDCO")->AddNode(GetVol("NDSE"),4,new TGeoTranslation(20.4,23.65,0.175)); | 
| 175 | GetVol("NDBO")->AddNode(GetVol("NDBS"),1,new TGeoTranslation(0.,-25.725,-0.5)); | 
| 176 | GetVol("NDBS")->AddNode(GetVol("NDSS"),1,gGeoIdentity); | 
| 177 | GetVol("NDBO")->AddNode(GetVol("NDBS"),2,new TGeoTranslation(0.,25.725,-0.5)); | 
| 178 |  | 
| 179 |  | 
| 180 | SetMotherProp(GetVol("NDBO"),1,new TGeoTranslation(0.,0.,-6.289)); | 
| 181 |  | 
| 182 | }; | 
| 183 |  | 
| 184 | void  PamVMCDetND::DefineCuts(){ | 
| 185 |  | 
| 186 | TString  s ="ALUMINIUM"; // default GPAMELA parameters | 
| 187 | if (GetMed(s) && !GetCC(s)) | 
| 188 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 189 | 0.001, 0.01, 1., 1., 1., 0., 1., 1., 1., 4., 1., 1., 1., 1.)); | 
| 190 | s ="N2 GAS"; | 
| 191 | if (GetMed(s) && !GetCC(s)) | 
| 192 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 193 | 0.001, 0.01, 1., 1., 1., 0., 0., 1., 1., 4., 1., 1., 2., 1.)); | 
| 194 | s = "IRON";  //default GPAMELA parameters | 
| 195 | if (GetMed(s) && !GetCC(s)) | 
| 196 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 197 | 0.001, 0.01, 1., 1., 1., 0., 1., 1., 1., 4., 1., 1., 1., 1.)); | 
| 198 | s = "CADMIUM"; //default GPAMELA parameters | 
| 199 | if (GetMed(s) && !GetCC(s)) | 
| 200 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 201 | 0.001, 0.01, 1., 1., 1., 0., 1., 1., 1., 4., 1., 1., 1., 1.)); | 
| 202 | s = "He3"; | 
| 203 | if (GetMed(s) && !GetCC(s)) //default GPAMELA parameters | 
| 204 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 205 | 0.001, 0.01, 1., 1., 1., 0., 1., 1., 1., 4., 1., 1., 1., 1.)); | 
| 206 | s = "POLYETHYLENE"; //default GPAMELA parameters | 
| 207 | if (GetMed(s) && !GetCC(s)) | 
| 208 | SetCC(s, new pCutControl(GetMedID(s), 0.0001, 0.001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, 0.0001, | 
| 209 | 0.001, 0.01, 1., 1., 1., 0., 1., 1., 1., 4., 1., 1., 1., 1.)); | 
| 210 | } | 
| 211 |  |