BOSS 7.0.5
BESIII Offline Software System
Loading...
Searching...
No Matches
EvtPhokhara_pi0pi0pipi.cc
Go to the documentation of this file.
1//--------------------------------------------------------------------------
2//
3// Environment:
4// This software is part of models developed at BES collaboration
5// based on the EvtGen framework. If you use all or part
6// of it, please give an appropriate acknowledgement.
7//
8// Copyright Information: See EvtGen/BesCopyright
9// Copyright (A) 2006 Ping Rong-Gang @IHEP
10//
11// Module: EvtPhokhara.cc
12// the necessary file: phokharar.F
13// fist.inc,gen.inc mix.inc stdhep.inc
14// Description: Modified Lund model at tau-charm energy level, see
15// PHYSICAL REVIEW D, VOLUME 62, 034003
16// Modification history:
17//
18// Ping R.-G. Jan.25, 2010 Module created
19// The random engine RLU0 is unified with RLU for BesEvtGen
20//------------------------------------------------------------------------
21//
27#include "EvtGenBase/EvtPDL.hh"
31#include <string>
32#include "EvtGenBase/EvtId.hh"
33#include <iostream>
34#include <iomanip>
35#include <fstream>
36#include <string.h>
37#include <stdlib.h>
38#include <unistd.h>
39#include <stdio.h>
40
41#include "GeneratorObject/McGenEvent.h"
42#include "BesKernel/IBesRndmGenSvc.h"
43#include "CLHEP/Random/RandomEngine.h"
44#include "cfortran/cfortran.h"
45
46using namespace std;
47using namespace CLHEP;
48
49using std::endl;
50using std::fstream;
51using std::ios;
52using std::ofstream;
53using std::resetiosflags;
54using std::setiosflags;
55using std::setw;
56
57int EvtPhokhara_pi0pi0pipi::nevtgen=0;
58int EvtPhokhara_pi0pi0pipi::nphokharadecays=0;
59EvtDecayBasePtr* EvtPhokhara_pi0pi0pipi::phokharadecays=0;
60int EvtPhokhara_pi0pi0pipi::ntable=0;
61
62int EvtPhokhara_pi0pi0pipi::ncommand=0;
63int EvtPhokhara_pi0pi0pipi::lcommand=0;
64std::string* EvtPhokhara_pi0pi0pipi::commands=0;
65int EvtPhokhara_pi0pi0pipi::nevt=0;
66
69 int i;
70 //the deletion of commands is really uggly!
71
72 if (nphokharadecays==0) {
73 delete [] commands;
74 commands=0;
75 return;
76 }
77
78 for(i=0;i<nphokharadecays;i++){
79 if (phokharadecays[i]==this){
80 phokharadecays[i]=phokharadecays[nphokharadecays-1];
81 nphokharadecays--;
82 if (nphokharadecays==0) {
83 delete [] commands;
84 commands=0;
85 }
86 return;
87 }
88 }
89
90 report(ERROR,"EvtGen") << "Error in destroying Phokhara model!"<<endl;
91
92}
93
94
95void EvtPhokhara_pi0pi0pipi::getName(std::string& model_name){
96
97 model_name="PHOKHARA_pi0pi0pipi";
98
99}
100
102
103 return new EvtPhokhara_pi0pi0pipi;
104
105}
106
107
109
110 noProbMax();
111
112}
113
114
116 m_pion=2;
117 // mu+mu-(0),pi+pi-(1),2pi0pi+pi-(2),
118 // 2pi+2pi-(3),ppbar(4),nnbar(5),
119 // K+K-(6),K0K0bar(7),pi+pi-pi0(8),
120 // Lamb Lambbar->pi-pi+ppbar(9),
121 // pi+pi-eta(10)
122#include "Phokhara_init_mode.txt"
123}
124
125
126
128 checkNArg(0);
129
130 std::string locvp=getenv("BESEVTGENROOT");
131 system("cat $BESEVTGENROOT/share/phokhara_9.1.param>phokhara_9.1.param");
132 system("cat $BESEVTGENROOT/share/phokhara_9.1.fferr>phokhara_9.1.fferr");
133 system("cat $BESEVTGENROOT/share/phokhara_9.1.ffwarn>phokhara_9.1.ffwarn");
134
135
136 if (getParentId().isAlias()){
137
138 report(ERROR,"EvtGen") << "EvtPhokhara finds that you are decaying the"<<endl
139 << " aliased particle "
140 << EvtPDL::name(getParentId()).c_str()
141 << " with the Phokhara model"<<endl
142 << " this does not work, please modify decay table."
143 << endl;
144 report(ERROR,"EvtGen") << "Will terminate execution!"<<endl;
145 ::abort();
146
147 }
148
149 store(this);
150
151}
152
153
155
156 return std::string("PhokharaPar");
157
158}
159
161
162 if (ncommand==lcommand){
163
164 lcommand=10+2*lcommand;
165
166 std::string* newcommands=new std::string[lcommand];
167
168 int i;
169
170 for(i=0;i<ncommand;i++){
171 newcommands[i]=commands[i];
172 }
173
174 delete [] commands;
175
176 commands=newcommands;
177
178 }
179
180 commands[ncommand]=cmd;
181
182 ncommand++;
183
184}
185
186
187
189 EvtId myvpho=EvtPDL::getId("vpho");
190 if(p->getId()!=myvpho) {std::cout<<"Parent particle is required to be vpho for Phokhara model"<<std::endl;abort();}
191 if(nevtgen==0) {init_mode(p);}
192 else {init_evt(p);}
193
194 std::cout<<"PHOKHARA : pi0pi0pi+pi- mode "<<std::endl;
195 int istdheppar=EvtPDL::getStdHep(p->getId());
196 int ntrials = 0;
197 int tr_old[3];
198 tr_old[0] = (int)maxima_.tr[0];
199 tr_old[1] = (int)maxima_.tr[1];
200 tr_old[2] = (int)maxima_.tr[2];
201
202 while( ntrials < 1000000)
203 {
204 ievent++;
205 RANLXDF(Ar_r,1);
206 Ar[1] = Ar_r[0];
207
208 if (Ar[1] <= (maxima_.Mmax[0]/(maxima_.Mmax[0]+maxima_.Mmax[1]+maxima_.Mmax[2]))) {
209 maxima_.count[0] = maxima_.count[0]+1.0;
210 GEN_0PH(2,qqmin,ctes_.Sp,cos3min,cos3max);
211 }else
212 if (Ar[1] <= ( (maxima_.Mmax[0]+maxima_.Mmax[1])/(maxima_.Mmax[0]+maxima_.Mmax[1]+maxima_.Mmax[2]))) {
213 maxima_.count[1] = maxima_.count[1]+1.0;
214 GEN_1PH(2,qqmin,qqmax,cos1min,cos1max,cos3min,cos3max);
215 }
216 else {
217 maxima_.count[2] = maxima_.count[2]+1.0;
218 GEN_2PH(2,qqmin,cos1min,cos1max,cos2min,cos2max,cos3min,cos3max);
219 }
220
221 if( ((int)maxima_.tr[0]+(int)maxima_.tr[1]+(int)maxima_.tr[2]) > (tr_old[0]+tr_old[1]+tr_old[2]) ) // event accepted after cuts
222 {
223 goto storedEvents;
224 }
225 ntrials ++;
226 }
227 std::cout <<"FATAL: Could not satisfy cuts after " << ntrials << "trials. Terminate." <<std::endl;
228 //----
229 storedEvents:
230 int more=0;
231 int numstable=0;
232 int numparton=0;
233 EvtId evtnumstable[100];//
234 EvtVector4R p4[20];
235
236 // except ISR photos, products depending on channel
237 if (flags_.pion == 0) { // mu+ mu-
238 // mu+
239 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-13);
240 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
241 numstable++;
242 // mu -
243 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(13);
244 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
245 numstable++;
246 }
247 if (flags_.pion == 1) { // pi+ pi-
248 // pi+
249 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
250 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
251 numstable++;
252 // pi -
253 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
254 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
255 numstable++;
256 }
257 if (flags_.pion == 2) { // pi+ pi-2pi0
258 // pi0
259 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(111);
260 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
261 numstable++;
262 // pi0
263 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(111);
264 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
265 numstable++;
266 // pi-
267 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
268 p4[numstable].set(ctes_.momenta[0][7],ctes_.momenta[1][7], ctes_.momenta[2][7], ctes_.momenta[3][7]);
269 numstable++;
270 // pi +
271 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
272 p4[numstable].set(ctes_.momenta[0][8],ctes_.momenta[1][8], ctes_.momenta[2][8], ctes_.momenta[3][8]);
273 numstable++;
274 }
275 if (flags_.pion == 3) { // 2(pi+ pi-)
276 // pi+
277 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
278 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
279 numstable++;
280 // pi-
281 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
282 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
283 numstable++;
284 // pi+
285 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
286 p4[numstable].set(ctes_.momenta[0][7],ctes_.momenta[1][7], ctes_.momenta[2][7], ctes_.momenta[3][7]);
287 numstable++;
288 // pi -
289 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
290 p4[numstable].set(ctes_.momenta[0][8],ctes_.momenta[1][8], ctes_.momenta[2][8], ctes_.momenta[3][8]);
291 numstable++;
292 }
293 if (flags_.pion == 4) { // ppbar
294 // pbar
295 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-2212);
296 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
297 numstable++;
298 // p
299 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(2212);
300 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
301 numstable++;
302 }
303 if (flags_.pion == 5) { // nnbar
304 // pbar
305 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-2112);
306 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
307 numstable++;
308 // p
309 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(2112);
310 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
311 numstable++;
312 }
313 if (flags_.pion == 6) { // K+ K-
314 // K+
315 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(321);
316 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
317 numstable++;
318 // K -
319 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-321);
320 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
321 numstable++;
322 }
323 if (flags_.pion == 7) { // K0K0bar
324 // Kbar
325 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(311);
326 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
327 numstable++;
328 // K0
329 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-311);
330 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
331 numstable++;
332 }
333 if (flags_.pion == 8) { // pi+ pi-pi0
334 // pi+
335 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
336 p4[numstable].set(ctes_.momenta[0][5],ctes_.momenta[1][5], ctes_.momenta[2][5], ctes_.momenta[3][5]);
337 numstable++;
338 // pi-
339 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
340 p4[numstable].set(ctes_.momenta[0][6],ctes_.momenta[1][6], ctes_.momenta[2][6], ctes_.momenta[3][6]);
341 numstable++;
342 // pi0
343 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(111);
344 p4[numstable].set(ctes_.momenta[0][7],ctes_.momenta[1][7], ctes_.momenta[2][7], ctes_.momenta[3][7]);
345 numstable++;
346 }
347 if (flags_.pion == 9) { //Lambda Lambdabar-> pi+ pi- ppbar
348 // pi+
349 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(211);
350 p4[numstable].set(ctes_.momenta[0][7],ctes_.momenta[1][7], ctes_.momenta[2][7], ctes_.momenta[3][7]);
351 numstable++;
352 // pbar
353 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-2212);
354 p4[numstable].set(ctes_.momenta[0][8],ctes_.momenta[1][8], ctes_.momenta[2][8], ctes_.momenta[3][8]);
355 numstable++;
356 // pi-
357 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(-211);
358 p4[numstable].set(ctes_.momenta[0][9],ctes_.momenta[1][9], ctes_.momenta[2][9], ctes_.momenta[3][9]);
359 numstable++;
360 // p
361 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(2212);
362 p4[numstable].set(ctes_.momenta[0][10],ctes_.momenta[1][10], ctes_.momenta[2][10], ctes_.momenta[3][10]);
363 numstable++;
364 }
365
366 // ISR gamma
367 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(22);
368 p4[numstable].set(ctes_.momenta[0][2],ctes_.momenta[1][2], ctes_.momenta[2][2], ctes_.momenta[3][2]);
369 numstable++;
370 if( ctes_.momenta[0][3] != 0 ) // second photon exists
371 {
372 evtnumstable[numstable]=EvtPDL::evtIdFromStdHep(22);
373 p4[numstable].set(ctes_.momenta[0][3],ctes_.momenta[1][3], ctes_.momenta[2][3], ctes_.momenta[3][3]);
374 numstable++;
375 }
376
377 int channel=EvtDecayTable::inChannelList(p->getId(),numstable,evtnumstable);
378 more=(channel!=-1);
379 if(more) {std::cout<<"Existence of mode "<<channel<<" in exclusive decay list has the same final state as this one"<<std::endl;abort(); }
380
381 p->makeDaughters(numstable,evtnumstable);
382
383 int ndaugFound=0;
384 EvtVector4R SUMP4(0,0,0,0);
385 for(int i=0;i<numstable;i++){
386 p->getDaug(i)->init(evtnumstable[i],p4[i]);
387 ndaugFound++;
388 }
389 if ( ndaugFound == 0 ) {
390 report(ERROR,"EvtGen") << "Phokhara has failed to do a decay ";
391 report(ERROR,"EvtGen") << EvtPDL::name(p->getId()).c_str() << " " << p->mass()<<endl;
392 assert(0);
393 }
394
395 nevtgen++;
396 return ;
397
398}
399
400
401
402void EvtPhokhara_pi0pi0pipi::store(EvtDecayBase* jsdecay){
403
404 if (nphokharadecays==ntable){
405
406 EvtDecayBasePtr* newphokharadecays=new EvtDecayBasePtr[2*ntable+10];
407 int i;
408 for(i=0;i<ntable;i++){
409 newphokharadecays[i]=phokharadecays[i];
410 }
411 ntable=2*ntable+10;
412 delete [] phokharadecays;
413 phokharadecays=newphokharadecays;
414 }
415
416 phokharadecays[nphokharadecays++]=jsdecay;
417
418
419
420}
421
422
424 static int first=1;
425 if (first){
426
427 first=0;
428 //for(int i=0;i<ncommand;i++)
429 // lugive0_(commands[i].c_str(),strlen(commands[i].c_str()));
430 }
431
432}
433
434
435
437 m_pion=2;
438 // mu+mu-(0),pi+pi-(1),2pi0pi+pi-(2),
439 // 2pi+2pi-(3),ppbar(4),nnbar(5),
440 // K+K-(6),K0K0bar(7),pi+pi-pi0(8),
441 // Lamb Lambbar->pi-pi+ppbar(9)
442#include "Phokhara_init_evt.txt"
443}
444
struct @17 flags_
#define GEN_1PH(I, QQMIN, QQMAX, COS1MIN, COS1MAX, COS3MIN, COS3MAX)
#define RANLXDF(AR, VAL)
#define GEN_0PH(I, QQMIN, SP, COS3MIN, COS3MAX)
struct @16 maxima_
struct @10 ctes_
#define GEN_2PH(I, QQMIN, COS1MIN, COS1MAX, COS2MIN, COS2MAX, COS3MIN, COS3MAX)
ostream & report(Severity severity, const char *facility)
Definition: EvtReport.cc:36
@ ERROR
Definition: EvtReport.hh:49
void noProbMax()
EvtId getParentId()
Definition: EvtDecayBase.hh:60
void checkNArg(int a1, int a2=-1, int a3=-1, int a4=-1)
static int inChannelList(EvtId parent, int ndaug, EvtId *daugs)
Definition: EvtId.hh:27
static int getStdHep(EvtId id)
Definition: EvtPDL.hh:56
static EvtId evtIdFromStdHep(int stdhep)
Definition: EvtPDL.cc:244
static std::string name(EvtId i)
Definition: EvtPDL.hh:64
static EvtId getId(const std::string &name)
Definition: EvtPDL.cc:287
void makeDaughters(int ndaug, EvtId *id)
virtual void init(EvtId part_n, const EvtVector4R &p4)=0
EvtId getId() const
Definition: EvtParticle.cc:113
EvtParticle * getDaug(int i)
Definition: EvtParticle.cc:85
double mass() const
Definition: EvtParticle.cc:127
void init_mode(EvtParticle *p)
void command(std::string cmd)
void init_evt(EvtParticle *p)
void getName(std::string &name)
void set(int i, double d)
Definition: EvtVector4R.hh:183