diff --git a/HGCalAnalysis/interface/AObData.h b/HGCalAnalysis/interface/AObData.h index c2eb61e87a553..939e1bce08dee 100644 --- a/HGCalAnalysis/interface/AObData.h +++ b/HGCalAnalysis/interface/AObData.h @@ -8,12 +8,13 @@ class AGenPart : public TObject { public: - AGenPart(): eta(-1000.),phi(-1000.),pt(-1000.),energy(-1000.),dvx(0.),dvy(0.),dvz(0.),pid(0),gen(-1),reachedEE(-1) + AGenPart(): eta(-1000.),phi(-1000.),pt(-1000.),energy(-1000.),dvx(0.),dvy(0.),dvz(0.),fbrem(-1.),pid(0),gen(-1),reachedEE(-1) { } AGenPart(float i_eta, float i_phi, float i_pt, float i_energy, - float i_dvx, float i_dvy,float i_dvz, int i_pid,int i_gen=-1,int i_reachedEE=-1, bool i_fromBeamPipe=true) : - eta(i_eta),phi(i_phi),pt(i_pt),energy(i_energy),dvx(i_dvx),dvy(i_dvy),dvz(i_dvz),pid(i_pid),gen(i_gen),reachedEE(i_reachedEE),fromBeamPipe(i_fromBeamPipe) + float i_dvx, float i_dvy,float i_dvz, float i_fbrem, int i_pid,int i_gen=-1,int i_reachedEE=-1, bool i_fromBeamPipe=true) : + eta(i_eta),phi(i_phi),pt(i_pt),energy(i_energy),dvx(i_dvx),dvy(i_dvy),dvz(i_dvz),fbrem(i_fbrem), pid(i_pid),gen(i_gen),reachedEE(i_reachedEE), +fromBeamPipe(i_fromBeamPipe) { } @@ -30,6 +31,7 @@ class AGenPart : public TObject float dvx; float dvy; float dvz; + float fbrem; int pid; int gen; int reachedEE; diff --git a/HGCalAnalysis/plugins/HGCalAnalysis.cc b/HGCalAnalysis/plugins/HGCalAnalysis.cc index 0ece3c5eafd31..8c4494f2dfcf8 100644 --- a/HGCalAnalysis/plugins/HGCalAnalysis.cc +++ b/HGCalAnalysis/plugins/HGCalAnalysis.cc @@ -345,11 +345,12 @@ HGCalAnalysis::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) math::XYZTLorentzVectorD vtx(0,0,0,0); int reachedEE=0; // compute the extrapolations for the particles reaching EE and for the gen particles + double fbrem=-1.; if (myTrack.noEndVertex() || myTrack.genpartIndex()>=0) { RawParticle part(myTrack.momentum(),myTrack.vertex().position()); - part.setID(myTrack.id()); + part.setID(myTrack.type()); BaseParticlePropagator myPropag(part,160,layerPositions[0],3.8); myPropag.propagate(); unsigned result=myPropag.getSuccess(); @@ -359,6 +360,12 @@ HGCalAnalysis::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) if (myTrack.noEndVertex()) { if (result==2 && vtx.Rho()> 25) { reachedEE=2; + double dpt=0; + + for(int i=0;ipush_back(part); }