CGEM BOSS 6.6.5.f
BESIII Offline Software System
Loading...
Searching...
No Matches
EvtChi0BB2.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: EvtChi0BB2.cc
12//
13// Description: Routine to decay Chi0 to B8 B8bar.
14//
15// Modification history:
16//
17// Pang C.Y. and Ping R.-G. April, 2007 Module created
18//
19//------------------------------------------------------------------------
20//
22#include <stdlib.h>
25#include "EvtGenBase/EvtPDL.hh"
32#include "EvtChi0BB2.hh"
33#include <string>
34using std::endl;
35using std::cout;
37
38void EvtChi0BB2::getName(std::string& model_name){
39
40 model_name="Chi0BB2";
41
42}
43
44
46
47 return new EvtChi0BB2;
48
49}
50
52// check that there are 1 arguments
53 checkNArg(2);
54 checkNDaug(2);
58
59 }
60
61/*
62void EvtChi0BB2::initProbMax() {
63
64 //Hard coded... should not be hard to calculate...
65 setProbMax(10.0);
66
67}
68*/
69
71
73
74 EvtParticle *v,*s1;
75 EvtVector4R pv,ps,ppr;
76
77 v =p->getDaug(0);
78 s1=p->getDaug(1);
79 pv=v->getP4();
80 ps=s1->getP4();
81 ppr=p->getP4();
82
83// Put phase space results into the daughters.
84 EvtHelSys angles(ppr,pv); //using helicity sys. angles
85 double theta =angles.getHelAng(1);
86 double phi =angles.getHelAng(2);
87 double gamma=0;
88
89 double F00=getArg(0);
90 double F11=getArg(1);
91 double F33=F00;
92 double F22=F11;
93//cout<<"************F00,F11,F22,F33="<<F00<<F11<<F22<<F33<<endl;
94 vertex(0,0,F00);
95 vertex(1,1,F11);
96 vertex(2,2,F22);
97 vertex(3,3,F33);
98
99 return ;
100
101}
102
103
104
105
**********Class see also m_nmax DOUBLE PRECISION m_amel DOUBLE PRECISION m_x2 DOUBLE PRECISION m_alfinv DOUBLE PRECISION m_Xenph INTEGER m_KeyWtm INTEGER m_idyfs DOUBLE PRECISION m_zini DOUBLE PRECISION m_q2 DOUBLE PRECISION m_Wt_KF DOUBLE PRECISION m_WtCut INTEGER m_KFfin *COMMON c_KarLud $ !Input CMS energy[GeV] $ !CMS energy after beam spread beam strahlung[GeV] $ !Beam energy spread[GeV] $ !z boost due to beam spread $ !electron beam mass *ff pair spectrum $ !minimum v
Definition: KarLud.h:35
void init()
Definition: EvtChi0BB2.cc:51
EvtDecayBase * clone()
Definition: EvtChi0BB2.cc:45
void getName(std::string &name)
Definition: EvtChi0BB2.cc:38
void decay(EvtParticle *p)
Definition: EvtChi0BB2.cc:70
virtual ~EvtChi0BB2()
Definition: EvtChi0BB2.cc:36
void vertex(const EvtComplex &amp)
Definition: EvtDecayAmp.hh:37
void checkSpinDaughter(int d1, EvtSpinType::spintype sp)
void checkSpinParent(EvtSpinType::spintype sp)
double getArg(int j)
void checkNDaug(int d1, int d2=-1)
EvtId * getDaugs()
Definition: EvtDecayBase.hh:65
void checkNArg(int a1, int a2=-1, int a3=-1, int a4=-1)
double getHelAng(int i)
Definition: EvtHelSys.cc:54
const EvtVector4R & getP4() const
Definition: EvtParticle.cc:121
EvtParticle * getDaug(int i)
Definition: EvtParticle.cc:85
double initializePhaseSpace(int numdaughter, EvtId *daughters, double poleSize=-1., int whichTwo1=0, int whichTwo2=1)