CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Static Public Attributes
GetLumi Class Reference

#include <GetLumi.h>

Public Types

enum  SQRT_S { SQRT_S_7TeV, SQRT_S_8TeV, SQRT_S_13TeV }
 

Public Member Functions

double convert2PU (double, double)
 
double convert2PU (double, int)
 
 GetLumi (const edm::ParameterSet &)
 
 GetLumi (const edm::InputTag &, double)
 
 GetLumi (const edm::ParameterSet &, edm::ConsumesCollector &iC)
 
 GetLumi (const edm::InputTag &, double, edm::ConsumesCollector &iC)
 
double getRawValue (const edm::Event &)
 
double getRawValue (edm::LuminosityBlock const &, edm::EventSetup const &)
 
double getValue (const edm::Event &)
 
double getValue (edm::LuminosityBlock const &, edm::EventSetup const &)
 
virtual ~GetLumi ()
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 

Public Attributes

edm::EDGetTokenT< LumiDetailslumiDetailsToken_
 
edm::InputTag lumiInputTag_
 
double lumiScale_
 
edm::EDGetTokenT< LumiSummarylumiSummaryToken_
 

Static Public Attributes

static double CM2_TO_NANOBARN = 1.0 / 1.e-33
 
static double FREQ_ORBIT = 11246.
 
static double INELASTIC_XSEC_13TeV = 71.3
 
static double INELASTIC_XSEC_7TeV = 68.0
 
static double INELASTIC_XSEC_8TeV = 69.3
 
static const unsigned int lastBunchCrossing = 3564
 
static const unsigned int NUM_BX = 3564
 
static double rXSEC_PIXEL_CLUSTER = 9.4e-24
 
static double rXSEC_PIXEL_CLUSTER_UNC = 0.119e-24
 
static double SECONDS_PER_LS = double(0x40000) / double(FREQ_ORBIT)
 
static double XSEC_PIXEL_CLUSTER = 10.08e-24
 
static double XSEC_PIXEL_CLUSTER_UNC = 0.17e-24
 

Detailed Description

Definition at line 21 of file GetLumi.h.

Member Enumeration Documentation

Enumerator
SQRT_S_7TeV 
SQRT_S_8TeV 
SQRT_S_13TeV 

Definition at line 23 of file GetLumi.h.

Constructor & Destructor Documentation

GetLumi::GetLumi ( const edm::ParameterSet iConfig)

Definition at line 14 of file GetLumi.cc.

15  : lumiInputTag_(iConfig.getParameter<edm::InputTag>("lumi")),
16  lumiScale_(iConfig.getParameter<double>("lumiScale")) {}
T getParameter(std::string const &) const
edm::InputTag lumiInputTag_
Definition: GetLumi.h:62
double lumiScale_
Definition: GetLumi.h:63
GetLumi::GetLumi ( const edm::InputTag lumiInputTag,
double  lumiScale 
)

Definition at line 18 of file GetLumi.cc.

19  : lumiInputTag_(lumiInputTag), lumiScale_(lumiScale) {}
edm::InputTag lumiInputTag_
Definition: GetLumi.h:62
double lumiScale_
Definition: GetLumi.h:63
GetLumi::GetLumi ( const edm::ParameterSet iConfig,
edm::ConsumesCollector iC 
)

Definition at line 21 of file GetLumi.cc.

References edm::ConsumesCollector::consumes(), edm::InLumi, lumiDetailsToken_, lumiInputTag_, and lumiSummaryToken_.

21  : GetLumi(iConfig) {
24 }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
edm::EDGetTokenT< LumiDetails > lumiDetailsToken_
Definition: GetLumi.h:65
edm::EDGetTokenT< LumiSummary > lumiSummaryToken_
Definition: GetLumi.h:66
GetLumi(const edm::ParameterSet &)
Definition: GetLumi.cc:14
edm::InputTag lumiInputTag_
Definition: GetLumi.h:62
GetLumi::GetLumi ( const edm::InputTag lumiInputTag,
double  lumiScale,
edm::ConsumesCollector iC 
)

Definition at line 26 of file GetLumi.cc.

References edm::ConsumesCollector::consumes(), edm::InLumi, lumiDetailsToken_, lumiInputTag_, and lumiSummaryToken_.

27  : GetLumi(lumiInputTag, lumiScale) {
30 }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
edm::EDGetTokenT< LumiDetails > lumiDetailsToken_
Definition: GetLumi.h:65
edm::EDGetTokenT< LumiSummary > lumiSummaryToken_
Definition: GetLumi.h:66
GetLumi(const edm::ParameterSet &)
Definition: GetLumi.cc:14
edm::InputTag lumiInputTag_
Definition: GetLumi.h:62
GetLumi::~GetLumi ( )
virtual

Definition at line 32 of file GetLumi.cc.

32 {}

Member Function Documentation

double GetLumi::convert2PU ( double  instLumi,
double  inelastic_xSec = GetLumi::INELASTIC_XSEC_8TeV 
)

Definition at line 78 of file GetLumi.cc.

References FREQ_ORBIT.

Referenced by convert2PU().

80 {
81  // from https://cmswbm.web.cern.ch/cmswbm/images/pileup.png
82  return instLumi * inelastic_xSec / FREQ_ORBIT;
83 }
static double FREQ_ORBIT
Definition: GetLumi.h:26
double GetLumi::convert2PU ( double  instLumi,
int  sqrt_s = GetLumi::SQRT_S_8TeV 
)

Definition at line 85 of file GetLumi.cc.

References convert2PU(), INELASTIC_XSEC_7TeV, INELASTIC_XSEC_8TeV, SQRT_S_7TeV, and SQRT_S_8TeV.

85  {
86  double inelastic_xSec = 0.;
87 
88  switch (sqrt_s) {
90  inelastic_xSec = GetLumi::INELASTIC_XSEC_7TeV;
91  break;
93  inelastic_xSec = GetLumi::INELASTIC_XSEC_8TeV;
94  break;
95  default:
96  break;
97  }
98 
99  return convert2PU(instLumi, inelastic_xSec);
100 }
static double INELASTIC_XSEC_8TeV
Definition: GetLumi.h:30
static double INELASTIC_XSEC_7TeV
Definition: GetLumi.h:29
double convert2PU(double, double)
Definition: GetLumi.cc:78
static void GetLumi::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static
double GetLumi::getRawValue ( const edm::Event iEvent)

Definition at line 34 of file GetLumi.cc.

References edm::EventBase::bunchCrossing(), edm::LuminosityBlock::getByToken(), edm::Event::getLuminosityBlock(), LumiDetails::isValid(), LumiDetails::kOCC1, BXlumiParameters_cfi::lumi, lumiSummaryToken_, and LumiDetails::lumiValue().

Referenced by getValue().

34  {
35  // taken from
36  // DPGAnalysis/SiStripTools/src/DigiLumiCorrHistogramMaker.cc
37  // the scale factor 6.37 should follow the lumi prescriptions
40 
41  double bxlumi = -1.;
42  if (lumi->isValid()) {
43  bxlumi = lumi->lumiValue(LumiDetails::kOCC1, iEvent.bunchCrossing());
44  }
45 
46  return bxlumi;
47 }
bool getByToken(EDGetToken token, Handle< PROD > &result) const
bool isValid() const
Definition: LumiDetails.cc:44
int bunchCrossing() const
Definition: EventBase.h:64
float lumiValue(AlgoType algo, unsigned int bx) const
Definition: LumiDetails.cc:72
edm::EDGetTokenT< LumiSummary > lumiSummaryToken_
Definition: GetLumi.h:66
LuminosityBlock const & getLuminosityBlock() const
Definition: Event.h:98
double GetLumi::getRawValue ( edm::LuminosityBlock const &  lumiBlock,
edm::EventSetup const &  eSetup 
)

Definition at line 54 of file GetLumi.cc.

References LumiSummary::avgInsDelLumi(), gather_cfg::cout, edm::LuminosityBlock::getByToken(), LumiSummary::intgDelLumi(), LumiSummary::isValid(), BXlumiParameters_cfi::lumi, and lumiSummaryToken_.

54  {
55  double lumi = -1.;
56  double intDelLumi = -1.;
57 
58  // size_t LS = lumiBlock.luminosityBlockAuxiliary().luminosityBlock();
59  // accumulate HF data at every LS as it is closed.
60  // note: lumi unit from DIPLumiSummary and Detail is microbarns
61  edm::Handle<LumiSummary> lumiSummary_;
62  lumiBlock.getByToken(lumiSummaryToken_, lumiSummary_);
63  if (lumiSummary_->isValid()) {
64  lumi = lumiSummary_->avgInsDelLumi();
65  intDelLumi = lumiSummary_->intgDelLumi();
66  std::cout << "Luminosity in this Lumi Section " << lumi << " --> " << intDelLumi << std::endl;
67  } else {
68  std::cout << "No valid data found!" << std::endl;
69  }
70 
71  return lumi;
72 }
float intgDelLumi() const
Definition: LumiSummary.cc:16
edm::EDGetTokenT< LumiSummary > lumiSummaryToken_
Definition: GetLumi.h:66
float avgInsDelLumi() const
Definition: LumiSummary.cc:8
bool isValid() const
Definition: LumiSummary.cc:50
double GetLumi::getValue ( const edm::Event iEvent)

Definition at line 49 of file GetLumi.cc.

References getRawValue(), and lumiScale_.

Referenced by VertexMonitor::analyze(), LogMessageMonitor::analyze(), and TrackingMonitor::analyze().

49  {
50  // bxlumi = lumi->lumiValue(LumiDetails::kOCC1,iEvent.bunchCrossing())*6.37;
51  return getRawValue(iEvent) * lumiScale_;
52 }
double getRawValue(const edm::Event &)
Definition: GetLumi.cc:34
double lumiScale_
Definition: GetLumi.h:63
double GetLumi::getValue ( edm::LuminosityBlock const &  lumiBlock,
edm::EventSetup const &  eSetup 
)

Definition at line 74 of file GetLumi.cc.

References getRawValue(), and lumiScale_.

74  {
75  return getRawValue(lumiBlock, eSetup) * lumiScale_;
76 }
double getRawValue(const edm::Event &)
Definition: GetLumi.cc:34
double lumiScale_
Definition: GetLumi.h:63

Member Data Documentation

double GetLumi::CM2_TO_NANOBARN = 1.0 / 1.e-33
static

Definition at line 42 of file GetLumi.h.

Referenced by LumiMonitor::dqmAnalyze(), and TrackAnalyzer::setLumi().

double GetLumi::FREQ_ORBIT = 11246.
static

Definition at line 26 of file GetLumi.h.

Referenced by convert2PU(), LumiMonitor::LumiMonitor(), and TrackAnalyzer::TrackAnalyzer().

double GetLumi::INELASTIC_XSEC_13TeV = 71.3
static

Definition at line 32 of file GetLumi.h.

double GetLumi::INELASTIC_XSEC_7TeV = 68.0
static

Definition at line 29 of file GetLumi.h.

Referenced by convert2PU().

double GetLumi::INELASTIC_XSEC_8TeV = 69.3
static

Definition at line 30 of file GetLumi.h.

Referenced by convert2PU().

const unsigned int GetLumi::lastBunchCrossing = 3564
static

Definition at line 43 of file GetLumi.h.

Referenced by TrackAnalyzer::bookHistosForEfficiencyFromHitPatter().

edm::EDGetTokenT<LumiDetails> GetLumi::lumiDetailsToken_

Definition at line 65 of file GetLumi.h.

Referenced by GetLumi().

edm::InputTag GetLumi::lumiInputTag_

Definition at line 62 of file GetLumi.h.

Referenced by GetLumi().

double GetLumi::lumiScale_

Definition at line 63 of file GetLumi.h.

Referenced by getValue().

edm::EDGetTokenT<LumiSummary> GetLumi::lumiSummaryToken_

Definition at line 66 of file GetLumi.h.

Referenced by GetLumi(), and getRawValue().

const unsigned int GetLumi::NUM_BX = 3564
static

Definition at line 25 of file GetLumi.h.

double GetLumi::rXSEC_PIXEL_CLUSTER = 9.4e-24
static

Definition at line 40 of file GetLumi.h.

Referenced by LumiMonitor::LumiMonitor(), and TrackAnalyzer::TrackAnalyzer().

double GetLumi::rXSEC_PIXEL_CLUSTER_UNC = 0.119e-24
static

Definition at line 41 of file GetLumi.h.

double GetLumi::SECONDS_PER_LS = double(0x40000) / double(FREQ_ORBIT)
static

Definition at line 27 of file GetLumi.h.

Referenced by LumiMonitor::LumiMonitor(), and TrackAnalyzer::TrackAnalyzer().

double GetLumi::XSEC_PIXEL_CLUSTER = 10.08e-24
static

Definition at line 36 of file GetLumi.h.

Referenced by LumiMonitor::LumiMonitor(), and TrackAnalyzer::TrackAnalyzer().

double GetLumi::XSEC_PIXEL_CLUSTER_UNC = 0.17e-24
static

Definition at line 37 of file GetLumi.h.