130 {
131
132
135
137 EvtId other_b;
138 EvtId daugs[2];
139
140
141
142 int flip = ((p->
getId() == B0) ? 0 : 1);
146
148
149 EvtComplex amp[3];
150
153 EvtComplex ePlusIPhi(
cos(phiCKM),
sin(phiCKM));
154 EvtComplex eMinusIPhi(
cos(-phiCKM),
sin(-phiCKM));
155
156
157
158
159 if (!flip) {
160 if (other_b==B0B){
161
162 for (int i=0; i<3; ++i) {
163 amp[i] = _A_f[i]*
cos(dmt2) + eMinusIPhi*EvtComplex(0.0,
sin(dmt2))*_A_f[i+3];
164 }
165 }
166 if (other_b==B0){
167
168 for(int i=0; i<3; ++i) {
169 amp[i] = _A_f[i]*ePlusIPhi*EvtComplex(0.0,
sin(dmt2)) + _A_f[i+3]*
cos(dmt2);
170 }
171 }
172 } else{
173 if (other_b==B0B){
174
175
176
177
178
179
180
181 for(int i=0; i<3; ++i) {
182 amp[i] = _A_f[8-i]*
cos(dmt2) + eMinusIPhi*EvtComplex(0.0,
sin(dmt2))*_A_f[11-i];
183 }
184 }
185 if (other_b==B0){
186
187 for(int i=0; i<3; ++i) {
188 amp[i] = _A_f[8-i] * ePlusIPhi * EvtComplex(0.0,
sin(dmt2)) + _A_f[11-i]*
cos(dmt2);
189 }
190 }
191 }
192
194
195 return ;
196}
double sin(const BesAngle a)
double cos(const BesAngle a)
static void OtherB(EvtParticle *p, double &t, EvtId &otherb)
static EvtId getId(const std::string &name)
double initializePhaseSpace(int numdaughter, EvtId *daughters, double poleSize=-1., int whichTwo1=0, int whichTwo2=1)
static void SVVHel(EvtParticle *parent, EvtAmp &, EvtId n_v1, EvtId n_v2, const EvtComplex &hp, const EvtComplex &h0, const EvtComplex &hm)