183 {
184 MsgStream log(
msgSvc(), name());
185 log << MSG::DEBUG << "BabayagaNLO in execute()" << endreq;
186
187
188 GenEvent* evt = new GenEvent(1,1);
189 GenVertex* prod_vtx = new GenVertex();
190 evt->add_vertex( prod_vtx );
191
192 log << MSG::DEBUG << "check point 1" << endreq;
193 bool unw = !(m_weighted);
194
195 log << MSG::DEBUG << "check point 2" << endreq;
197
198 log << MSG::DEBUG << "check point 3" << endreq;
199 int finalpidm,finalpidp;
200 if (m_ch == 0) {
201 finalpidm=11;
202 finalpidp=-11;
203 } else if (m_ch == 1) {
204 finalpidm=13;
205 finalpidp=-13;
206 } else if (m_ch == 2) {
207 finalpidm=22;
208 finalpidp=22;
209 } else {
210 finalpidm=11;
211 finalpidp=-11;
212 }
213
218
219
220
221 GenParticle *p =
new GenParticle(CLHEP::HepLorentzVector(
p1[1],
p1[2],-
p1[3],
p1[0]), 11, 3);
222 p->suggest_barcode(1);
223 prod_vtx->add_particle_in(p);
224
225
226 p =
new GenParticle(CLHEP::HepLorentzVector(
p2[1],
p2[2],-
p2[3],
p2[0]), -11, 3);
227 p->suggest_barcode(2);
228 prod_vtx->add_particle_in(p);
229
230 log << MSG::DEBUG << "check point 4" << endreq;
231
232 p =
new GenParticle(CLHEP::HepLorentzVector(
p3[1],
p3[2],-
p3[3],
p3[0]), finalpidm, 1);
233 p->suggest_barcode(3);
234 prod_vtx->add_particle_out(p);
235
236
237 p =
new GenParticle(CLHEP::HepLorentzVector(
p4[1],
p4[2],-
p4[3],
p4[0]), finalpidp, 1);
238 p->suggest_barcode(4);
239 prod_vtx->add_particle_out(p);
240
241 log << MSG::DEBUG << "check point 5" << endreq;
242
243 int id_cntr = 5;
249 p = new GenParticle(CLHEP::HepLorentzVector(px,py,pz,eph), 22, 1);
250 p->suggest_barcode(id_cntr);
251 prod_vtx->add_particle_out(p);
252 id_cntr++;
253 }
254
255 log << MSG::DEBUG << "check point 6" << endreq;
256 if (!unw){
257 p =
new GenParticle(CLHEP::HepLorentzVector(0,0,0,
weights_.sdif), 99, 1);
258 p->suggest_barcode(id_cntr);
259 prod_vtx->add_particle_out(p);
260 id_cntr++;
261 }
262
263 if( log.level() <= MSG::DEBUG ){
264 evt->print();
265 }
266
267
268 SmartDataPtr<McGenEventCol> anMcCol(eventSvc(), "/Event/Gen");
269 if (anMcCol!=0){
270
271 log<<MSG::WARNING<<"add event"<<endreq;
272 MsgStream log(messageService(), name());
273 log << MSG::INFO << "Add McGenEvent to existing collection" << endreq;
274 McGenEvent* mcEvent = new McGenEvent(evt);
275 anMcCol->push_back(mcEvent);
276 } else {
277
278 log<<MSG::WARNING<<"create collection"<<endreq;
280 McGenEvent* mcEvent = new McGenEvent(evt);
281 mcColl->push_back(mcEvent);
282 StatusCode sc = eventSvc()->registerObject("/Event/Gen",mcColl);
283 if (sc != StatusCode::SUCCESS) {
284 log << MSG::ERROR << "Could not register McGenEvent" << endreq;
285 delete mcColl;
286 delete evt;
287 delete mcEvent;
288 return StatusCode::FAILURE;
289 } else {
290 log << MSG::INFO << "McGenEventCol created!" << endreq;
291 }
292 }
293
294
295 log<<MSG::DEBUG<< "before execute() return"<<endreq;
296 return StatusCode::SUCCESS;
297
298}
struct @363256214333150134303037351143026113364271126245 momentainitial_
void generate_event_(bool &use_unweighted)
struct @057027206004162011053321026341137365177113276162 event_mom_
struct @026173277112124265060176162144124214021335260256 weights_
struct @012127344050317246235203007042135233025124047270 babayagainitint_
ObjectVector< McGenEvent > McGenEventCol
double double double * p4