CMS 3D CMS Logo

Functions
parseHBHEPhase1AlgoDescription.cc File Reference
#include <cassert>
#include "RecoLocalCalo/HcalRecAlgos/interface/parseHBHEPhase1AlgoDescription.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "RecoLocalCalo/HcalRecAlgos/interface/PulseShapeFitOOTPileupCorrection.h"
#include "RecoLocalCalo/HcalRecAlgos/interface/HcalDeterministicFit.h"
#include "RecoLocalCalo/HcalRecAlgos/interface/SimpleHBHEPhase1Algo.h"

Go to the source code of this file.

Functions

edm::ParameterSetDescription fillDescriptionForParseHBHEPhase1Algo ()
 
static std::unique_ptr< MahiFitparseHBHEMahiDescription (const edm::ParameterSet &conf)
 
static std::unique_ptr< PulseShapeFitOOTPileupCorrectionparseHBHEMethod2Description (const edm::ParameterSet &conf)
 
static std::unique_ptr< HcalDeterministicFitparseHBHEMethod3Description (const edm::ParameterSet &conf)
 
std::unique_ptr< AbsHBHEPhase1AlgoparseHBHEPhase1AlgoDescription (const edm::ParameterSet &ps)
 

Function Documentation

◆ fillDescriptionForParseHBHEPhase1Algo()

edm::ParameterSetDescription fillDescriptionForParseHBHEPhase1Algo ( )

Definition at line 144 of file parseHBHEPhase1AlgoDescription.cc.

144  {
146 
147  desc.setAllowAnything();
148  desc.add<std::string>("Class", "SimpleHBHEPhase1Algo");
149  desc.add<bool>("useM2", false);
150  desc.add<bool>("useM3", true);
151  desc.add<bool>("useMahi", true);
152  desc.add<int>("firstSampleShift", 0);
153  desc.add<int>("samplesToAdd", 2);
154  desc.add<double>("correctionPhaseNS", 6.0);
155  desc.add<double>("tdcTimeShift", 0.0);
156  desc.add<bool>("correctForPhaseContainment", true);
157  desc.add<bool>("applyLegacyHBMCorrection", true);
158  desc.add<bool>("calculateArrivalTime", false);
159 
160  return desc;
161 }

References edm::ParameterSetDescription::add(), edm::ParameterSetDescription::setAllowAnything(), and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by HBHEPhase1Reconstructor::fillDescriptions().

◆ parseHBHEMahiDescription()

static std::unique_ptr<MahiFit> parseHBHEMahiDescription ( const edm::ParameterSet conf)
static

Definition at line 13 of file parseHBHEPhase1AlgoDescription.cc.

13  {
14  const bool iDynamicPed = conf.getParameter<bool>("dynamicPed");
15  const double iTS4Thresh = conf.getParameter<double>("ts4Thresh");
16  const double chiSqSwitch = conf.getParameter<double>("chiSqSwitch");
17 
18  const bool iApplyTimeSlew = conf.getParameter<bool>("applyTimeSlew");
19 
20  const bool iCalculateArrivalTime = conf.getParameter<bool>("calculateArrivalTime");
21  const double iMeanTime = conf.getParameter<double>("meanTime");
22  const double iTimeSigmaHPD = conf.getParameter<double>("timeSigmaHPD");
23  const double iTimeSigmaSiPM = conf.getParameter<double>("timeSigmaSiPM");
24 
25  const std::vector<int> iActiveBXs = conf.getParameter<std::vector<int>>("activeBXs");
26  const int iNMaxItersMin = conf.getParameter<int>("nMaxItersMin");
27  const int iNMaxItersNNLS = conf.getParameter<int>("nMaxItersNNLS");
28  const double iDeltaChiSqThresh = conf.getParameter<double>("deltaChiSqThresh");
29  const double iNnlsThresh = conf.getParameter<double>("nnlsThresh");
30 
31  std::unique_ptr<MahiFit> corr = std::make_unique<MahiFit>();
32 
33  corr->setParameters(iDynamicPed,
34  iTS4Thresh,
36  iApplyTimeSlew,
38  iCalculateArrivalTime,
39  iMeanTime,
40  iTimeSigmaHPD,
41  iTimeSigmaSiPM,
42  iActiveBXs,
43  iNMaxItersMin,
44  iNMaxItersNNLS,
45  iDeltaChiSqThresh,
46  iNnlsThresh);
47 
48  return corr;
49 }

References HLT_2018_cff::chiSqSwitch, alignCSCRings::corr, edm::ParameterSet::getParameter(), and HcalTimeSlew::Medium.

Referenced by parseHBHEPhase1AlgoDescription().

◆ parseHBHEMethod2Description()

static std::unique_ptr<PulseShapeFitOOTPileupCorrection> parseHBHEMethod2Description ( const edm::ParameterSet conf)
static

Definition at line 51 of file parseHBHEPhase1AlgoDescription.cc.

51  {
52  const bool iPedestalConstraint = conf.getParameter<bool>("applyPedConstraint");
53  const bool iTimeConstraint = conf.getParameter<bool>("applyTimeConstraint");
54  const bool iAddPulseJitter = conf.getParameter<bool>("applyPulseJitter");
55  const bool iApplyTimeSlew = conf.getParameter<bool>("applyTimeSlew");
56  const double iTS4Min = conf.getParameter<double>("ts4Min");
57  const std::vector<double> iTS4Max = conf.getParameter<std::vector<double>>("ts4Max");
58  const double iPulseJitter = conf.getParameter<double>("pulseJitter");
59  const double iTimeMean = conf.getParameter<double>("meanTime");
60  const double iTimeSigHPD = conf.getParameter<double>("timeSigmaHPD");
61  const double iTimeSigSiPM = conf.getParameter<double>("timeSigmaSiPM");
62  const double iPedMean = conf.getParameter<double>("meanPed");
63  const double iTMin = conf.getParameter<double>("timeMin");
64  const double iTMax = conf.getParameter<double>("timeMax");
65  const std::vector<double> its4Chi2 = conf.getParameter<std::vector<double>>("ts4chi2");
66  const int iFitTimes = conf.getParameter<int>("fitTimes");
67 
68  if (iTimeConstraint)
69  assert(iTimeSigHPD);
70  if (iTimeConstraint)
71  assert(iTimeSigSiPM);
72 
73  std::unique_ptr<PulseShapeFitOOTPileupCorrection> corr = std::make_unique<PulseShapeFitOOTPileupCorrection>();
74 
75  corr->setPUParams(iPedestalConstraint,
76  iTimeConstraint,
77  iAddPulseJitter,
78  iApplyTimeSlew,
79  iTS4Min,
80  iTS4Max,
81  iPulseJitter,
82  iTimeMean,
83  iTimeSigHPD,
84  iTimeSigSiPM,
85  iPedMean,
86  iTMin,
87  iTMax,
88  its4Chi2,
90  iFitTimes);
91 
92  return corr;
93 }

References cms::cuda::assert(), alignCSCRings::corr, edm::ParameterSet::getParameter(), and HcalTimeSlew::Medium.

Referenced by parseHBHEPhase1AlgoDescription().

◆ parseHBHEMethod3Description()

static std::unique_ptr<HcalDeterministicFit> parseHBHEMethod3Description ( const edm::ParameterSet conf)
static

Definition at line 95 of file parseHBHEPhase1AlgoDescription.cc.

95  {
96  const bool iApplyTimeSlew = conf.getParameter<bool>("applyTimeSlewM3");
97  const int iTimeSlewParsType = conf.getParameter<int>("timeSlewParsType");
98  const double irespCorrM3 = conf.getParameter<double>("respCorrM3");
99 
100  std::unique_ptr<HcalDeterministicFit> fit = std::make_unique<HcalDeterministicFit>();
101 
102  fit->init((HcalTimeSlew::ParaSource)iTimeSlewParsType, HcalTimeSlew::Medium, iApplyTimeSlew, irespCorrM3);
103 
104  return fit;
105 }

References L1TowerCalibrationProducer_cfi::fit, edm::ParameterSet::getParameter(), and HcalTimeSlew::Medium.

Referenced by parseHBHEPhase1AlgoDescription().

◆ parseHBHEPhase1AlgoDescription()

std::unique_ptr<AbsHBHEPhase1Algo> parseHBHEPhase1AlgoDescription ( const edm::ParameterSet ps)

Definition at line 107 of file parseHBHEPhase1AlgoDescription.cc.

107  {
108  std::unique_ptr<AbsHBHEPhase1Algo> algo;
109 
110  const std::string& className = ps.getParameter<std::string>("Class");
111 
112  if (className == "SimpleHBHEPhase1Algo") {
113  std::unique_ptr<MahiFit> mahi;
114  std::unique_ptr<PulseShapeFitOOTPileupCorrection> m2;
115  std::unique_ptr<HcalDeterministicFit> detFit;
116 
117  // only run Mahi OR Method 2 but not both
118  if (ps.getParameter<bool>("useMahi") && ps.getParameter<bool>("useM2")) {
119  throw cms::Exception("ConfigurationError")
120  << "SimpleHBHEPhase1Algo does not allow both Mahi and Method 2 to be turned on together.";
121  }
122  if (ps.getParameter<bool>("useMahi"))
123  mahi = parseHBHEMahiDescription(ps);
124  if (ps.getParameter<bool>("useM2"))
126  if (ps.getParameter<bool>("useM3"))
127  detFit = parseHBHEMethod3Description(ps);
128 
129  algo =
130  std::unique_ptr<AbsHBHEPhase1Algo>(new SimpleHBHEPhase1Algo(ps.getParameter<int>("firstSampleShift"),
131  ps.getParameter<int>("samplesToAdd"),
132  ps.getParameter<double>("correctionPhaseNS"),
133  ps.getParameter<double>("tdcTimeShift"),
134  ps.getParameter<bool>("correctForPhaseContainment"),
135  ps.getParameter<bool>("applyLegacyHBMCorrection"),
136  std::move(m2),
137  std::move(detFit),
138  std::move(mahi)));
139  }
140 
141  return algo;
142 }

References className(), Exception, edm::ParameterSet::getParameter(), eostools::move(), parseHBHEMahiDescription(), parseHBHEMethod2Description(), parseHBHEMethod3Description(), and AlCaHLTBitMon_QueryRunRegistry::string.

parseHBHEMethod3Description
static std::unique_ptr< HcalDeterministicFit > parseHBHEMethod3Description(const edm::ParameterSet &conf)
Definition: parseHBHEPhase1AlgoDescription.cc:95
HLT_2018_cff.chiSqSwitch
chiSqSwitch
Definition: HLT_2018_cff.py:7102
edm::ParameterSetDescription::add
ParameterDescriptionBase * add(U const &iLabel, T const &value)
Definition: ParameterSetDescription.h:95
HcalTimeSlew::ParaSource
ParaSource
Definition: HcalTimeSlew.h:70
HcalTimeSlew::Medium
Definition: HcalTimeSlew.h:71
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
cms::cuda::assert
assert(be >=bs)
L1TowerCalibrationProducer_cfi.fit
fit
Definition: L1TowerCalibrationProducer_cfi.py:36
cmsdt::algo
algo
Definition: constants.h:164
SimpleHBHEPhase1Algo
Definition: SimpleHBHEPhase1Algo.h:18
alignCSCRings.corr
dictionary corr
Definition: alignCSCRings.py:124
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
parseHBHEMethod2Description
static std::unique_ptr< PulseShapeFitOOTPileupCorrection > parseHBHEMethod2Description(const edm::ParameterSet &conf)
Definition: parseHBHEPhase1AlgoDescription.cc:51
edm::ParameterSetDescription::setAllowAnything
void setAllowAnything()
allow any parameter label/value pairs
Definition: ParameterSetDescription.cc:37
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
eostools.move
def move(src, dest)
Definition: eostools.py:511
parseHBHEMahiDescription
static std::unique_ptr< MahiFit > parseHBHEMahiDescription(const edm::ParameterSet &conf)
Definition: parseHBHEPhase1AlgoDescription.cc:13
Exception
Definition: hltDiff.cc:246
className
std::string className(const T &t)
Definition: ClassName.h:31
fit
Definition: CombinedChiSquaredLikelihood.h:6