src
CalibCalorimetry
HcalAlgos
src
HcalSiPMRadiationDamage.cc
Go to the documentation of this file.
1
#include "
CalibCalorimetry/HcalAlgos/interface/HcalSiPMRadiationDamage.h
"
2
3
#include <vector>
4
#include <cmath>
5
6
//default constructor
7
HcalSiPMRadiationDamage::HcalSiPMRadiationDamage
()
8
: temperatureBase_(0.0), temperatureNew_(0.0), intlumiOffset_(0.0), depVsTemp_(0.0), intlumiToNeutrons_(0.0) {}
9
10
HcalSiPMRadiationDamage::HcalSiPMRadiationDamage
(std::vector<double> darkCurrentBase,
const
edm::ParameterSet
&
p
)
11
: darkCurrentBase_(darkCurrentBase),
12
temperatureBase_(
p
.getParameter<double>(
"temperatureBase"
)),
13
temperatureNew_(
p
.getParameter<double>(
"temperatureNew"
)),
14
intlumiOffset_(
p
.getParameter<double>(
"intlumiOffset"
)),
15
depVsTemp_(
p
.getParameter<double>(
"depVsTemp"
)),
16
intlumiToNeutrons_(
p
.getParameter<double>(
"intlumiToNeutrons"
)),
17
depVsNeutrons_(
p
.getParameter<
std
::
vector
<double>>(
"depVsNeutrons"
)) {}
18
19
//accounts for both lumi dependence and temp dependence
20
double
HcalSiPMRadiationDamage::getDarkCurrent
(
double
intlumi
,
unsigned
index
)
const
{
21
intlumi
-=
intlumiOffset_
;
22
if
(
intlumi
<= 0)
23
return
darkCurrentBase_
.at(
index
);
24
double
darkCurrentNewLumi =
darkCurrentBase_
.at(
index
) +
depVsNeutrons_
.at(
index
) * (
intlumi
*
intlumiToNeutrons_
);
25
double
darkCurrentNewTemp = darkCurrentNewLumi *
std::exp
(
depVsTemp_
* (
temperatureNew_
-
temperatureBase_
));
26
return
darkCurrentNewTemp;
27
}
HcalSiPMRadiationDamage::getDarkCurrent
double getDarkCurrent(double intlumi, unsigned index) const
Definition:
HcalSiPMRadiationDamage.cc:20
std
Definition:
JetResolutionObject.h:76
submitPVValidationJobs.intlumi
intlumi
Definition:
submitPVValidationJobs.py:383
HcalSiPMRadiationDamage::HcalSiPMRadiationDamage
HcalSiPMRadiationDamage()
Definition:
HcalSiPMRadiationDamage.cc:7
AlignmentPI::index
index
Definition:
AlignmentPayloadInspectorHelper.h:46
HcalSiPMRadiationDamage::temperatureNew_
double temperatureNew_
Definition:
HcalSiPMRadiationDamage.h:27
HcalSiPMRadiationDamage::depVsTemp_
double depVsTemp_
Definition:
HcalSiPMRadiationDamage.h:29
HcalSiPMRadiationDamage::intlumiOffset_
double intlumiOffset_
Definition:
HcalSiPMRadiationDamage.h:28
HcalSiPMRadiationDamage::depVsNeutrons_
std::vector< double > depVsNeutrons_
Definition:
HcalSiPMRadiationDamage.h:31
HcalSiPMRadiationDamage::temperatureBase_
double temperatureBase_
Definition:
HcalSiPMRadiationDamage.h:26
HcalSiPMRadiationDamage::darkCurrentBase_
std::vector< double > darkCurrentBase_
Definition:
HcalSiPMRadiationDamage.h:25
HcalSiPMRadiationDamage::intlumiToNeutrons_
double intlumiToNeutrons_
Definition:
HcalSiPMRadiationDamage.h:30
trackerHitRTTI::vector
Definition:
trackerHitRTTI.h:21
edm::ParameterSet
Definition:
ParameterSet.h:47
JetChargeProducer_cfi.exp
exp
Definition:
JetChargeProducer_cfi.py:6
AlCaHLTBitMon_ParallelJobs.p
def p
Definition:
AlCaHLTBitMon_ParallelJobs.py:153
HcalSiPMRadiationDamage.h
Generated for CMSSW Reference Manual by
1.8.14