#include <Alignment/LaserAlignmentSimulation/interface/MaterialProperties.h>
Public Member Functions | |
MaterialProperties (int DebugLevel, double SiAbsLengthScale) | |
constructor | |
~MaterialProperties () | |
destructor | |
Private Member Functions | |
void | setMaterialProperties () |
define optical properties of materials in the detector | |
Private Attributes | |
const G4MaterialTable * | theMaterialTable |
int | theMPDebugLevel |
G4MaterialPropertiesTable * | theMPT |
double | theSiAbsLengthScalingFactor |
G4Material * | theTECWafer |
G4Material * | theTIBWafer |
G4Material * | theTOBWafer |
Definition at line 15 of file MaterialProperties.h.
MaterialProperties::MaterialProperties | ( | int | DebugLevel, | |
double | SiAbsLengthScale | |||
) |
constructor
Definition at line 14 of file MaterialProperties.cc.
References g, setMaterialProperties(), theMPDebugLevel, theSiAbsLengthScalingFactor, theTECWafer, theTIBWafer, and theTOBWafer.
00015 : theMaterialTable(), theMPDebugLevel(0), 00016 theSiAbsLengthScalingFactor(0), 00017 theMPT(), 00018 theTECWafer(), theTOBWafer(), theTIBWafer() 00019 { 00020 theMPDebugLevel = DebugLevel; 00021 theSiAbsLengthScalingFactor = SiAbsLengthScale; 00022 /* *********************************************************************** */ 00023 /* 00024 define the materials for the sensitive detectors in TEC, TIB and TOB 00025 we need this to specify different properties for Barrel and Endcap 00026 detectors, which is by default no longer possible in CMSSW due to 00027 the fact that all modules are made out of the same G4Material 00028 */ 00029 /* *********************************************************************** */ 00030 G4double theDensity = 2.33*g/cm3; 00031 G4double theAtomicWeight = 28.09*g/mole; 00032 G4double theAtomicNumber = 14.0; 00033 00034 theTECWafer = new G4Material("TEC_Wafer", theAtomicNumber, theAtomicWeight, theDensity); 00035 theTOBWafer = new G4Material("TOB_Wafer", theAtomicNumber, theAtomicWeight, theDensity); 00036 theTIBWafer = new G4Material("TIB_Wafer", theAtomicNumber, theAtomicWeight, theDensity); 00037 00038 // set the properties of the materials 00039 setMaterialProperties(); 00040 }
MaterialProperties::~MaterialProperties | ( | ) |
destructor
Definition at line 42 of file MaterialProperties.cc.
References theMPT, theTECWafer, theTIBWafer, and theTOBWafer.
00043 { 00044 if ( theMPT != 0 ) { delete theMPT; } 00045 if ( theTECWafer != 0 ) { delete theTECWafer; } 00046 if ( theTOBWafer != 0 ) { delete theTOBWafer; } 00047 if ( theTIBWafer != 0 ) { delete theTIBWafer; } 00048 }
void MaterialProperties::setMaterialProperties | ( | ) | [private] |
define optical properties of materials in the detector
Definition at line 51 of file MaterialProperties.cc.
References GenMuonPlsPt100GeV_cfg::cout, lat::endl(), LogDebug, m, theMaterialTable, theMPDebugLevel, theMPT, theTECWafer, theTIBWafer, and theTOBWafer.
Referenced by MaterialProperties().
00052 { 00053 /* *********************************************************************** */ 00054 /* 00055 use this function to define material properties (like refraction 00056 index, absorptionlenght and so on) and add them to the 00057 MaterialPropertiesTable. Finally set the MPT to a give Material. 00058 */ 00059 /* *********************************************************************** */ 00060 00061 // get the MaterialTable as it is defined in OSCAR (CMSSW now) 00062 theMaterialTable = G4Material::GetMaterialTable(); 00063 00064 /* *********************************************************************** */ 00065 /* 00066 with the following code one can access the MaterialTable defined in 00067 OSCAR. This contains all the materials needed for the CMS detector, 00068 which are defined in the Geometry and DDD packages. COBRA takes care 00069 of the proper conversion between a DDMaterial and a G4Material. 00070 */ 00071 /* *********************************************************************** */ 00072 00073 // if (theMPDebugLevel > 1) 00074 // { 00075 // print the materialtable 00076 LogDebug("SimLaserAlignment:MaterialProperties") << " **** here comes the material table **** " 00077 << *(G4Material::GetMaterialTable()); 00078 // } 00079 00080 // define the MateriapropertiesTable for the Sensitive Regions in the Tracker 00081 // TOB_Wafer, TOB_Silicon, TID_Wafer, TIB_Wafer and TEC_Wafer 00082 00083 const G4int nEntries = 3; 00084 00085 // Photon energies 00086 G4double PhotonEnergy[nEntries] = { 1.10 * eV, 1.15 * eV, 1.20 * eV }; 00087 00088 // scintillation 00089 G4double Scintillation[nEntries] = { 0.1, 1.0, 0.1 }; 00090 00091 // Refractive Index 00092 G4double RefractiveIndex[nEntries] = { 3.5400, 3.5425, 3.5450 }; 00093 // Refractive Index of the Mirrors (BK7) 00094 G4double RefractiveIndexMirror[nEntries] = { 1.50669, 1.50669, 1.50669 }; 00095 00096 /* *********************************************************************** */ 00097 /* set the refractive index for the other materials to 1.0. This is * 00098 * needed to propagate the optical photons through the detector according * 00099 * to Peter Gumplinger. */ 00100 /* *********************************************************************** */ 00101 G4double RefractiveIndexGeneral[nEntries] = { 1.0, 1.0, 1.0 }; 00102 00103 // Absorption Length 00104 G4double AbsorptionLengthSi[nEntries] = { 198.8 * micrometer, 00105 198.8 * micrometer, 00106 198.8 * micrometer }; 00107 00108 G4double AbsorptionLengthSiBarrel[nEntries] = { 0.1 * fermi, 00109 0.1 * fermi, 00110 0.1 * fermi }; 00111 00112 00113 // Absorption length of the mirrors 00114 G4double AbsorptionLengthMirror[nEntries] = { 11.7 * cm, 0.5 * 11.7 * cm, 11.7 * cm }; 00115 00116 // Absorption Length for dead material in the tracker; set to small values 00117 // to kill the optical photons outside the TEC. Maybe this is later a problem 00118 // when implementing Ray 1 to connect both TECs which eachother and with TIB 00119 // and TOB!?? 00120 G4double AbsorptionLengthDead[nEntries] = { 0.001 * micrometer, 0.001 * micrometer, 00121 0.001 * micrometer }; 00122 00123 // Absorption Length of the other Materials in the Tracker 00124 G4double AbsorptionLengthGeneral[nEntries] = { 75 * cm, 75 * cm, 75 * cm }; 00125 00126 // Absorption Length of the Air in the Tracker 00127 G4double AbsorptionLengthTAir[nEntries] = { 10 * m, 1.8 * m, 10 * m }; 00128 00129 G4double AbsorptionLengthAl[nEntries] = { 10 * mm, 10 * mm, 10 * mm}; 00130 G4double AbsorptionLengthTOB_CF_Str[nEntries] = { 1 * cm, 10 * cm, 1 * cm }; 00131 G4double AbsorptionLengthTOBCF[nEntries] = { 0.1 * mm, 20 * mm, 0.1 * mm }; 00132 G4double AbsorptionLengthTIBCF[nEntries] = { 15.0 * cm, 15.0 * cm, 15.0 * cm }; 00133 00134 // Reflectivity of the modules 00135 G4double SiReflectivity[nEntries] = { 0.0, 0.0, 0.0 }; 00136 00137 // Efficiency of the modules 00138 G4double TECEfficiency[nEntries] = { 0.9, 0.9, 0.9 }; 00139 G4double BarrelEfficiency[nEntries] = { 1.0, 1.0, 1.0 }; 00140 00141 // Reflectivity of the mirrors in the Alignment Tubes 00142 G4double Reflectivity[nEntries] = { 0.05, 0.05, 0.05 }; 00143 00144 /* *********************************************************************** */ 00145 00146 /* *********************************************************************** */ 00147 /* 00148 define the materials for the sensitive detectors in TEC, TIB and TOB 00149 we need this to specify different properties for Barrel and Endcap 00150 detectors, which is by default no longer possible in CMSSW due to 00151 the fact that all modules are made out of the same G4Material 00152 */ 00153 /* *********************************************************************** */ 00154 00155 // set the options for the materials 00156 { 00157 for(G4MaterialTable::const_iterator theMTEntry = theMaterialTable->begin(); 00158 theMTEntry != theMaterialTable->end(); theMTEntry++) 00159 { 00160 if(*theMTEntry) 00161 { 00162 G4Material * theMaterial = const_cast<G4Material*>(*theMTEntry); 00163 00164 if (theMaterial->GetMaterialPropertiesTable()) 00165 { 00166 theMPT = theMaterial->GetMaterialPropertiesTable(); 00167 } 00168 else 00169 { 00170 theMPT = new G4MaterialPropertiesTable; 00171 } 00172 00173 // properties of the TEC_Wafer 00174 if ( theMaterial->GetName() == "TEC_Wafer" ) 00175 { 00176 theMPT->AddProperty("FASTCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00177 theMPT->AddProperty("SLOWCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00178 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndex, nEntries); 00179 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthSi, nEntries); 00180 theMPT->AddProperty("EFFICIENCY", PhotonEnergy, TECEfficiency, nEntries); 00181 00182 theMPT->AddConstProperty("SCINTILLATIONYIELD", 12000.0/MeV); 00183 theMPT->AddConstProperty("RESOLTUIONSCALE", 1.0); 00184 theMPT->AddConstProperty("FASTTIMECONSTANT", 20.0 * ns); 00185 theMPT->AddConstProperty("SLOWTIMECONSTANT", 45.0 * ns); 00186 theMPT->AddConstProperty("YIELDRATIO", 1.0); 00187 00188 // set the MaterialPropertiesTable 00189 theMaterial->SetMaterialPropertiesTable(theMPT); 00190 } 00191 00192 // properties of Silicon (used as Module Material in CMSSW) 00193 else if ( theMaterial->GetName() == "Silicon" ) 00194 { 00195 theMPT->AddProperty("FASTCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00196 theMPT->AddProperty("SLOWCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00197 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndex, nEntries); 00198 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthSi, nEntries); 00199 theMPT->AddProperty("EFFICIENCY", PhotonEnergy, TECEfficiency, nEntries); 00200 00201 theMPT->AddConstProperty("SCINTILLATIONYIELD", 12000.0/MeV); 00202 theMPT->AddConstProperty("RESOLTUIONSCALE", 1.0); 00203 theMPT->AddConstProperty("FASTTIMECONSTANT", 20.0 * ns); 00204 theMPT->AddConstProperty("SLOWTIMECONSTANT", 45.0 * ns); 00205 theMPT->AddConstProperty("YIELDRATIO", 1.0); 00206 00207 // set the MaterialPropertiesTable 00208 theMaterial->SetMaterialPropertiesTable(theMPT); 00209 } 00210 00211 // properties of the TOB_Wafer, TOB_Silicon, TIB_Wafer 00212 else if ( ( theMaterial->GetName() == "TOB_Wafer" ) || 00213 ( theMaterial->GetName() == "TIB_Wafer" ) ) 00214 { 00215 theMPT->AddProperty("FASTCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00216 theMPT->AddProperty("SLOWCOMPONENT", PhotonEnergy, Scintillation, nEntries); 00217 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndex, nEntries); 00218 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthSiBarrel, nEntries); 00219 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00220 theMPT->AddProperty("EFFICIENCY", PhotonEnergy, BarrelEfficiency, nEntries); 00221 00222 theMPT->AddConstProperty("SCINTILLATIONYIELD", 12000.0/MeV); 00223 theMPT->AddConstProperty("RESOLTUIONSCALE", 1.0); 00224 theMPT->AddConstProperty("FASTTIMECONSTANT", 20.0 * ns); 00225 theMPT->AddConstProperty("SLOWTIMECONSTANT", 45.0 * ns); 00226 theMPT->AddConstProperty("YIELDRATIO", 1.0); 00227 00228 // set the MaterialPropertiesTable 00229 theMaterial->SetMaterialPropertiesTable(theMPT); 00230 } 00231 00232 // properties of the TIB_ledge_side 00233 else if ( theMaterial->GetName() == "TIB_ledge_side" ) 00234 { 00235 // set the refractive index 00236 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00237 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthGeneral, nEntries); 00238 00239 // set the MaterialPropertiesTable 00240 theMaterial->SetMaterialPropertiesTable(theMPT); 00241 } 00242 00243 // properties of air 00244 else if ( ( theMaterial->GetName() == "T_Air" ) || 00245 ( theMaterial->GetName() == "Air" ) ) 00246 { 00247 // set the refractive index 00248 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00249 // set the reflectivity 00250 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00251 // set the absorptionlength 00252 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthTAir, nEntries); 00253 00254 // set the MaterialPropertiesTable 00255 theMaterial->SetMaterialPropertiesTable(theMPT); 00256 } 00257 00258 // properties of some materials in the Barrel 00259 // used to absorb photons to avoid hits in other TEC 00260 else if ( ( theMaterial->GetName() == "TIB_connector" ) || 00261 ( theMaterial->GetName() == "TIB_cylinder" ) || 00262 ( theMaterial->GetName() == "TID_Connector" ) ) 00263 { 00264 // set the refractive index 00265 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00266 // set the reflectivity 00267 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00268 // set the absorptionlength 00269 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthDead, nEntries); 00270 00271 // set the MaterialPropertiesTable 00272 theMaterial->SetMaterialPropertiesTable(theMPT); 00273 } 00274 00275 // properties of SiO2; used for the mirrors of the Alignment Tubes 00276 else if ( theMaterial->GetName() == "Si O_2" ) 00277 { 00278 // set the refractive index 00279 theMPT->AddProperty("RINDEX", PhotonEnergy,RefractiveIndexMirror, nEntries); 00280 //set the absorptionlength 00281 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthMirror, nEntries); 00282 // set the reflectivity 00283 theMPT->AddProperty("REFLECTIVITY",PhotonEnergy,Reflectivity, nEntries); 00284 00285 // set the MaterialPropertiesTable 00286 theMaterial->SetMaterialPropertiesTable(theMPT); 00287 } 00288 00289 // properties of Aluminium 00290 else if ( ( theMaterial->GetName() == "TOB_Aluminium" ) || 00291 ( theMaterial->GetName() == "Aluminium" ) ) 00292 { 00293 // set the refractive index 00294 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00295 // set the reflectivity 00296 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00297 // set the absorptionlength 00298 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthAl, nEntries); 00299 00300 // set the MaterialPropertiesTable 00301 theMaterial->SetMaterialPropertiesTable(theMPT); 00302 } 00303 00304 // properties of TOB_CF_Str 00305 else if ( ( theMaterial->GetName() == "TOB_CF_Str" ) ) 00306 { 00307 // set the refractive index 00308 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00309 // set the reflectivity 00310 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00311 // set the absorptionlength 00312 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthTOB_CF_Str, nEntries); 00313 00314 // set the MaterialPropertiesTable 00315 theMaterial->SetMaterialPropertiesTable(theMPT); 00316 } 00317 00318 // some other Tracker materials 00319 else if ( ( theMaterial->GetName() == "TID_CF" ) || 00320 ( theMaterial->GetName() == "Nomex" ) || 00321 ( theMaterial->GetName() == "TOB_Nomex" ) || 00322 ( theMaterial->GetName() == "TID_Nomex" ) || 00323 ( theMaterial->GetName() == "TOB_plate_C" ) || 00324 ( theMaterial->GetName() == "TOB_rod" ) || 00325 ( theMaterial->GetName() == "TOB_cool_DS" ) || 00326 ( theMaterial->GetName() == "TOB_cool_SS" ) || 00327 ( theMaterial->GetName() == "TID_in_cable" ) || 00328 ( theMaterial->GetName() == "TOB_PA_rphi" ) || 00329 ( theMaterial->GetName() == "TOB_frame_ele" ) || 00330 ( theMaterial->GetName() == "TOB_PA_ster" ) || 00331 ( theMaterial->GetName() == "TOB_ICB" ) || 00332 ( theMaterial->GetName() == "TOB_CONN1" ) || 00333 ( theMaterial->GetName() == "TOB_CONN2" ) || 00334 ( theMaterial->GetName() == "TOB_CONN3" ) || 00335 ( theMaterial->GetName() == "TOB_rail" ) || 00336 ( theMaterial->GetName() == "TOB_sid_rail1" ) || 00337 ( theMaterial->GetName() == "TOB_sid_rail2" ) ) 00338 { 00339 // set the refractive index 00340 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00341 // set the reflectivity 00342 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00343 // set the absorptionlength 00344 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthTOBCF, nEntries); 00345 00346 // set the MaterialPropertiesTable 00347 theMaterial->SetMaterialPropertiesTable(theMPT); 00348 } 00349 00350 // properties of some TIB materials 00351 else if ( ( theMaterial->GetName() == "TIB_CF" ) || 00352 ( theMaterial->GetName() == "TIB_cables_ax_out" ) || 00353 ( theMaterial->GetName() == "TIB_outer_supp" ) || 00354 ( theMaterial->GetName() == "TIB_PA_rphi" ) || 00355 ( theMaterial->GetName() == "TIB_rail" ) || 00356 ( theMaterial->GetName() == "TIB_sid_rail1" ) || 00357 ( theMaterial->GetName() == "TIB_sid_rail2" ) || 00358 ( theMaterial->GetName() == "TIB_mod_cool" ) ) 00359 { 00360 // set the refractive index 00361 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00362 // set the reflectivity 00363 theMPT->AddProperty("REFLECTIVITY", PhotonEnergy, SiReflectivity, nEntries); 00364 // set the absorptionlength 00365 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthTIBCF, nEntries); 00366 00367 // set the MaterialPropertiesTable 00368 theMaterial->SetMaterialPropertiesTable(theMPT); 00369 } 00370 00371 // properties of all other materials in the detector 00372 else 00373 { 00374 // set the refractive index 00375 theMPT->AddProperty("RINDEX", PhotonEnergy, RefractiveIndexGeneral, nEntries); 00376 // set the absorptionlength 00377 theMPT->AddProperty("ABSLENGTH", PhotonEnergy, AbsorptionLengthGeneral, nEntries); 00378 00379 // set the MaterialPropertiesTable 00380 theMaterial->SetMaterialPropertiesTable(theMPT); 00381 } 00382 00383 } 00384 } 00385 } 00386 00387 // loop over the logical volumes and set the material for the sensitive detectors 00388 const G4LogicalVolumeStore * theLogicalVolumeStore = G4LogicalVolumeStore::GetInstance(); 00389 std::vector<G4LogicalVolume*>::const_iterator theLogicalVolume; 00390 00391 for ( theLogicalVolume = theLogicalVolumeStore->begin(); theLogicalVolume != theLogicalVolumeStore->end(); theLogicalVolume++ ) 00392 { 00393 if ( ( (*theLogicalVolume)->GetName() == "TECModule0StereoActive" ) || 00394 ( (*theLogicalVolume)->GetName() == "TECModule0RphiActive" ) || 00395 ( (*theLogicalVolume)->GetName() == "TECModule1StereoActive" ) || 00396 ( (*theLogicalVolume)->GetName() == "TECModule1RphiActive" ) || 00397 ( (*theLogicalVolume)->GetName() == "TECModule2RphiActive" ) || 00398 ( (*theLogicalVolume)->GetName() == "TECModule3RphiActive" ) || 00399 ( (*theLogicalVolume)->GetName() == "TECModule4StereoActive" ) || 00400 ( (*theLogicalVolume)->GetName() == "TECModule4RphiActive" ) || 00401 ( (*theLogicalVolume)->GetName() == "TECModule5RphiActive" ) || 00402 ( (*theLogicalVolume)->GetName() == "TECModule6RphiActive" ) ) 00403 { 00404 // set the material 00405 (*theLogicalVolume)->SetMaterial(theTECWafer); 00406 00407 if (theMPDebugLevel > 2) 00408 { 00409 std::cout << " AC1CMS: found a logical volume: " << (*theLogicalVolume)->GetName() << std::endl; 00410 std::cout << " AC1CMS: the logical volume material = " << (*theLogicalVolume)->GetMaterial()->GetName() << std::endl; 00411 std::cout << " AC1CMS: the MaterialPropertiesTable = " << std::endl; 00412 (*theLogicalVolume)->GetMaterial()->GetMaterialPropertiesTable()->DumpTable(); 00413 } 00414 } 00415 else if ( ( (*theLogicalVolume)->GetName() == "TOBActiveSter0" ) || 00416 ( (*theLogicalVolume)->GetName() == "TOBActiveRphi0" ) || 00417 ( (*theLogicalVolume)->GetName() == "TOBActiveRphi2" ) || 00418 ( (*theLogicalVolume)->GetName() == "TOBActiveRphi4" ) ) 00419 { 00420 // set the material 00421 (*theLogicalVolume)->SetMaterial(theTOBWafer); 00422 00423 if (theMPDebugLevel > 2) 00424 { 00425 std::cout << " AC1CMS: found a logical volume: " << (*theLogicalVolume)->GetName() << std::endl; 00426 std::cout << " AC1CMS: the logical volume material = " << (*theLogicalVolume)->GetMaterial()->GetName() << std::endl; 00427 std::cout << " AC1CMS: the MaterialPropertiesTable = " << std::endl; 00428 (*theLogicalVolume)->GetMaterial()->GetMaterialPropertiesTable()->DumpTable(); 00429 } 00430 } 00431 else if ( ( (*theLogicalVolume)->GetName() == "TIBActiveSter0" ) || 00432 ( (*theLogicalVolume)->GetName() == "TIBActiveRphi0" ) || 00433 ( (*theLogicalVolume)->GetName() == "TIBActiveRphi2" ) ) 00434 { 00435 // set the material 00436 (*theLogicalVolume)->SetMaterial(theTIBWafer); 00437 00438 if (theMPDebugLevel > 2) 00439 { 00440 std::cout << " AC1CMS: found a logical volume: " << (*theLogicalVolume)->GetName() << std::endl; 00441 std::cout << " AC1CMS: the logical volume material = " << (*theLogicalVolume)->GetMaterial()->GetName() << std::endl; 00442 std::cout << " AC1CMS: the MaterialPropertiesTable = " << std::endl; 00443 (*theLogicalVolume)->GetMaterial()->GetMaterialPropertiesTable()->DumpTable(); 00444 } 00445 } 00446 } 00447 }
const G4MaterialTable* MaterialProperties::theMaterialTable [private] |
int MaterialProperties::theMPDebugLevel [private] |
Definition at line 31 of file MaterialProperties.h.
Referenced by MaterialProperties(), and setMaterialProperties().
G4MaterialPropertiesTable* MaterialProperties::theMPT [private] |
Definition at line 33 of file MaterialProperties.h.
Referenced by setMaterialProperties(), and ~MaterialProperties().
double MaterialProperties::theSiAbsLengthScalingFactor [private] |
G4Material* MaterialProperties::theTECWafer [private] |
Definition at line 34 of file MaterialProperties.h.
Referenced by MaterialProperties(), setMaterialProperties(), and ~MaterialProperties().
G4Material* MaterialProperties::theTIBWafer [private] |
Definition at line 36 of file MaterialProperties.h.
Referenced by MaterialProperties(), setMaterialProperties(), and ~MaterialProperties().
G4Material* MaterialProperties::theTOBWafer [private] |
Definition at line 35 of file MaterialProperties.h.
Referenced by MaterialProperties(), setMaterialProperties(), and ~MaterialProperties().