#include "Pythia.h"
#include "HepMCInterface.h"
#include "Generate.h"
#include "HepMCEvent.H"
#include "Setup.H"
#include "Photos/Photos.h"
#include "Photos/PhotosHepMCEvent.h"
#include "Photos/Log.h"
Go to the source code of this file.
      
        
          | void checkMomentumConservationInEvent | ( | HepMC::GenEvent * | evt | ) |  | 
      
 
Definition at line 35 of file photos_pythia_example.cxx.
References m, p, and pz.
   39         double px=0.0,py=0.0,
pz=0.0,e=0.0;
 
   41         for ( HepMC::GenEvent::particle_const_iterator 
p = 
evt->particles_begin();
 
   42               p != 
evt->particles_end(); ++
p )
 
   44                 if( (*p)->status() == 1 )
 
   46                         HepMC::FourVector 
m = (*p)->momentum();
 
   55   cout.setf(ios_base::floatfield);
 
   56         cout<<endl<<
"Vector Sum: "<<px<<
" "<<py<<
" "<<
pz<<
" "<<e<<endl;
 
 
 
 
      
        
          | int main | ( | int | argc, | 
        
          |  |  | char ** | argv | 
        
          |  | ) |  |  | 
      
 
Definition at line 145 of file photos_pythia_example.cxx.
References checkMomentumConservationInEvent(), EventsToCheck, evt, chigen::initialize(), NumberOfEvents, Photospp::PhotosEvent::process(), and chigen::pythia::pythia.
  148         HepMC::I_Pythia8 ToHepMC;
 
  150         Event& 
event = pythia.event;
 
  153         pythia.readString(
"PartonLevel:ISR = on");
 
  154         pythia.readString(
"PartonLevel:FSR = off");
 
  156         pythia.readString(
"WeakSingleBoson:ffbar2gmZ = on");
 
  157         pythia.readString(
"23:onMode = off");
 
  158         pythia.readString(
"23:onIfAny = 13");
 
  159         pythia.init( 11, -11, 91.187);                           
 
  167         Photos::setInfraredCutOff(0.01/91.187); 
 
  168         Photos::maxWtInterference(3.0);
 
  172         Log::SummaryAtExit();
 
  173         cout.setf(ios::fixed);
 
  178                 if(iEvent%1000==0) Log::Info()<<
"Event: "<<iEvent<<
"\t("<<iEvent*(100./
NumberOfEvents)<<
"%)"<<endl;
 
  179                 if (!pythia.next()) 
continue;
 
  182                 HepMC::GenEvent * HepMCEvt = 
new HepMC::GenEvent();
 
  183                 ToHepMC.fill_next_event(event, HepMCEvt);
 
  189                         cout<<
"Momentum conservation chceck BEFORE/AFTER Photos"<<endl;
 
  211                 HepMCEvent temp_event(*HepMCEvt,
false);
 
  212                 MC_Analyze(&temp_event);
 
  215                 if(iEvent>=NumberOfEvents-5) HepMCEvt->print();
 
void checkMomentumConservationInEvent(PhotosHEPEVTEvent *evt)
 
 
 
      
        
          | void switch_history_entries_status | ( | HepMC::GenEvent * | evt | ) |  | 
      
 
Definition at line 75 of file photos_pythia_example.cxx.
References exit(), p, p2, and v.
   77   for ( HepMC::GenEvent::particle_const_iterator 
p = 
evt->particles_begin();
 
   78               p != 
evt->particles_end(); ++
p )
 
   82       if((*p)->pdg_id()==22) 
continue;
 
   84       int barcode = (*p)->barcode();
 
   86       HepMC::GenVertex *
v = (*p)->production_vertex();
 
   91       int last_photon_position = -1;
 
   93       for(HepMC::GenVertex::particles_out_const_iterator 
p2 = v->particles_out_const_begin();
 
   94           p2 != v->particles_out_const_end(); ++
p2)
 
   98         if((*p2)->barcode()==barcode) 
break;
 
  100         if((*p2)->pdg_id()==22) { last_photon_position=position; }
 
  104       if(last_photon_position<0) 
continue;
 
  106       position -= last_photon_position;
 
  107       HepMC::GenParticle *part = NULL;
 
  110       for(HepMC::GenVertex::particles_out_const_iterator 
p2 = v->particles_out_const_begin();
 
  111           p2 != v->particles_out_const_end(); ++
p2)
 
  115         if     (position >  0) 
continue;
 
  116         else if(position == 0) part = *
p2;
 
  120           if((*p2)->pdg_id()==22 ) (*p2)->set_status(3);
 
  128       if( part->pdg_id() != (*p)->pdg_id())
 
  130         cout<<
"switch_history_entries_status: mismatch in pdg_id of history entry"<<endl;
 
  131         cout<<
"and its corresponding particle. The algorithm does not work correctly."<<endl;
 
  136       if(part->status()!=1) 
continue;
 
 
 
 
      
        
          | unsigned int EventsToCheck =20 | 
      
 
 
      
        
          | unsigned long NumberOfEvents = 10000 |