CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
TtHadLRJetCombObservables.cc
Go to the documentation of this file.
1 // $Id: TtHadLRJetCombObservables.cc,v 1.2 2008/02/17 11:27:55 rwolf Exp $
2 
4 
5 // constructor with path; default should not be used
7 {
8 }
9 
11 {
12 }
13 
15 {
16  jetCombVarVal.clear();
17 
18  //observable 1 : pt(had top)
19  //Calculate the average pt for all possible combinations of light jets with the two b-jets
20  double AverageTop =((sol.getHadb().p4()+sol.getHadq().p4()+sol.getHadp().p4()).pt()+
21  (sol.getHadbbar().p4()+sol.getHadq().p4()+sol.getHadp().p4()).pt()+
22  (sol.getHadb().p4()+sol.getHadbbar().p4()+sol.getHadp().p4()).pt()+
23  (sol.getHadb().p4()+sol.getHadbbar().p4()+sol.getHadq().p4()).pt()+
24  (sol.getHadb().p4()+sol.getHadk().p4()+sol.getHadj().p4()).pt()+
25  (sol.getHadbbar().p4()+sol.getHadk().p4()+sol.getHadj().p4()).pt()+
26  (sol.getHadb().p4()+sol.getHadbbar().p4()+sol.getHadj().p4()).pt()+
27  (sol.getHadb().p4()+sol.getHadbbar().p4()+sol.getHadk().p4()).pt()+
28  (sol.getHadb().p4()+sol.getHadq().p4()+sol.getHadj().p4()).pt()+
29  (sol.getHadb().p4()+sol.getHadq().p4()+sol.getHadk().p4()).pt()+
30  (sol.getHadbbar().p4()+sol.getHadq().p4()+sol.getHadj().p4()).pt()+
31  (sol.getHadbbar().p4()+sol.getHadq().p4()+sol.getHadk().p4()).pt())/12.;
32 
33  double Obs1 = ((sol.getHadb().p4()+sol.getHadq().p4()+sol.getHadp().p4()+sol.getHadbbar().p4()+sol.getHadk().p4()+sol.getHadj().p4()).pt())/AverageTop;
34  jetCombVarVal.push_back(std::pair<unsigned int,double>(1,Obs1));
35 
36  //observable 2 : (pt_b1 + pt_b2)/(sum jetpt)
37  double obs2 = (sol.getHadb().pt()+sol.getHadbbar().pt())/(sol.getHadp().pt()+sol.getHadq().pt()+sol.getHadj().pt()+sol.getHadk().pt());
38  jetCombVarVal.push_back(std::pair<unsigned int,double>(2,obs2));
39 
40  //observable 3 and 4: delta R between had b and had W and delta R between had bbar and had W
41  double Obs3 = ROOT::Math::VectorUtil::DeltaR( sol.getHadb().p4(),(sol.getHadq().p4()+sol.getHadp().p4()) );
42  jetCombVarVal.push_back(std::pair<unsigned int,double>(3,Obs3));
43 
44  double Obs4 = ROOT::Math::VectorUtil::DeltaR( sol.getHadbbar().p4(),(sol.getHadk().p4()+sol.getHadj().p4()) );
45  jetCombVarVal.push_back(std::pair<unsigned int,double>(4,Obs4));
46 
47  //observalbe 5 and 6: delta R between light quarks pq and jk
48  double Obs5 = ROOT::Math::VectorUtil::DeltaR( sol.getHadq().p4(),sol.getHadp().p4() );
49  jetCombVarVal.push_back(std::pair<unsigned int,double>(5,Obs5));
50 
51  double Obs6 = ROOT::Math::VectorUtil::DeltaR( sol.getHadk().p4(),sol.getHadj().p4() );
52  jetCombVarVal.push_back(std::pair<unsigned int,double>(6,Obs6));
53 
54  //observable 7: b-tagging information
55  double Obs7 = 0;
56  if ( fabs(sol.getHadb().bDiscriminator("trackCountingJetTags") +10) < 0.0001 || fabs(sol.getHadbbar().bDiscriminator("trackCountingJetTags") +10)< 0.0001 ){
57  Obs7 = -10.;
58  } else {
59  Obs7 = (sol.getHadb().bDiscriminator("trackCountingJetTags")+sol.getHadbbar().bDiscriminator("trackCountingJetTags"));
60  }
61  jetCombVarVal.push_back(std::pair<unsigned int,double>(7,Obs7));
62 
63  //observable 8 : chi2 value of kinematical fit with W-mass constraint
64  double Obs8 =0;
65  if(sol.getProbChi2() <0){
66  Obs8 = -0;
67  } else {
68  Obs8 = log10(sol.getProbChi2()+.00001);
69  }
70  jetCombVarVal.push_back(std::pair<unsigned int,double>(8,Obs8));
71 
73 }
virtual const LorentzVector & p4() const GCC11_FINAL
four-momentum Lorentz vector
pat::Jet getHadbbar() const
pat::Jet getHadb() const
pat::Jet getHadq() const
pat::Jet getHadj() const
void setLRJetCombObservables(const std::vector< std::pair< unsigned int, double > > &varval)
std::vector< std::pair< unsigned int, double > > jetCombVarVal
double getProbChi2() const
float bDiscriminator(const std::string &theLabel) const
-— methods for accessing b-tagging info -—
Definition: Jet.cc:308
pat::Jet getHadp() const
pat::Jet getHadk() const
void operator()(TtHadEvtSolution &)
virtual float pt() const GCC11_FINAL
transverse momentum