15 #include <phgeom/PHGeomUtility.h>
19 #include <phfield/PHFieldUtility.h>
20 #include <phfield/PHFieldConfig_v1.h>
21 #include <phfield/PHFieldConfig_v2.h>
22 #include <phfield/PHFieldConfig_v3.h>
31 #include <phparameter/PHParameters.h>
36 #include <CLHEP/Random/Random.h>
38 #include <Geant4/G4RunManager.hh>
40 #include <Geant4/G4Material.hh>
41 #include <Geant4/G4NistManager.hh>
42 #include <Geant4/G4OpenGLImmediateX.hh>
43 #include <Geant4/G4Region.hh>
44 #include <Geant4/G4RegionStore.hh>
45 #include <Geant4/G4StepLimiterPhysics.hh>
46 #include <Geant4/G4UIExecutive.hh>
47 #include <Geant4/G4UImanager.hh>
48 #include <Geant4/G4VisExecutive.hh>
49 #include <Geant4/G4Cerenkov.hh>
50 #include <Geant4/G4EmProcessOptions.hh>
51 #include <Geant4/G4EmSaturation.hh>
52 #include <Geant4/G4FastSimulationManager.hh>
53 #include <Geant4/G4HadronicProcessStore.hh>
54 #include <Geant4/G4LossTableManager.hh>
55 #include <Geant4/G4OpAbsorption.hh>
56 #include <Geant4/G4OpBoundaryProcess.hh>
57 #include <Geant4/G4OpMieHG.hh>
58 #include <Geant4/G4OpRayleigh.hh>
59 #include <Geant4/G4OpWLS.hh>
60 #include <Geant4/G4OpticalPhoton.hh>
61 #include <Geant4/G4OpticalPhysics.hh>
62 #include <Geant4/G4PAIModel.hh>
63 #include <Geant4/G4PEEffectFluoModel.hh>
64 #include <Geant4/G4EmProcessOptions.hh>
65 #include <Geant4/G4HadronicProcessStore.hh>
66 #include <Geant4/G4StepLimiterPhysics.hh>
67 #include <Geant4/G4ParticleDefinition.hh>
68 #include <Geant4/G4ParticleTable.hh>
69 #include <Geant4/G4ParticleTypes.hh>
70 #include <Geant4/G4ProcessManager.hh>
71 #include <Geant4/G4Scintillation.hh>
72 #include <Geant4/G4SystemOfUnits.hh>
73 #include <Geant4/G4Version.hh>
74 #include <Geant4/globals.hh>
77 #include <Geant4/FTFP_BERT.hh>
78 #include <Geant4/LBE.hh>
79 #include <Geant4/QGSP_BERT.hh>
80 #include <Geant4/QGSP_BIC.hh>
81 #include <Geant4/QGSP_BIC_HP.hh>
83 #if G4VERSION_NUMBER <= 951
85 #include <Geant4/LHEP.hh>
88 #if G4VERSION_NUMBER >= 1001
89 #define HAVE_FTFP_BERT_HP
90 #define HAVE_QGSP_BERT_HP
91 #include <Geant4/FTFP_BERT_HP.hh>
92 #include <Geant4/QGSP_BERT_HP.hh>
119 , magfield_rescale(1.0)
121 , runManager_(nullptr)
122 , uisession_(nullptr)
124 , eventAction_(nullptr)
125 , steppingAction_(nullptr)
126 , trackingAction_(nullptr)
127 , generatorAction_(nullptr)
128 , visManager(nullptr)
132 , worldshape(
"G4Tubs")
133 , worldmaterial(
"G4_AIR")
134 #if G4VERSION_NUMBER >= 1033
135 , physicslist(
"FTFP_BERT")
137 , physicslist(
"QGSP_BERT")
139 , save_DST_geometry_(true)
140 , optical_photon_(false)
141 , energy_threshold_(0.0005)
142 , zero_field_line_(99999.)
145 for (
int i = 0; i < 3; i++)
174 cout <<
"========================= PHG4Reco::Init() ================================" << endl;
180 if (
verbosity > 1) cout <<
"PHG4Reco::Init - create run manager" << endl;
186 G4UImanager *uimanager = G4UImanager::GetUIpointer();
196 G4VModularPhysicsList *myphysicslist =
nullptr;
199 myphysicslist =
new FTFP_BERT(
verbosity);
203 myphysicslist =
new QGSP_BERT(
verbosity);
211 setenv(
"AllowForHeavyElements",
"1", 1);
212 myphysicslist =
new QGSP_BIC_HP(
verbosity);
220 #ifdef HAVE_FTFP_BERT_HP
223 setenv(
"AllowForHeavyElements",
"1", 1);
224 myphysicslist =
new FTFP_BERT_HP(
verbosity);
227 #ifdef HAVE_QGSP_BERT_HP
230 setenv(
"AllowForHeavyElements",
"1", 1);
231 myphysicslist =
new QGSP_BERT_HP(
verbosity);
236 cout <<
"Physics List " <<
physicslist <<
" not implemented" << endl;
240 myphysicslist->RegisterPhysics(
new G4StepLimiterPhysics());
243 myphysicslist->SetCutsWithDefault();
247 #if G4VERSION_NUMBER >= 1033
248 G4EmSaturation* emSaturation = G4LossTableManager::Instance()->EmSaturation();
251 cout <<
PHWHERE <<
"Could not initialize EmSaturation, Birks constants will fail" << endl;
263 cout <<
"===========================================================================" << endl;
270 if (
verbosity > 1) cout <<
"PHG4Reco::InitField - create magnetic field setup" << endl;
272 unique_ptr<PHFieldConfig> default_field_cfg(
nullptr);
275 std::vector<std::string> fieldmapfiles(std::istream_iterator<std::string>{ssfieldmapfile},
276 std::istream_iterator<std::string>());
278 if (fieldmapfiles.size() == 1)
282 else if (fieldmapfiles.size() == 0)
286 else if (fieldmapfiles.size() == 2)
289 fieldmapfiles[0], fieldmapfiles[1], 1.0, 1.0, 5.0
292 else if (fieldmapfiles.size() == 5)
295 fieldmapfiles[0], fieldmapfiles[1], std::stod(fieldmapfiles[2]), std::stod(fieldmapfiles[3]), std::stod(fieldmapfiles[4])
299 if (
verbosity > 1) cout <<
"PHG4Reco::InitField - create magnetic field setup" << endl;
318 if (
verbosity > 0) cout <<
"PHG4Reco::set_field_map(): " << oss.str() <<
"." << endl;
332 static int InitRunDone = 0;
340 cout <<
"========================= PHG4Reco::InitRun() ================================" << endl;
346 const int field_ret =
InitField(topNode);
349 cout <<
"PHG4Reco::InitRun- Error - Failed field init with status = "<<field_ret<<endl;
357 reco->InitRun(topNode);
361 if (
verbosity > 1) cout <<
"PHG4Reco::Init - create detector" << endl;
376 double z_offset = 0.;
380 cout <<
"Will update the z-positions of the downstream volumes by zOffset = " << z_offset <<
"cm." << endl;
389 double z_in_world = g4sub->GetParams()->get_double_param(
"place_z");
392 g4sub->GetParams()->set_double_param(
"place_z", z_in_world - z_offset);
433 cout <<
"Adding steppingaction for " << g4sub->Name() << endl;
448 if (g4sub->GetTrackingAction())
451 if (G4TrackingManager *trackingManager = G4EventManager::GetEventManager()->GetTrackingManager())
453 g4sub->GetTrackingAction()->SetTrackingManagerPointer(trackingManager);
467 G4Cerenkov *theCerenkovProcess =
new G4Cerenkov(
"Cerenkov");
478 theCerenkovProcess->SetMaxNumPhotonsPerStep(100);
479 theCerenkovProcess->SetMaxBetaChangePerStep(10.0);
480 theCerenkovProcess->SetTrackSecondariesFirst(
true);
490 G4ParticleTable *theParticleTable = G4ParticleTable::GetParticleTable();
491 G4ParticleTable::G4PTblDicIterator *_theParticleIterator;
492 _theParticleIterator = theParticleTable->GetIterator();
493 _theParticleIterator->reset();
494 while ((*_theParticleIterator)())
496 G4ParticleDefinition *particle = _theParticleIterator->value();
497 G4String particleName = particle->GetParticleName();
498 G4ProcessManager *pmanager = particle->GetProcessManager();
499 if (theCerenkovProcess->IsApplicable(*particle))
501 pmanager->AddProcess(theCerenkovProcess);
502 pmanager->SetProcessOrdering(theCerenkovProcess, idxPostStep);
511 G4ProcessManager *pmanager = G4OpticalPhoton::OpticalPhoton()->GetProcessManager();
513 pmanager->AddDiscreteProcess(
new G4OpAbsorption());
514 pmanager->AddDiscreteProcess(
new G4OpRayleigh());
515 pmanager->AddDiscreteProcess(
new G4OpMieHG());
516 pmanager->AddDiscreteProcess(
new G4OpBoundaryProcess());
517 pmanager->AddDiscreteProcess(
new G4OpWLS());
518 pmanager->AddDiscreteProcess(
new G4PhotoElectricEffect());
529 G4HadronicProcessStore::Instance()->SetVerbose(0);
530 G4LossTableManager::Instance()->SetVerbose(1);
540 const string filename =
543 cout <<
"PHG4Reco::InitRun - export geometry to DST via tmp file " << filename << endl;
554 cout <<
"===========================================================================" << endl;
606 PHG4InEvent *ineve = findNode::getClass<PHG4InEvent>(topNode,
"PHG4INEVENT");
613 cout <<
"PHG4Reco::process_event - " << reco->Name() <<
"->process_event" << endl;
617 reco->process_event(topNode);
619 catch (
const exception &e)
621 cout <<
PHWHERE <<
" caught exception thrown during process_event from "
622 << reco->Name() << endl;
623 cout <<
"error: " << e.what() << endl;
634 cout <<
" PHG4Reco::process_event - "
635 <<
"run one event :" << endl;
645 cout <<
" PHG4Reco::process_event - " << g4sub->Name() <<
"->process_after_geant" << endl;
648 g4sub->process_after_geant(topNode);
650 catch (
const exception &e)
652 cout <<
PHWHERE <<
" caught exception thrown during process_after_geant from "
653 << g4sub->Name() << endl;
654 cout <<
"error: " << e.what() << endl;
668 reco->ResetEvent(topNode);
684 if (what.empty() || what ==
"ALL" || (reco->Name()).find(what) != string::npos)
686 cout <<
"Printing " << reco->Name() << endl;
688 cout <<
"---------------------------" << endl;
696 PHG4InEvent *ineve = findNode::getClass<PHG4InEvent>(topNode,
"PHG4INEVENT");
729 CLHEP::HepRandom::setTheSeed(i);
736 G4UIExecutive *ui =
new G4UIExecutive(0,
nullptr,
"Xm");
739 if (ui->IsGUI() &&
true)
741 UImanager->ApplyCommand(
"/control/execute gui.mac");
757 G4double fractionmass;
759 G4int ncomponents, natoms;
762 set<G4String> ignoremat;
763 ignoremat.insert(
"G4_Cf");
766 G4NistManager *nist = G4NistManager::Instance();
767 vector<G4String> matnames = nist->GetNistMaterialNames();
768 while (matnames.begin() != matnames.end())
770 G4String mat = matnames.back();
771 if (ignoremat.find(mat) == ignoremat.end())
773 nist->FindOrBuildMaterial(mat);
779 G4Material *quartz =
new G4Material(
"Quartz", density = 2.200 * g / cm3, ncomponents = 2);
780 quartz->AddElement(G4Element::GetElement(
"Si"), 1);
781 quartz->AddElement(G4Element::GetElement(
"O"), 2);
784 G4Material *IsoButane =
new G4Material(
"Isobutane", 0.00265 * g / cm3, 2);
785 IsoButane->AddElement(G4Element::GetElement(
"C"), 4);
786 IsoButane->AddElement(G4Element::GetElement(
"H"), 10);
788 G4Material *MuIDgas =
new G4Material(
"MuIDgas", density = (1.977e-3 * 0.92 + 0.00265 * 0.08) * g / cm3, ncomponents = 2);
789 MuIDgas->AddMaterial(IsoButane, fractionmass = 0.08);
790 MuIDgas->AddMaterial(G4Material::GetMaterial(
"G4_CARBON_DIOXIDE"), fractionmass = 0.92);
793 G4Material *StainlessSteel =
794 new G4Material(
"SS304", density = 7.9 * g / cm3, ncomponents = 8);
795 StainlessSteel->AddElement(G4Element::GetElement(
"Fe"), 0.70105);
796 StainlessSteel->AddElement(G4Element::GetElement(
"Cr"), 0.18);
797 StainlessSteel->AddElement(G4Element::GetElement(
"Ni"), 0.09);
798 StainlessSteel->AddElement(G4Element::GetElement(
"Mn"), 0.02);
799 StainlessSteel->AddElement(G4Element::GetElement(
"C"), 0.0007);
800 StainlessSteel->AddElement(G4Element::GetElement(
"S"), 0.0003);
801 StainlessSteel->AddElement(G4Element::GetElement(
"Si"), 0.0075);
802 StainlessSteel->AddElement(G4Element::GetElement(
"P"), 0.00045);
805 new G4Material(
"SS310", density = 8.0 * g / cm3, ncomponents = 8);
806 SS310->AddElement(G4Element::GetElement(
"Fe"), 0.50455);
807 SS310->AddElement(G4Element::GetElement(
"Cr"), 0.25);
808 SS310->AddElement(G4Element::GetElement(
"Ni"), 0.20);
809 SS310->AddElement(G4Element::GetElement(
"Mn"), 0.02);
810 SS310->AddElement(G4Element::GetElement(
"C"), 0.0025);
811 SS310->AddElement(G4Element::GetElement(
"S"), 0.015);
812 SS310->AddElement(G4Element::GetElement(
"Si"), 0.0075);
813 SS310->AddElement(G4Element::GetElement(
"P"), 0.00045);
816 new G4Material(
"Steel", density = 7.86 * g / cm3, ncomponents = 5);
817 Steel->AddElement(G4Element::GetElement(
"Fe"), 0.9834);
818 Steel->AddElement(G4Element::GetElement(
"Mn"), 0.014);
819 Steel->AddElement(G4Element::GetElement(
"C"), 0.0017);
820 Steel->AddElement(G4Element::GetElement(
"S"), 0.00045);
821 Steel->AddElement(G4Element::GetElement(
"P"), 0.00045);
824 G4Material *a36 =
new G4Material(
"Steel_A36", density = 7.85 * g / cm3, ncomponents = 5);
825 a36->AddElement(G4Element::GetElement(
"Fe"), 0.9824);
826 a36->AddElement(G4Element::GetElement(
"Cu"), 0.002);
827 a36->AddElement(G4Element::GetElement(
"C"), 0.0025);
828 a36->AddElement(G4Element::GetElement(
"Mn"), 0.0103);
829 a36->AddElement(G4Element::GetElement(
"Si"), 0.0028);
832 G4Material *steel_1006 =
new G4Material(
"Steel_1006", density = 7.872 * g / cm3, ncomponents = 2);
833 steel_1006->AddElement(G4Element::GetElement(
"Fe"), 0.996);
834 steel_1006->AddElement(G4Element::GetElement(
"Mn"), 0.004);
837 G4Material *Al5083 =
new G4Material(
"Al5083", density = 2.65 * g / cm3, ncomponents = 3);
838 Al5083->AddElement(G4Element::GetElement(
"Mn"), 0.004);
839 Al5083->AddElement(G4Element::GetElement(
"Mg"), 0.04);
840 Al5083->AddElement(G4Element::GetElement(
"Al"), 0.956);
842 G4Material *FPC =
new G4Material(
"FPC", 1.542 * g / cm3, 2);
843 FPC->AddMaterial(G4Material::GetMaterial(
"G4_Cu"), 0.0162);
844 FPC->AddMaterial(G4Material::GetMaterial(
"G4_KAPTON"), 0.9838);
847 G4Material *W_Epoxy =
new G4Material(
"W_Epoxy", density = 10.2 * g / cm3, ncomponents = 2);
848 W_Epoxy->AddMaterial(G4Material::GetMaterial(
"G4_W"), fractionmass = 0.5);
849 W_Epoxy->AddMaterial(G4Material::GetMaterial(
"G4_POLYSTYRENE"), fractionmass = 0.5);
854 G4Material *Epoxy =
new G4Material(
"Epoxy", 1.2 * g / cm3, ncomponents = 2);
855 Epoxy->AddElement(G4Element::GetElement(
"H"), natoms = 2);
856 Epoxy->AddElement(G4Element::GetElement(
"C"), natoms = 2);
859 density = 1.86 * g / cm3;
860 G4Material *FR4 =
new G4Material(
"FR4", density, ncomponents = 2);
861 FR4->AddMaterial(quartz, fractionmass = 0.528);
862 FR4->AddMaterial(Epoxy, fractionmass = 0.472);
869 G4Material *NOMEX =
new G4Material(
"NOMEX", density, ncomponents = 4);
870 NOMEX->AddElement(G4Element::GetElement(
"C"), natoms = 14);
871 NOMEX->AddElement(G4Element::GetElement(
"H"), natoms = 10);
872 NOMEX->AddElement(G4Element::GetElement(
"N"), natoms = 2);
873 NOMEX->AddElement(G4Element::GetElement(
"O"), natoms = 2);
880 G4Material *Spacal_W_Epoxy =
881 new G4Material(
"Spacal_W_Epoxy", density = 12.18 * g / cm3, ncomponents = 3);
882 Spacal_W_Epoxy->AddElement(G4Element::GetElement(
"C"), 0.029);
883 Spacal_W_Epoxy->AddElement(G4Element::GetElement(
"H"), 0.002);
884 Spacal_W_Epoxy->AddElement(G4Element::GetElement(
"W"), 0.969);
891 new G4Material(
"PMMA", density = 1.19 * g / cm3, ncomponents = 3);
892 PMMA->AddElement(G4Element::GetElement(
"C"), 3.6 / (3.6 + 5.7 + 1.4));
893 PMMA->AddElement(G4Element::GetElement(
"H"), 5.7 / (3.6 + 5.7 + 1.4));
894 PMMA->AddElement(G4Element::GetElement(
"O"), 1.4 / (3.6 + 5.7 + 1.4));
897 new G4Material(
"G10", density = 1.700 * g / cm3, ncomponents = 4);
898 G10->AddElement(G4Element::GetElement(
"Si"), natoms = 1);
899 G10->AddElement(G4Element::GetElement(
"O"), natoms = 2);
900 G10->AddElement(G4Element::GetElement(
"C"), natoms = 3);
901 G10->AddElement(G4Element::GetElement(
"H"), natoms = 3);
904 new G4Material(
"CsI", density = 4.534 * g / cm3, ncomponents = 2);
905 CsI->AddElement(G4Element::GetElement(
"Cs"), natoms = 1);
906 CsI->AddElement(G4Element::GetElement(
"I"), natoms = 1);
907 CsI->GetIonisation()->SetMeanExcitationEnergy(553.1 * eV);
910 new G4Material(
"C4F10", density = 0.00973 * g / cm3, ncomponents = 2);
911 C4F10->AddElement(G4Element::GetElement(
"C"), natoms = 4);
912 C4F10->AddElement(G4Element::GetElement(
"F"), natoms = 10);
914 G4Material *CF4 =
new G4Material(
"CF4", density = 3.72 * mg / cm3, ncomponents = 2, kStateGas, 288.15 * kelvin, 1 * atmosphere);
915 CF4->AddElement(G4Element::GetElement(
"C"), natoms = 1);
916 CF4->AddElement(G4Element::GetElement(
"F"), natoms = 4);
922 const double den_CF4 = CF4->GetDensity() * .1;
923 const double den_G4_Ar = G4Material::GetMaterial(
"G4_Ar")->GetDensity() * .8;
924 const double den_G4_CARBON_DIOXIDE = G4Material::GetMaterial(
"G4_CARBON_DIOXIDE")->GetDensity() * .1;
925 const double den = den_CF4 + den_G4_Ar + den_G4_CARBON_DIOXIDE;
927 G4Material *ePHEINX_TPC_Gas =
new G4Material(
"ePHEINX_TPC_Gas", den,
928 ncomponents = 3, kStateGas);
929 ePHEINX_TPC_Gas->AddMaterial(CF4, den_CF4 / den);
930 ePHEINX_TPC_Gas->AddMaterial(G4Material::GetMaterial(
"G4_Ar"), den_G4_Ar / den);
931 ePHEINX_TPC_Gas->AddMaterial(G4Material::GetMaterial(
"G4_CARBON_DIOXIDE"),
932 den_G4_CARBON_DIOXIDE / den);
935 double G4_Ne_frac = 0.9;
936 double CF4_frac = 0.1;
937 const double den_G4_Ne = G4Material::GetMaterial(
"G4_Ne")->GetDensity();
938 const double den_CF4_2 = CF4->GetDensity();
939 const double den_sphenix_tpc_gas = den_G4_Ne * G4_Ne_frac + den_CF4_2 * CF4_frac;
940 G4Material *sPHENIX_tpc_gas =
new G4Material(
"sPHENIX_TPC_Gas", den_sphenix_tpc_gas, ncomponents = 2, kStateGas);
941 sPHENIX_tpc_gas->AddMaterial(CF4, den_CF4_2 * CF4_frac / den_sphenix_tpc_gas);
942 sPHENIX_tpc_gas->AddMaterial(G4Material::GetMaterial(
"G4_Ne"), den_G4_Ne * G4_Ne_frac / den_sphenix_tpc_gas);
946 const G4int nEntries_CF4 = 50;
948 G4double PhotonEnergy_CF4[nEntries_CF4] =
949 {5.5 * eV, 5.6 * eV, 5.7 * eV, 5.8 * eV, 5.9 * eV,
950 6.0 * eV, 6.1 * eV, 6.2 * eV, 6.3 * eV, 6.4 * eV,
951 6.5 * eV, 6.6 * eV, 6.7 * eV, 6.8 * eV, 6.9 * eV,
952 7.0 * eV, 7.1 * eV, 7.2 * eV, 7.3 * eV, 7.4 * eV,
953 7.5 * eV, 7.6 * eV, 7.7 * eV, 7.8 * eV, 7.9 * eV,
954 8.0 * eV, 8.1 * eV, 8.2 * eV, 8.4 * eV, 8.6 * eV,
955 8.8 * eV, 9.0 * eV, 9.2 * eV, 9.4 * eV, 9.6 * eV,
956 9.8 * eV, 10.0 * eV, 10.2 * eV, 10.4 * eV, 10.6 * eV,
957 10.8 * eV, 11.0 * eV, 11.2 * eV, 11.3 * eV, 11.4 * eV,
958 11.5 * eV, 11.6 * eV, 11.7 * eV, 11.8 * eV, 11.9 * eV};
960 G4double RefractiveIndex_CF4[nEntries_CF4] =
961 {1.000480, 1.000482, 1.000483, 1.000485, 1.000486,
962 1.000488, 1.000490, 1.000491, 1.000493, 1.000495,
963 1.000497, 1.000498, 1.000500, 1.000502, 1.000504,
964 1.000506, 1.000508, 1.000510, 1.000512, 1.000514,
965 1.000517, 1.000519, 1.000521, 1.000524, 1.000526,
966 1.000529, 1.000531, 1.000534, 1.000539, 1.000545,
967 1.000550, 1.000557, 1.000563, 1.000570, 1.000577,
968 1.000584, 1.000592, 1.000600, 1.000608, 1.000617,
969 1.000626, 1.000636, 1.000646, 1.000652, 1.000657,
970 1.000662, 1.000667, 1.000672, 1.000677, 1.000682};
972 G4double Absorption_CF4[nEntries_CF4] =
973 {1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
974 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
975 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
976 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
977 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
978 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
979 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
980 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
981 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
982 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m};
984 G4MaterialPropertiesTable *MPT_CF4 =
new G4MaterialPropertiesTable();
986 MPT_CF4->AddProperty(
"RINDEX", PhotonEnergy_CF4, RefractiveIndex_CF4, nEntries_CF4)
988 MPT_CF4->AddProperty(
"ABSLENGTH", PhotonEnergy_CF4, Absorption_CF4, nEntries_CF4)
991 CF4->SetMaterialPropertiesTable(MPT_CF4);
996 G4Material *g4_lif = nist->FindOrBuildMaterial(
"G4_LITHIUM_FLUORIDE");
997 G4Material *LiF =
new G4Material(
"LiF", density = 2.635 * g / cm3, ncomponents = 2);
998 LiF->AddElement(G4Element::GetElement(
"Li"), natoms = 1);
999 LiF->AddElement(G4Element::GetElement(
"F"), natoms = 1);
1003 cout <<
"g4_lif: " << g4_lif << endl;
1004 cout <<
"LiF: " << LiF << endl;
1007 const G4int nEntries_LiF = 50;
1009 G4double PhotonEnergy_LiF[nEntries_LiF] =
1010 {5.5 * eV, 5.6 * eV, 5.7 * eV, 5.8 * eV, 5.9 * eV,
1011 6.0 * eV, 6.1 * eV, 6.2 * eV, 6.3 * eV, 6.4 * eV,
1012 6.5 * eV, 6.6 * eV, 6.7 * eV, 6.8 * eV, 6.9 * eV,
1013 7.0 * eV, 7.1 * eV, 7.2 * eV, 7.3 * eV, 7.4 * eV,
1014 7.5 * eV, 7.6 * eV, 7.7 * eV, 7.8 * eV, 7.9 * eV,
1015 8.0 * eV, 8.1 * eV, 8.2 * eV, 8.4 * eV, 8.6 * eV,
1016 8.8 * eV, 9.0 * eV, 9.2 * eV, 9.4 * eV, 9.6 * eV,
1017 9.8 * eV, 10.0 * eV, 10.2 * eV, 10.4 * eV, 10.6 * eV,
1018 10.8 * eV, 11.0 * eV, 11.2 * eV, 11.3 * eV, 11.4 * eV,
1019 11.5 * eV, 11.6 * eV, 11.7 * eV, 11.8 * eV, 11.9 * eV};
1021 G4double RefractiveIndex_LiF[nEntries_LiF] =
1022 {1.42709, 1.42870, 1.42998, 1.43177, 1.43368,
1023 1.43520, 1.43736, 1.43907, 1.44088, 1.44279,
1024 1.44481, 1.44694, 1.44920, 1.45161, 1.45329,
1025 1.45595, 1.45781, 1.46077, 1.46285, 1.46503,
1026 1.46849, 1.47093, 1.47349, 1.47618, 1.47901,
1027 1.48198, 1.48511, 1.48841, 1.49372, 1.50152,
1028 1.50799, 1.51509, 1.52290, 1.53152, 1.54108,
1029 1.54805, 1.55954, 1.56799, 1.58202, 1.59243,
1030 1.60382, 1.61632, 1.63010, 1.63753, 1.64536,
1031 1.65363, 1.66236, 1.67159, 1.68139, 1.69178};
1033 G4double Absorption_LiF[nEntries_LiF] =
1034 {1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1035 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1036 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1037 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1038 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1039 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1040 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1041 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1042 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m,
1043 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m, 1.e4 * m};
1045 G4MaterialPropertiesTable *MPT_LiF =
new G4MaterialPropertiesTable();
1047 MPT_LiF->AddProperty(
"RINDEX", PhotonEnergy_LiF, RefractiveIndex_LiF, nEntries_LiF)
1049 MPT_LiF->AddProperty(
"ABSLENGTH", PhotonEnergy_LiF, Absorption_LiF, nEntries_LiF)
1052 LiF->SetMaterialPropertiesTable(MPT_LiF);
1057 const G4int nEntries_CsI = 50;
1059 G4double PhotonEnergy_CsI[nEntries_CsI] =
1060 {5.5 * eV, 5.6 * eV, 5.7 * eV, 5.8 * eV, 5.9 * eV,
1061 6.0 * eV, 6.1 * eV, 6.2 * eV, 6.3 * eV, 6.4 * eV,
1062 6.5 * eV, 6.6 * eV, 6.7 * eV, 6.8 * eV, 6.9 * eV,
1063 7.0 * eV, 7.1 * eV, 7.2 * eV, 7.3 * eV, 7.4 * eV,
1064 7.5 * eV, 7.6 * eV, 7.7 * eV, 7.8 * eV, 7.9 * eV,
1065 8.0 * eV, 8.1 * eV, 8.2 * eV, 8.4 * eV, 8.6 * eV,
1066 8.8 * eV, 9.0 * eV, 9.2 * eV, 9.4 * eV, 9.6 * eV,
1067 9.8 * eV, 10.0 * eV, 10.2 * eV, 10.4 * eV, 10.6 * eV,
1068 10.8 * eV, 11.0 * eV, 11.2 * eV, 11.3 * eV, 11.4 * eV,
1069 11.5 * eV, 11.6 * eV, 11.7 * eV, 11.8 * eV, 11.9 * eV};
1071 G4double RefractiveIndex_CsI[nEntries_CsI] =
1072 {1., 1., 1., 1., 1.,
1081 1., 1., 1., 1., 1.};
1083 G4double Absorption_CsI[nEntries_CsI] =
1084 {0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1085 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1086 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1087 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1088 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1089 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1090 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1091 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1092 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m,
1093 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m, 0.0000001 * m};
1095 G4MaterialPropertiesTable *MPT_CsI =
new G4MaterialPropertiesTable();
1097 MPT_CsI->AddProperty(
"RINDEX", PhotonEnergy_CsI, RefractiveIndex_CsI, nEntries_CsI)
1099 MPT_CsI->AddProperty(
"ABSLENGTH", PhotonEnergy_CsI, Absorption_CsI, nEntries_CsI)
1102 CsI->SetMaterialPropertiesTable(MPT_CsI);
1106 new G4Material(
"P10", density = 1.74 * mg / cm3, ncomponents = 3);
1107 P10->AddElement(G4Element::GetElement(
"Ar"), fractionmass = 0.9222);
1108 P10->AddElement(G4Element::GetElement(
"C"), fractionmass = 0.0623);
1109 P10->AddElement(G4Element::GetElement(
"H"), fractionmass = 0.0155);
1116 const int mRICH_nEntries_Air_Opt=2;
1118 G4double mRICH_PhotonEnergy_Air_Opt[mRICH_nEntries_Air_Opt] = {2.034*eV, 4.136*eV};
1119 G4double mRICH_RefractiveIndex_Air_Opt[mRICH_nEntries_Air_Opt] = {1.00, 1.00};
1121 G4MaterialPropertiesTable* mRICH_Air_Opt_MPT =
new G4MaterialPropertiesTable();
1122 mRICH_Air_Opt_MPT->AddProperty(
"RINDEX", mRICH_PhotonEnergy_Air_Opt, mRICH_RefractiveIndex_Air_Opt, mRICH_nEntries_Air_Opt);
1124 G4Material* mRICH_Air_Opt =
new G4Material(
"mRICH_Air_Opt", density=1.29*mg/cm3, ncomponents=2);
1125 mRICH_Air_Opt->AddElement(G4Element::GetElement(
"N"), fractionmass=70.*perCent);
1126 mRICH_Air_Opt->AddElement(G4Element::GetElement(
"O"), fractionmass=30.*perCent);
1127 mRICH_Air_Opt->SetMaterialPropertiesTable(mRICH_Air_Opt_MPT);
1130 const int mRICH_nEntries1=32;
1133 G4double mRICH_PhotonEnergy[mRICH_nEntries1] =
1134 { 2.034*eV, 2.068*eV, 2.103*eV, 2.139*eV,
1135 2.177*eV, 2.216*eV, 2.256*eV, 2.298*eV,
1136 2.341*eV, 2.386*eV, 2.433*eV, 2.481*eV,
1137 2.532*eV, 2.585*eV, 2.640*eV, 2.697*eV,
1138 2.757*eV, 2.820*eV, 2.885*eV, 2.954*eV,
1139 3.026*eV, 3.102*eV, 3.181*eV, 3.265*eV,
1140 3.353*eV, 3.446*eV, 3.545*eV, 3.649*eV,
1141 3.760*eV, 3.877*eV, 4.002*eV, 4.136*eV };
1143 G4double mRICH_AcRefractiveIndex[mRICH_nEntries1] =
1144 { 1.4902, 1.4907, 1.4913, 1.4918, 1.4924,
1145 1.4930, 1.4936, 1.4942, 1.4948, 1.4954,
1146 1.4960, 1.4965, 1.4971, 1.4977, 1.4983,
1147 1.4991, 1.5002, 1.5017, 1.5017, 1.5017,
1148 1.5017, 1.5017, 1.5017, 1.5017, 1.5017,
1149 1.5017, 1.5017, 1.5017, 1.5017, 1.5017,
1152 G4double mRICH_AcAbsorption[mRICH_nEntries1] =
1153 {25.25*cm, 25.25*cm, 25.25*cm, 25.25*cm,
1154 25.25*cm, 25.25*cm, 25.25*cm, 25.25*cm,
1155 25.25*cm, 25.25*cm, 25.25*cm, 25.25*cm,
1156 25.25*cm, 25.25*cm, 25.25*cm, 25.25*cm,
1157 25.25*cm, 25.25*cm, 25.25*cm, 25.25*cm,
1158 25.25*cm, 00.667*cm, 00.037*cm, 00.333*cm,
1159 00.001*cm, 00.001*cm, 00.001*cm, 00.001*cm,
1160 00.001*cm, 00.001*cm, 00.001*cm, 00.001*cm};
1162 G4MaterialPropertiesTable* mRICH_Ac_myMPT =
new G4MaterialPropertiesTable();
1163 mRICH_Ac_myMPT->AddProperty(
"RINDEX" ,mRICH_PhotonEnergy, mRICH_AcRefractiveIndex,mRICH_nEntries1);
1164 mRICH_Ac_myMPT->AddProperty(
"ABSLENGTH", mRICH_PhotonEnergy, mRICH_AcAbsorption,mRICH_nEntries1);
1166 G4Material* mRICH_Acrylic=
new G4Material(
"mRICH_Acrylic", density=1.19*g/cm3, ncomponents=3);
1167 mRICH_Acrylic->AddElement(G4Element::GetElement(
"C"), natoms=5);
1168 mRICH_Acrylic->AddElement(G4Element::GetElement(
"H"), natoms=8);
1169 mRICH_Acrylic->AddElement(G4Element::GetElement(
"O"), natoms=2);
1170 mRICH_Acrylic->SetMaterialPropertiesTable(mRICH_Ac_myMPT);
1175 G4double mRICH_Agel1RefractiveIndex[mRICH_nEntries1] =
1176 { 1.02435, 1.0244, 1.02445, 1.0245, 1.02455,
1177 1.0246, 1.02465, 1.0247, 1.02475, 1.0248,
1178 1.02485, 1.02492, 1.025, 1.02505, 1.0251,
1179 1.02518, 1.02522, 1.02530, 1.02535, 1.0254,
1180 1.02545, 1.0255, 1.02555, 1.0256, 1.02568,
1181 1.02572, 1.0258, 1.02585, 1.0259, 1.02595,
1184 G4double mRICH_Agel1Absorption[mRICH_nEntries1] =
1185 { 3.448*m, 4.082*m, 6.329*m, 9.174*m, 12.346*m, 13.889*m,
1186 15.152*m, 17.241*m, 18.868*m, 20.000*m, 26.316*m, 35.714*m,
1187 45.455*m, 47.619*m, 52.632*m, 52.632*m, 55.556*m, 52.632*m,
1188 52.632*m, 47.619*m, 45.455*m, 41.667*m, 37.037*m, 33.333*m,
1189 30.000*m, 28.500*m, 27.000*m, 24.500*m, 22.000*m, 19.500*m,
1190 17.500*m, 14.500*m };
1192 G4double mRICH_Agel1Rayleigh[mRICH_nEntries1];
1194 const G4double AerogelTypeAClarity = 0.0020*micrometer*micrometer*micrometer*micrometer/cm;
1195 G4double Cparam = AerogelTypeAClarity*cm/(micrometer*micrometer*micrometer*micrometer);
1196 G4double PhotMomWaveConv = 1239*eV*nm;
1198 if(Cparam != 0.0 ) {
1199 for(
int i=0; i<mRICH_nEntries1; i++ ){
1200 G4double ephoton = mRICH_PhotonEnergy[i];
1202 G4double wphoton=(PhotMomWaveConv/ephoton)/(1000.0*nm);
1203 mRICH_Agel1Rayleigh[i]=(std::pow(wphoton,4))/Cparam;
1207 G4MaterialPropertiesTable* mRICH_Agel1_myMPT =
new G4MaterialPropertiesTable();
1208 mRICH_Agel1_myMPT->AddProperty(
"RINDEX", mRICH_PhotonEnergy, mRICH_Agel1RefractiveIndex, mRICH_nEntries1);
1209 mRICH_Agel1_myMPT->AddProperty(
"ABSLENGTH", mRICH_PhotonEnergy, mRICH_Agel1Absorption,mRICH_nEntries1);
1210 mRICH_Agel1_myMPT->AddProperty(
"RAYLEIGH", mRICH_PhotonEnergy, mRICH_Agel1Rayleigh, mRICH_nEntries1);
1211 mRICH_Agel1_myMPT->AddConstProperty(
"SCINTILLATIONYIELD",0./MeV);
1212 mRICH_Agel1_myMPT->AddConstProperty(
"RESOLUTIONSCALE",1.0);
1214 G4Material* mRICH_Aerogel1 =
new G4Material(
"mRICH_Aerogel1", density=0.02*g/cm3, ncomponents=2);
1215 mRICH_Aerogel1->AddElement(G4Element::GetElement(
"Si"), natoms=1);
1216 mRICH_Aerogel1->AddElement(G4Element::GetElement(
"O"), natoms=2);
1217 mRICH_Aerogel1->SetMaterialPropertiesTable(mRICH_Agel1_myMPT);
1220 const int mRICH_nEntries2=50;
1222 G4double mRICH_Agel2PhotonEnergy[mRICH_nEntries2]=
1223 {1.87855*eV,1.96673*eV,2.05490*eV,2.14308*eV,2.23126*eV,
1224 2.31943*eV,2.40761*eV,2.49579*eV,2.58396*eV,2.67214*eV,
1225 2.76032*eV,2.84849*eV,2.93667*eV,3.02485*eV,3.11302*eV,
1226 3.20120*eV,3.28938*eV,3.37755*eV,3.46573*eV,3.55391*eV,
1227 3.64208*eV,3.73026*eV,3.81844*eV,3.90661*eV,3.99479*eV,
1228 4.08297*eV,4.17114*eV,4.25932*eV,4.34750*eV,4.43567*eV,
1229 4.52385*eV,4.61203*eV,4.70020*eV,4.78838*eV,4.87656*eV,
1230 4.96473*eV,5.05291*eV,5.14109*eV,5.22927*eV,5.31744*eV,
1231 5.40562*eV,5.49380*eV,5.58197*eV,5.67015*eV,5.75833*eV,
1232 5.84650*eV,5.93468*eV,6.02286*eV,6.11103*eV,6.19921*eV };
1234 G4double mRICH_Agel2RefractiveIndex[mRICH_nEntries2] =
1235 {1.02825,1.02829,1.02834,1.02839,1.02844,
1236 1.02849,1.02854,1.02860,1.02866,1.02872,
1237 1.02878,1.02885,1.02892,1.02899,1.02906,
1238 1.02914,1.02921,1.02929,1.02938,1.02946,
1239 1.02955,1.02964,1.02974,1.02983,1.02993,
1240 1.03003,1.03014,1.03025,1.03036,1.03047,
1241 1.03059,1.03071,1.03084,1.03096,1.03109,
1242 1.03123,1.03137,1.03151,1.03166,1.03181,
1243 1.03196,1.03212,1.03228,1.03244,1.03261,
1244 1.03279,1.03297,1.03315,1.03334,1.03354};
1246 G4double mRICH_Agel2Absorption[mRICH_nEntries2] =
1247 {17.5000*cm,17.7466*cm,17.9720*cm,18.1789*cm,18.3694*cm,
1248 18.5455*cm,18.7086*cm,18.8602*cm,19.0015*cm,19.1334*cm,
1249 19.2569*cm,19.3728*cm,19.4817*cm,19.5843*cm,19.6810*cm,
1250 19.7725*cm,19.8590*cm,19.9410*cm,20.0188*cm,20.0928*cm,
1251 18.4895*cm,16.0174*cm,13.9223*cm,12.1401*cm,10.6185*cm,
1252 9.3147*cm,8.1940*cm,7.2274*cm,6.3913*cm,5.6659*cm,
1253 5.0347*cm,4.4841*cm,4.0024*cm,3.5801*cm,3.2088*cm,
1254 2.8817*cm,2.5928*cm,2.3372*cm,2.1105*cm,1.9090*cm,
1255 1.7296*cm,1.5696*cm,1.4266*cm,1.2986*cm,1.1837*cm,
1256 1.0806*cm,0.9877*cm,0.9041*cm,0.8286*cm,0.7603*cm };
1258 G4double mRICH_Agel2Rayleigh[mRICH_nEntries2] =
1259 {35.1384*cm, 29.24805*cm, 24.5418*cm, 20.7453*cm, 17.6553*cm,
1260 15.1197*cm, 13.02345*cm, 11.2782*cm, 9.81585*cm, 8.58285*cm,
1261 7.53765*cm, 6.6468*cm, 5.88375*cm, 5.22705*cm, 4.6596*cm,
1262 4.167*cm, 3.73785*cm, 3.36255*cm, 3.03315*cm, 2.7432*cm,
1263 2.487*cm, 2.26005*cm, 2.05845*cm, 1.87875*cm, 1.71825*cm,
1264 1.57455*cm, 1.44555*cm, 1.3296*cm, 1.2249*cm, 1.1304*cm,
1265 1.04475*cm, 0.9672*cm, 0.89655*cm, 0.83235*cm, 0.77385*cm,
1266 0.7203*cm, 0.67125*cm, 0.6264*cm, 0.58515*cm, 0.54735*cm,
1267 0.51255*cm, 0.48045*cm, 0.45075*cm, 0.4233*cm, 0.39795*cm,
1268 0.37455*cm, 0.3528*cm, 0.33255*cm, 0.3138*cm, 0.29625*cm};
1270 G4MaterialPropertiesTable* mRICH_Agel2MPT =
new G4MaterialPropertiesTable();
1271 mRICH_Agel2MPT->AddProperty(
"RINDEX", mRICH_Agel2PhotonEnergy, mRICH_Agel2RefractiveIndex, mRICH_nEntries2);
1272 mRICH_Agel2MPT->AddProperty(
"ABSLENGTH", mRICH_Agel2PhotonEnergy, mRICH_Agel2Absorption,mRICH_nEntries2);
1273 mRICH_Agel2MPT->AddProperty(
"RAYLEIGH", mRICH_Agel2PhotonEnergy, mRICH_Agel2Rayleigh, mRICH_nEntries2);
1274 mRICH_Agel2MPT->AddConstProperty(
"SCINTILLATIONYIELD",0./MeV);
1275 mRICH_Agel2MPT->AddConstProperty(
"RESOLUTIONSCALE",1.0);
1277 G4Material* mRICH_Aerogel2 =
new G4Material(
"mRICH_Aerogel2", density=0.02*g/cm3, ncomponents=2);
1278 mRICH_Aerogel2->AddElement(G4Element::GetElement(
"Si"), natoms=1);
1279 mRICH_Aerogel2->AddElement(G4Element::GetElement(
"O"), natoms=2);
1280 mRICH_Aerogel2->SetMaterialPropertiesTable(mRICH_Agel2MPT);
1285 G4double mRICH_glassRefractiveIndex[mRICH_nEntries1] =
1286 { 1.47, 1.47, 1.47, 1.47, 1.47,
1287 1.47, 1.47, 1.47, 1.47, 1.47,
1288 1.47, 1.47, 1.47, 1.47, 1.47,
1289 1.47, 1.47, 1.47, 1.47, 1.47,
1290 1.47, 1.47, 1.47, 1.47, 1.47,
1291 1.47, 1.47, 1.47, 1.47, 1.47,
1294 G4double mRICH_glassAbsorption[mRICH_nEntries1] =
1295 {4.25*cm, 4.25*cm, 4.25*cm, 4.25*cm,
1296 4.25*cm, 4.25*cm, 4.25*cm, 4.25*cm,
1297 4.25*cm, 4.25*cm, 4.25*cm, 4.25*cm,
1298 4.25*cm, 4.25*cm, 4.25*cm, 4.25*cm,
1299 4.25*cm, 4.25*cm, 4.25*cm, 4.25*cm,
1300 4.25*cm, 00.667*cm, 00.037*cm, 00.333*cm,
1301 00.001*cm, 00.001*cm, 00.001*cm, 00.001*cm,
1302 00.001*cm, 00.001*cm, 00.001*cm, 00.001*cm};
1304 G4MaterialPropertiesTable* mRICH_glass_myMPT =
new G4MaterialPropertiesTable();
1306 mRICH_glass_myMPT->AddProperty(
"RINDEX", mRICH_PhotonEnergy, mRICH_glassRefractiveIndex, mRICH_nEntries1);
1307 mRICH_glass_myMPT->AddProperty(
"ABSLENGTH", mRICH_PhotonEnergy, mRICH_glassAbsorption, mRICH_nEntries1);
1309 const G4Material *G4_Pyrex_Glass = nist->FindOrBuildMaterial(
"G4_Pyrex_Glass");
1310 G4Material *mRICH_Borosilicate=
new G4Material(
"mRICH_Borosilicate",G4_Pyrex_Glass->GetDensity(),G4_Pyrex_Glass,G4_Pyrex_Glass->GetState(),G4_Pyrex_Glass->GetTemperature(),G4_Pyrex_Glass->GetPressure());
1311 mRICH_Borosilicate->SetMaterialPropertiesTable(mRICH_glass_myMPT);
1316 G4double mRICH_AirRefractiveIndex[mRICH_nEntries1] =
1317 { 1.00, 1.00, 1.00, 1.00, 1.00, 1.00, 1.00,
1318 1.00, 1.00, 1.00, 1.00, 1.00, 1.00, 1.00,
1319 1.00, 1.00, 1.00, 1.00, 1.00, 1.00, 1.00,
1320 1.00, 1.00, 1.00, 1.00, 1.00, 1.00, 1.00,
1321 1.00, 1.00, 1.00, 1.00 };
1323 G4MaterialPropertiesTable* mRICH_Air_myMPT =
new G4MaterialPropertiesTable();
1324 mRICH_Air_myMPT->AddProperty(
"RINDEX", mRICH_PhotonEnergy, mRICH_AirRefractiveIndex , mRICH_nEntries1);
1325 const G4Material *G4_AIR = G4Material::GetMaterial(
"G4_AIR");
1326 G4Material *mRICH_Air=
new G4Material(
"mRICH_Air",G4_AIR->GetDensity(),G4_AIR,G4_AIR->GetState(),G4_AIR->GetTemperature(),G4_AIR->GetPressure());
1327 mRICH_Air->SetMaterialPropertiesTable(mRICH_Air_myMPT);
1330 G4Element* eleD =
new G4Element(
"eleD",
"eleD", 1.0, 2.014);
1332 G4Material* SQ_LH2 =
new G4Material(
"SQ_LH2", density = 0.07066*g/cm3, ncomponents = 1);
1333 SQ_LH2->AddElement(G4Element::GetElement(
"H"), natoms = 2);
1335 G4Material* SQ_LD2 =
new G4Material(
"SQ_LD2", density = 0.15707*g/cm3, ncomponents = 1);
1336 SQ_LD2->AddElement(eleD, natoms = 2);
1338 G4Material* SQ_NH3 =
new G4Material(
"SQ_NH3", density = 0.917*g/cm3, ncomponents = 2);
1339 SQ_NH3->AddElement(G4Element::GetElement(
"N"), natoms = 1);
1340 SQ_NH3->AddElement(G4Element::GetElement(
"H"), natoms = 3);
1342 G4Material* SQ_ND3 =
new G4Material(
"SQ_ND3", density = 0.987*g/cm3, ncomponents = 2);
1343 SQ_ND3->AddElement(G4Element::GetElement(
"N"), natoms = 1);
1344 SQ_ND3->AddElement(eleD, natoms = 3);
1346 G4Material* SQ_boratedPoly =
new G4Material(
"SQ_boratedPoly", density = 0.95000146*g/cm3, ncomponents = 3);
1347 SQ_boratedPoly->AddElement(G4Element::GetElement(
"B"), fractionmass = 0.7032045573308*perCent);
1348 SQ_boratedPoly->AddElement(G4Element::GetElement(
"C"), fractionmass = 4.0128564211902*perCent);
1349 SQ_boratedPoly->AddElement(G4Element::GetElement(
"H"), fractionmass = 95.283939021478*perCent);
1351 G4Material* SQ_Scintillator =
new G4Material(
"SQ_Scintillator", density = 1.02300158*g/cm3, ncomponents = 2);
1352 SQ_Scintillator->AddElement(G4Element::GetElement(
"C"), fractionmass = 47.368421052631*perCent);
1353 SQ_Scintillator->AddElement(G4Element::GetElement(
"H"), fractionmass = 52.631578947368*perCent);
1355 G4Material* SQ_ArCO2 =
new G4Material(
"SQ_ArCO2", density = 0.001822, ncomponents = 3);
1356 SQ_ArCO2->AddElement(G4Element::GetElement(
"Ar"), fractionmass = 77.651981*perCent);
1357 SQ_ArCO2->AddElement(G4Element::GetElement(
"C"), fractionmass = 5.83366*perCent);
1358 SQ_ArCO2->AddElement(G4Element::GetElement(
"O"), fractionmass = 16.514359*perCent);
1360 G4Material* SQ_P08CF4 =
new G4Material(
"SQ_P08CF4", density = 0.00177504, ncomponents = 4);
1361 SQ_P08CF4->AddElement(G4Element::GetElement(
"Ar"), fractionmass = 89.121162862311*perCent);
1362 SQ_P08CF4->AddElement(G4Element::GetElement(
"C"), fractionmass = 3.2270886143930*perCent);
1363 SQ_P08CF4->AddElement(G4Element::GetElement(
"H"), fractionmass = 0.7168203310375*perCent);
1364 SQ_P08CF4->AddElement(G4Element::GetElement(
"F"), fractionmass = 6.9349281922577*perCent);
1370 const G4RegionStore* theRegionStore = G4RegionStore::GetInstance();
1371 G4ProductionCuts *gcuts =
new G4ProductionCuts(*(theRegionStore->GetRegion(
"DefaultRegionForTheWorld")->GetProductionCuts()));
1372 G4Region *tpcregion =
new G4Region(
"REGION_TPCGAS");
1373 tpcregion->SetProductionCuts(gcuts);
1374 #if G4VERSION_NUMBER >= 1033
1379 G4EmParameters *g4emparams = G4EmParameters::Instance();
1380 g4emparams->AddPAIModel(
"all",
"REGION_TPCGAS",
"PAI");
1391 if (subsys->Name() == name)
1395 cout <<
"Found Subsystem " << name << endl;
1400 cout <<
"Could not find Subsystem " << name << endl;
void g4guithread(void *ptr)
static TThread * gui_thread
int verbosity
The verbosity level. 0 means not verbose at all.
virtual int Verbosity() const
Gets the verbosity of this module.
G4FieldManager * GetDummyFieldManager()
PHBoolean addNode(PHNode *)
PHFieldConfig_v1 implements field configuration information for input a field map file.
PHFieldConfig_v2 implements field configuration information for uniform field model.
PHFieldConfig_v3 implements field configuration information for input a field map file.
PHFieldConfig store field configuration information.
static PHField * GetFieldMapNode(const PHFieldConfig *default_config=nullptr, PHCompositeNode *topNode=nullptr, const int verbosity=0)
Get transient PHField from DST nodes. If not found, make a new one based on default_config.
transient DST object for field storage and access
virtual double get_DoubleFlag(const std::string &name) const
virtual void set_FloatFlag(const std::string &name, const float flag)
virtual const std::string get_CharFlag(const std::string &flag) const
static void Dump_GDML(const std::string &filename, G4VPhysicalVolume *vol, PHCompositeNode *topNode=nullptr)
save the current Geant4 geometry to GDML file. Reading PHG4GDMLConfig from topNode
virtual void identify(std::ostream &os=std::cout) const
this is the main detector construction class, passed to geant to construct the entire phenix detector
G4VPhysicalVolume * GetPhysicalVolume(void)
void AddDetector(PHG4Detector *detector, int zero_field=0)
register a detector. This is called in PHG4Reco::Init based on which detectors are found on the tree
void SetWorldSizeX(const G4double sx)
void SetWorldShape(const std::string &s)
void SetWorldSizeY(const G4double sy)
void SetWorldSizeZ(const G4double sz)
void SetZeroFieldManager(G4FieldManager *man)
void SetWorldMaterial(const std::string &s)
void SetZeroFieldStartZ(const G4double z)
void AddAction(PHG4EventAction *action)
register an action. This is called in PHG4Reco::Init based on which actions are found on the tree
void set_energy_threshold(double t)
void AddAction(PHG4SteppingAction *action)
register an action. This is called in PHG4Reco::Init based on which actions are found on the tree
void AddAction(PHG4TrackingAction *action)
register an action. This is called in PHG4Reco::Init based on which actions are found on the tree
void SetInEvent(PHG4InEvent *const inevt)
set top node (from where particle list is retrieved for passing to geant
PHG4PhenixTrackingAction * trackingAction_
pointer to main tracking action
PHG4PhenixEventAction * eventAction_
pointer to main event action
int ResetEvent(PHCompositeNode *)
Clean up after each event.
int StartGui()
start the gui
SubsystemList subsystems_
PHG4Reco(const std::string &name="PHG4RECO")
constructor
void Dump_GDML(const std::string &filename)
int Init(PHCompositeNode *)
full initialization
void setGeneratorAction(G4VUserPrimaryGeneratorAction *action)
PHTimeServer::timer _timer
module timer.
PHG4PrimaryGeneratorAction * generatorAction_
event generator (read from PHG4INEVENT node)
int InitField(PHCompositeNode *topNode)
bool optical_photon_
speed up options
void set_rapidity_coverage(const double eta)
PHG4PhenixDetector * detector_
pointer to detector
virtual ~PHG4Reco()
destructor
int ApplyCommand(const std::string &cmd)
interface to G4 cmd interpreter
G4VisManager * visManager
std::string worldmaterial
PHFieldConfig::FieldConfigTypes mapdim
int InitRun(PHCompositeNode *topNode)
void Print(const std::string &what=std::string()) const
print info
G4TBMagneticFieldSetup * field_
magnetic field
int End(PHCompositeNode *)
end of run method
int process_event(PHCompositeNode *)
event processing method
static void G4Seed(const unsigned int i)
PHG4PhenixSteppingAction * steppingAction_
pointer to main stepping action
void G4Verbosity(const int i)
G4RunManager * runManager_
pointer to geant run manager
int setupInputEventNodeReader(PHCompositeNode *)
PHG4UIsession * uisession_
pointer to geant ui session
PHG4Subsystem * getSubsystem(const std::string &name)
static void SetPseudoRapidityCoverage(const double eta)
static std::string GenerateGeometryFileName(const std::string &filename_extension="gdml")
static int ImportGeomFile(PHCompositeNode *topNode, const std::string &geometry_file)
TGeo ROOT/GDML/Macro file -> DST node with automatic file type discrimination based on file names.
static bool RemoveGeometryFile(const std::string &file_name)
delete the geometry file after use
PHNode * findFirst(const std::string &, const std::string &)
PHTimer server for accessing external information.
void restart()
Restart timer.
void stop()
stops the counter
static recoConsts * instance()