CMS 3D CMS Logo

SoftElectronMVAEstimator.cc
Go to the documentation of this file.
7 
9 {
10  //Check number of weight files given
11  if (ExpectedNBins != cfg_.vweightsfiles.size() ) {
12  edm::LogError ("Soft Electron MVA Error") <<
13  "Expected Number of bins = " << ExpectedNBins <<
14  " does not equal to weightsfiles.size() = " <<
15  cfg_.vweightsfiles.size() << std::endl;
16  }
17 
18  for(auto& weightsfile : cfg_.vweightsfiles) {
19  // Taken from Daniele (his mail from the 30/11)
20  // training of the 7/12 with Nvtx added
21  gbr_.push_back(createGBRForest( weightsfile ));
22  }
23 }
24 
25 
27 { }
28 
30  const reco::VertexCollection& pvc) const {
31  float vars[25];
32 
33  vars[0] = myElectron.fbrem();// fbrem
34  vars[1] = myElectron.eSuperClusterOverP(); //EtotOvePin
35  vars[2] = myElectron.eEleClusterOverPout(); //eleEoPout
36 
37  float etot = myElectron.eSuperClusterOverP()*myElectron.trackMomentumAtVtx().R();
38  float eEcal = myElectron.eEleClusterOverPout()*myElectron.trackMomentumAtEleClus().R();
39  float dP = myElectron.trackMomentumAtVtx().R()-myElectron.trackMomentumAtEleClus().R();
40  vars[3] = (etot-eEcal)/dP; //EBremOverDeltaP
41  vars[4] = std::log(myElectron.sigmaEtaEta()); //logSigmaEtaEta
42  vars[5] = myElectron.deltaEtaEleClusterTrackAtCalo(); //DeltaEtaTrackEcalSeed
43  vars[6] = myElectron.hcalOverEcalBc(); //HoE
44 
45  bool validKF= false;
46  reco::TrackRef myTrackRef = myElectron.closestCtfTrackRef();
47  validKF = (myTrackRef.isAvailable() && myTrackRef.isNonnull());
48  vars[7] = myElectron.gsfTrack()->normalizedChi2(); //gsfchi2
49  vars[8] = (validKF) ? myTrackRef->normalizedChi2() : 0 ; //kfchi2
50  vars[9] = (validKF) ? myTrackRef->hitPattern().trackerLayersWithMeasurement() : -1. ; //kfhits
51 
52  vars[10] = myElectron.gsfTrack().get()->ptModeError()/myElectron.gsfTrack().get()->ptMode() ; //SigmaPtOverPt
53  vars[11] = myElectron.deltaEtaSuperClusterTrackAtVtx(); //deta
54  vars[12] = myElectron.deltaPhiSuperClusterTrackAtVtx(); //dphi
55  vars[13] = myElectron.deltaEtaSeedClusterTrackAtCalo(); //detacalo
56  vars[14] = myElectron.sigmaIetaIeta(); //see
57  vars[15] = myElectron.sigmaIphiIphi(); //spp
58  vars[16] = myElectron.r9(); //R9
59  vars[17] = myElectron.superCluster()->etaWidth(); //etawidth
60  vars[18] = myElectron.superCluster()->phiWidth(); //phiwidth
61  vars[19] = (myElectron.e5x5()) !=0. ? 1.-(myElectron.e1x5()/myElectron.e5x5()) : -1. ; //OneMinusE1x5E5x5
62  vars[20] = (1.0/myElectron.ecalEnergy()) - (1.0 / myElectron.p()); // IoEmIoP
63  vars[21] = myElectron.superCluster()->preshowerEnergy() / myElectron.superCluster()->rawEnergy(); //PreShowerOverRaw
64  vars[22] = pvc.size(); // nPV
65  vars[23] = myElectron.pt(); //pt
66  vars[24] = myElectron.eta(); //eta
67 
68 /*
69  std::cout<<"fbrem "<<fbrem<<std::endl;
70  std::cout<<"EtotOvePin "<<EtotOvePin<<std::endl;
71  std::cout<<"eleEoPout "<<eleEoPout<<std::endl;
72  std::cout<<"EBremOverDeltaP "<<EBremOverDeltaP<<std::endl;
73  std::cout<<"logSigmaEtaEta "<<logSigmaEtaEta<<std::endl;
74  std::cout<<"DeltaEtaTrackEcalSeed "<<DeltaEtaTrackEcalSeed<<std::endl;
75  std::cout<<"HoE "<<HoE<<std::endl;
76  std::cout<<"kfchi2 "<<kfchi2<<std::endl;
77  std::cout<<"kfhits "<<kfhits<<std::endl;
78  std::cout<<"gsfchi2 "<<gsfchi2<<std::endl;
79  std::cout<<"SigmaPtOverPt "<<SigmaPtOverPt<<std::endl;
80  std::cout<<"deta "<<deta<<std::endl;
81  std::cout<<"dphi "<<dphi<<std::endl;
82  std::cout<<"detacalo "<<detacalo<<std::endl;
83  std::cout<<"see "<<see<<std::endl;
84  std::cout<< "spp " << spp<< std::endl;
85  std::cout<< "R9 " << R9<< std::endl;
86  std::cout<< "IoEmIoP " << IoEmIoP<< std::endl;
87  std::cout<<"etawidth "<<etawidth<<std::endl;
88  std::cout<<"phiwidth "<<phiwidth<<std::endl;
89  std::cout<<"OneMinusE1x5E5x5 "<<OneMinusE1x5E5x5<<std::endl;
90  std::cout<<"PreShowerOverRaw "<<PreShowerOverRaw<<std::endl;
91 */
92  bindVariables(vars);
93 
94  double result= gbr_[0]->GetClassifier(vars);
95 
96  return result;
97 }
98 
99 
100 void SoftElectronMVAEstimator::bindVariables(float vars[25]) const {
101  if( vars[0] < -1.) //fbrem
102  vars[0] = -1.;
103 
104  vars[11] = std::abs(vars[11]); // deta
105  if(vars[11] > 0.06)
106  vars[11] = 0.06;
107 
108  vars[12] = std::abs(vars[12]);
109  if(vars[12] > 0.6)
110  vars[12] = 0.6;
111 
112  //if(EoP > 20.)
113  // EoP = 20.;
114 
115  if(vars[2] > 20.) //eleEoPout
116  vars[2] = 20.;
117 
118  vars[13] = std::abs(vars[13]); //detacalo
119  if(vars[13] > 0.2)
120  vars[13] = 0.2;
121 
122  if( vars[19] < -1.) //OneMinusE1x5E5x5
123  vars[19] = -1;
124 
125  if( vars[19] > 2.) //OneMinusE1x5E5x5
126  vars[19] = 2.;
127 
128  if( vars[7] > 200.) //gsfchi2
129  vars[7] = 200;
130 
131  if( vars[8] > 10.) //kfchi2
132  vars[8] = 10.;
133 
134 }
float sigmaIphiIphi() const
Definition: GsfElectron.h:437
bool isAvailable() const
Definition: Ref.h:577
GsfTrackRef gsfTrack() const override
reference to a GsfTrack
Definition: GsfElectron.h:185
virtual TrackRef closestCtfTrackRef() const
Definition: GsfElectron.h:201
bool isNonnull() const
Checks for non-null.
Definition: Ref.h:253
double eta() const final
momentum pseudorapidity
float eSuperClusterOverP() const
Definition: GsfElectron.h:245
SoftElectronMVAEstimator(const Configuration &)
math::XYZVectorF trackMomentumAtVtx() const
Definition: GsfElectron.h:291
double pt() const final
transverse momentum
std::vector< Vertex > VertexCollection
collection of Vertex objects
Definition: VertexFwd.h:9
float fbrem() const
Definition: GsfElectron.h:761
float deltaEtaSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:249
float sigmaIetaIeta() const
Definition: GsfElectron.h:436
float deltaPhiSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:252
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
float eEleClusterOverPout() const
Definition: GsfElectron.h:248
T const * get() const
Returns C++ pointer to the item.
Definition: Ref.h:245
float hcalOverEcalBc() const
Definition: GsfElectron.h:448
double mva(const reco::GsfElectron &myElectron, const reco::VertexCollection &) const
std::vector< std::unique_ptr< const GBRForest > > gbr_
double p() const final
magnitude of momentum vector
float deltaEtaEleClusterTrackAtCalo() const
Definition: GsfElectron.h:251
float e1x5() const
Definition: GsfElectron.h:438
void bindVariables(float vars[25]) const
float ecalEnergy() const
Definition: GsfElectron.h:848
math::XYZVectorF trackMomentumAtEleClus() const
Definition: GsfElectron.h:294
float e5x5() const
Definition: GsfElectron.h:440
float r9() const
Definition: GsfElectron.h:441
float deltaEtaSeedClusterTrackAtCalo() const
Definition: GsfElectron.h:250
SuperClusterRef superCluster() const override
reference to a SuperCluster
Definition: GsfElectron.h:184
std::unique_ptr< const GBRForest > createGBRForest(const std::string &weightsFile)
float sigmaEtaEta() const
Definition: GsfElectron.h:435