12 TString OutputFile =
"sim_complete.root";
17 TString MediaFile =
"media_pnd.geo";
21 Bool_t UseEvtGenDirect =kTRUE;
24 Bool_t UseBoxGenerator =kFALSE;
36 TLorentzVector
fIni(0, 0,
mom,
sqrt(
mom*
mom+9.3827203e-01*9.3827203e-01)+9.3827203e-01);
37 TDatabasePDG::Instance()->AddParticle(
"pbarpSystem",
"pbarpSystem",fIni.M(),kFALSE,0.1,0,
"",88888);
44 FairRunSim *
fRun =
new FairRunSim();
45 fRun->SetName(SimEngine.Data() );
46 fRun->SetOutputFile(OutputFile.Data());
47 fRun->SetGenerateRunInfo(kFALSE);
48 fRun->SetBeamMom(BeamMomentum);
49 fRun->SetMaterials(MediaFile.Data());
50 fRun->SetUseFairLinks(kTRUE);
51 FairRuntimeDb *
rtdb=fRun->GetRuntimeDb();
56 allDigiFile +=
"/macro/params/";
61 FairParAsciiFileIo*
parIo1 =
new FairParAsciiFileIo();
62 parIo1->open(allDigiFile.Data(),
"in");
63 rtdb->setFirstInput(parIo1);
67 FairParRootFileIo*
output=
new FairParRootFileIo(kParameterMerged);
68 output->open(ParOutputfile.Data());
69 rtdb->setOutput(output);
76 Cave->SetGeometryFileName(
"pndcave.geo");
77 fRun->AddModule(Cave);
84 Dipole->SetGeometryFileName(
"dipole.geo");
85 fRun->AddModule(Dipole);
88 Pipe->SetGeometryFileName(
"beampipe_201309.root");
89 fRun->AddModule(Pipe);
91 FairDetector *
Stt=
new PndStt(
"STT", kTRUE);
92 Stt->SetGeometryFileName(
"straws_skewed_blocks_35cm_pipe.geo");
96 Mvd->SetGeometryFileName(
"Mvd-2.1_FullVersion.root");
100 Gem->SetGeometryFileName(
"gem_3Stations_Tube.root");
101 fRun->AddModule(Gem);
106 fRun->AddModule(Emc);
108 FairDetector *SciT =
new PndSciT(
"SCIT",kTRUE);
109 SciT->SetGeometryFileName(
"SciTil_201508.root");
110 fRun->AddModule(SciT);
113 Drc->SetGeometryFileName(
"dirc_l0_p0_updated.root");
115 fRun->AddModule(Drc);
120 fRun->AddModule(Dsk);
130 fRun->AddModule(Muo);
132 FairDetector *
Fts=
new PndFts(
"FTS", kTRUE);
133 Fts->SetGeometryFileName(
"fts.geo");
134 fRun->AddModule(Fts);
137 FTof->SetGeometryFileName(
"ftofwall.root");
138 fRun->AddModule(FTof);
140 FairDetector *Rich=
new PndRich(
"RICH",kFALSE);
141 Rich->SetGeometryFileName(
"rich_v2_shift.geo");
142 fRun->AddModule(Rich);
146 FairPrimaryGenerator*
primGen =
new FairPrimaryGenerator();
147 fRun->SetGenerator(primGen);
150 FairBoxGenerator*
boxGen =
new FairBoxGenerator(22, 5);
151 boxGen->SetPRange(
mom,
mom);
152 boxGen->SetPhiRange(0., 360.);
153 boxGen->SetThetaRange(0., 90.);
154 boxGen->SetXYZ(0., 0., 0.);
155 primGen->AddGenerator(boxGen);
159 primGen->AddGenerator(Dpm);
166 primGen->AddGenerator(Ftf);
169 TString EvtInput =gSystem->Getenv(
"VMCWORKDIR");
170 EvtInput+=
"/macro/QA/timeOrdered/psi2s_Jpsi2pi_Jpsi_mumu.dec";
173 primGen->AddGenerator(EvtGen);
178 fRun->SetField(fField);
183 fRun->AddTask(emcHitProd);
195 printf(
"RealTime=%f seconds, CpuTime=%f seconds\n",rtime,ctime);
197 cout <<
" Test passed" << endl;
198 cout <<
" All ok " << endl;
void SetForward(TString name)
printf("RealTime=%f seconds, CpuTime=%f seconds\n", rtime, ctime)
friend F32vec4 sqrt(const F32vec4 &a)
creates PndEmcHits from PndEmcPoints
void SetMdtCoil(bool opt=false)
void SetMdtMFIron(bool opt=false)
void SetStorageOfData(Bool_t val)
int run_sim(Int_t nEvents=100, TString SimEngine="TGeant3", Float_t mom=6.231552)
FairParRootFileIo * output
FairPrimaryGenerator * primGen
void SetMdtMagnet(bool opt=false)
void SetStoreTrackPoints(Bool_t storeTrackPoints)
void SetStoreTree(Bool_t store=true)
A simple class which adds the corresponding file extensions to a given base class.
void SetStoreCerenkovs(Bool_t storeCerenkovs)
virtual void SetGeometryVersion(const Int_t GeoNumber)
void SetBarrel(TString name)
FairParAsciiFileIo * parIo1
FairBoxGenerator * boxGen
void SetEndcap(TString name)
void SetMuonFilter(TString name)
PndMvdCreateDefaultApvMap * creator
void SetRunCherenkov(Bool_t ch)