11 TString OutputFile =
"sim_complete.root";
12 TString ParOutputfile =
"simparams.root";
13 TString MediaFile =
"media_pnd.geo";
18 Bool_t UseEvtGenDirect =kFALSE;
20 Bool_t UseBoxGenerator =kTRUE;
32 TLorentzVector
fIni(0, 0,
mom,
sqrt(
mom*
mom+9.3827203e-01*9.3827203e-01)+9.3827203e-01);
33 TDatabasePDG::Instance()->AddParticle(
"pbarpSystem",
"pbarpSystem",
fIni.M(),kFALSE,0.1,0,
"",88888);
40 FairRunSim *
fRun =
new FairRunSim();
41 fRun->SetName(SimEngine.Data() );
42 fRun->SetOutputFile(OutputFile.Data());
43 fRun->SetGenerateRunInfo(kFALSE);
44 fRun->SetBeamMom(BeamMomentum);
45 fRun->SetMaterials(MediaFile.Data());
46 FairRuntimeDb *
rtdb=fRun->GetRuntimeDb();
51 allDigiFile +=
"/macro/params/";
56 FairParAsciiFileIo*
parIo1 =
new FairParAsciiFileIo();
57 parIo1->open(allDigiFile.Data(),
"in");
58 rtdb->setFirstInput(parIo1);
62 FairParRootFileIo*
output=
new FairParRootFileIo(kParameterMerged);
63 output->open(ParOutputfile.Data());
64 rtdb->setOutput(output);
71 Cave->SetGeometryFileName(
"pndcave.geo");
72 fRun->AddModule(Cave);
79 Dipole->SetGeometryFileName(
"dipole.geo");
80 fRun->AddModule(Dipole);
83 Pipe->SetGeometryFileName(
"beampipe_201309.root");
84 fRun->AddModule(Pipe);
95 Gem->SetGeometryFileName(
"gem_3Stations_Tube.root");
127 FairDetector *
Fts=
new PndFts(
"FTS", kTRUE);
128 Fts->SetGeometryFileName(
"fts_reduced.geo");
129 fRun->AddModule(Fts);
132 FTof->SetGeometryFileName(
"ftofwall.root");
133 fRun->AddModule(FTof);
135 FairDetector *Rich=
new PndRich(
"RICH",kFALSE);
136 Rich->SetGeometryFileName(
"rich_v2_shift.geo");
137 fRun->AddModule(Rich);
141 FairPrimaryGenerator*
primGen =
new FairPrimaryGenerator();
142 fRun->SetGenerator(primGen);
160 FairBoxGenerator* muMinusBoxGen =
new FairBoxGenerator(13, 1);
161 muMinusBoxGen->SetPRange(1.0,3.0);
162 muMinusBoxGen->SetPhiRange(0., 360.);
163 muMinusBoxGen->SetThetaRange(3., 7.);
164 muMinusBoxGen->SetXYZ(0., 0., 0.);
165 primGen->AddGenerator(muMinusBoxGen);
169 primGen->AddGenerator(Dpm);
172 TString EvtInput =gSystem->Getenv(
"VMCWORKDIR");
173 EvtInput+=
"/input/psi2s_jpsi2pi_1k.evt";
174 FairEvtGenGenerator*
evtGen =
new FairEvtGenGenerator(EvtInput.Data());
175 primGen->AddGenerator(evtGen);
178 TString EvtInput =gSystem->Getenv(
"VMCWORKDIR");
179 EvtInput+=
"/macro/run/psi2s_Jpsi2pi_Jpsi_mumu.dec";
182 primGen->AddGenerator(EvtGen);
187 fRun->SetField(fField);
195 fRun->SetStoreTraj(kTRUE);
201 trajFilter->SetStepSizeCut(0.04);
205 trajFilter->SetStorePrimaries(kTRUE);
206 trajFilter->SetStoreSecondaries(kTRUE);
215 printf(
"RealTime=%f seconds, CpuTime=%f seconds\n",rtime,ctime);
217 cout <<
" Test passed" << endl;
218 cout <<
" All ok " << endl;
FairTrajFilter * trajFilter
printf("RealTime=%f seconds, CpuTime=%f seconds\n", rtime, ctime)
friend F32vec4 sqrt(const F32vec4 &a)
FairParRootFileIo * output
FairPrimaryGenerator * primGen
void SetStoreTree(Bool_t store=true)
FairParAsciiFileIo * parIo1
FairEvtGenGenerator * evtGen