forked from h2gglobe/h2gglobe
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathKFactorSmearer.cc
98 lines (73 loc) · 3.39 KB
/
KFactorSmearer.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include "KFactorSmearer.h"
#include "PhotonReducedInfo.h"
#include "TRandom3.h"
#include <assert.h>
KFactorSmearer::KFactorSmearer(const std::string & theFile, Normalization_8TeV* norm, unsigned int dId , unsigned int uId ) :
norm_(norm), efficiency_file(theFile) , downId(dId), upId(uId)
{
name_="KFactorSmearer";
}
KFactorSmearer::~KFactorSmearer()
{
}
void KFactorSmearer::readMassPoint(int mass, int uId, int dId ){
kFactorSmearers_[mass] = std::vector<TH1*>(3,(TH1*)0);
TH1* temp = (TH1D*) theKFactorFile_->Get( Form("kfact%d_0",mass) );
assert(temp!=0); kFactorSmearers_[mass][0]=(TH1D*) temp->Clone(Form("Hmass%d",mass)); kFactorSmearers_[mass][0]->SetDirectory(0);
temp = (TH1D*) theKFactorFile_->Get( Form("kfact%d_%d",mass,uId) );
assert(temp!=0); kFactorSmearers_[mass][1]=(TH1D*) temp->Clone(Form("Hmass%_up",mass)); kFactorSmearers_[mass][1]->SetDirectory(0);
temp = (TH1D*) theKFactorFile_->Get( Form("kfact%d_%d",mass,dId) );
assert(temp!=0); kFactorSmearers_[mass][2]=(TH1D*) temp->Clone(Form("Hmass%_down",mass)); kFactorSmearers_[mass][2]->SetDirectory(0);
}
bool KFactorSmearer::smearEvent( float & weight, const TLorentzVector & p4, const int nPu, const int sample_type, float syst_shift ) const
{
int genMassPoint;
if( sample_type >= 0 ) { return true; }
genMassPoint = std::round(norm_->GetMass(sample_type));
if( norm_->GetProcess(sample_type) != "ggh" ) {
return true;
}
if( genMassPoint > 150 ) { genMassPoint=150; } // Warning: missing k-factor
if( genMassPoint == 100 ) { genMassPoint=105; } // Warning: missing k-factor
assert( genMassPoint % 5 == 0 );
double kWeight = getWeight( p4, nPu, genMassPoint, syst_shift );
weight = (kWeight > 0) ? kWeight : 0;
return true;
}
bool KFactorSmearer::init()
{
cout << name_ << " - Opening KFactor file"<<endl;
theKFactorFile_ = TFile::Open( efficiency_file.c_str() );
assert(theKFactorFile_!=0);
readMassPoint(105, upId, downId);
readMassPoint(110, upId, downId);
readMassPoint(115, upId, downId);
readMassPoint(120, upId, downId);
readMassPoint(121, upId, downId);
readMassPoint(123, upId, downId);
readMassPoint(125, upId, downId);
readMassPoint(130, upId, downId);
readMassPoint(135, upId, downId);
readMassPoint(140, upId, downId);
readMassPoint(145, upId, downId);
readMassPoint(150, upId, downId);
theKFactorFile_->Close();
return true;
}
double KFactorSmearer::getKFactor(int genMassPoint, int id, double gPT ) const {
if(genMassPoint==105 || genMassPoint==110 || genMassPoint==115 || genMassPoint==120 || genMassPoint==125 || genMassPoint==130 || genMassPoint==135 || genMassPoint==140 || genMassPoint==145 ||genMassPoint==150 ||genMassPoint==121 ||genMassPoint==123 ) {
const TH1* tmp = kFactorSmearers_.find(genMassPoint)->second[id];
return tmp->GetBinContent(tmp->FindFixBin(gPT));
}
assert(0); return 0.;
}
double KFactorSmearer::getWeight( const TLorentzVector & p4, const int nPu, const int & genMassPoint, float syst_shift) const
{
float gPT = p4.Pt();
// this is consistent with samples available on Tue Jun 21 18:10:03 CEST 2011
// bins are very fine, therefore interpolation between bins can be neglegted for now
int varId = syst_shift > 0 ? 1 : 2;
double nominal = getKFactor( genMassPoint, 0, gPT );
double variation = getKFactor( genMassPoint, varId, gPT );
return ( nominal + (variation-nominal) * fabs(syst_shift) );
}