|
void | analyze (const edm::Event &e, const edm::EventSetup &c) override |
|
void | beginJob () override |
|
void | endJob () override |
|
| HcalTB06Analysis (const edm::ParameterSet &p) |
|
| HcalTB06Analysis (const HcalTB06Analysis &)=delete |
|
const HcalTB06Analysis & | operator= (const HcalTB06Analysis &)=delete |
|
| ~HcalTB06Analysis () override |
|
| EDAnalyzer ()=default |
|
| EDAnalyzer (const EDAnalyzer &)=delete |
|
SerialTaskQueue * | globalLuminosityBlocksQueue () final |
|
SerialTaskQueue * | globalRunsQueue () final |
|
const EDAnalyzer & | operator= (const EDAnalyzer &)=delete |
|
bool | wantsGlobalLuminosityBlocks () const final |
|
bool | wantsGlobalRuns () const final |
|
bool | wantsInputProcessBlocks () const final |
|
bool | wantsProcessBlocks () const final |
|
void | callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func) |
|
| EDAnalyzerBase () |
|
ModuleDescription const & | moduleDescription () const |
|
bool | wantsStreamLuminosityBlocks () const |
|
bool | wantsStreamRuns () const |
|
| ~EDAnalyzerBase () override |
|
std::vector< ConsumesInfo > | consumesInfo () const |
|
void | convertCurrentProcessAlias (std::string const &processName) |
| Convert "@currentProcess" in InputTag process names to the actual current process name. More...
|
|
| EDConsumerBase () |
|
| EDConsumerBase (EDConsumerBase const &)=delete |
|
| EDConsumerBase (EDConsumerBase &&)=default |
|
ESProxyIndex const * | esGetTokenIndices (edm::Transition iTrans) const |
|
std::vector< ESProxyIndex > const & | esGetTokenIndicesVector (edm::Transition iTrans) const |
|
std::vector< ESRecordIndex >
const & | esGetTokenRecordIndicesVector (edm::Transition iTrans) const |
|
ProductResolverIndexAndSkipBit | indexFrom (EDGetToken, BranchType, TypeID const &) const |
|
void | itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const |
|
void | itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const |
|
std::vector
< ProductResolverIndexAndSkipBit >
const & | itemsToGetFrom (BranchType iType) const |
|
void | labelsForToken (EDGetToken iToken, Labels &oLabels) const |
|
void | modulesWhoseProductsAreConsumed (std::array< std::vector< ModuleDescription const * > *, NumBranchTypes > &modulesAll, std::vector< ModuleProcessName > &modulesInPreviousProcesses, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const |
|
EDConsumerBase const & | operator= (EDConsumerBase const &)=delete |
|
EDConsumerBase & | operator= (EDConsumerBase &&)=default |
|
bool | registeredToConsume (ProductResolverIndex, bool, BranchType) const |
|
bool | registeredToConsumeMany (TypeID const &, BranchType) const |
|
void | selectInputProcessBlocks (ProductRegistry const &productRegistry, ProcessBlockHelperBase const &processBlockHelperBase) |
|
ProductResolverIndexAndSkipBit | uncheckedIndexFrom (EDGetToken) const |
|
void | updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet) |
|
void | updateLookup (eventsetup::ESRecordsToProxyIndices const &) |
|
virtual | ~EDConsumerBase () noexcept(false) |
|
|
typedef EDAnalyzerBase | ModuleType |
|
typedef ProductLabels | Labels |
|
static const std::string & | baseType () |
|
static void | fillDescriptions (ConfigurationDescriptions &descriptions) |
|
static void | prevalidate (ConfigurationDescriptions &descriptions) |
|
template<typename ProductType , BranchType B = InEvent> |
EDGetTokenT< ProductType > | consumes (edm::InputTag const &tag) |
|
template<BranchType B = InEvent> |
EDConsumerBaseAdaptor< B > | consumes (edm::InputTag tag) noexcept |
|
EDGetToken | consumes (const TypeToGet &id, edm::InputTag const &tag) |
|
template<BranchType B> |
EDGetToken | consumes (TypeToGet const &id, edm::InputTag const &tag) |
|
ConsumesCollector | consumesCollector () |
| Use a ConsumesCollector to gather consumes information from helper functions. More...
|
|
template<typename ProductType , BranchType B = InEvent> |
void | consumesMany () |
|
void | consumesMany (const TypeToGet &id) |
|
template<BranchType B> |
void | consumesMany (const TypeToGet &id) |
|
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event> |
auto | esConsumes () |
|
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event> |
auto | esConsumes (ESInputTag const &tag) |
|
template<Transition Tr = Transition::Event> |
constexpr auto | esConsumes () noexcept |
|
template<Transition Tr = Transition::Event> |
auto | esConsumes (ESInputTag tag) noexcept |
|
template<Transition Tr = Transition::Event> |
ESGetTokenGeneric | esConsumes (eventsetup::EventSetupRecordKey const &iRecord, eventsetup::DataKey const &iKey) |
| Used with EventSetupRecord::doGet. More...
|
|
template<typename ProductType , BranchType B = InEvent> |
EDGetTokenT< ProductType > | mayConsume (edm::InputTag const &tag) |
|
EDGetToken | mayConsume (const TypeToGet &id, edm::InputTag const &tag) |
|
template<BranchType B> |
EDGetToken | mayConsume (const TypeToGet &id, edm::InputTag const &tag) |
|
void | resetItemsToGetFrom (BranchType iType) |
|
Definition at line 54 of file HcalTB06Analysis.cc.
Definition at line 91 of file HcalTB06Analysis.cc.
References edm::ParameterSet::getParameter(), HLT_FULL_cff::InputTag, m_BeamToken, m_ECAL, m_EcalToken, m_ener, m_eta, m_factEcal, m_factHcal, m_HcalToken, m_histo, m_idxetaEcal, m_idxetaHcal, m_idxphiEcal, m_idxphiHcal, m_PDG, m_phi, m_timeLimit, m_widthEcal, m_widthHcal, maxEta, HLT_FULL_cff::maxPhi, and HLT_FULL_cff::minPhi.
92 usesResource(
"TFileService");
109 double beamEta = (maxEta + minEta) * 0.5;
110 double beamPhi = (maxPhi +
minPhi) * 0.5;
132 edm::LogInfo(
"HcalTB06Analysis") <<
"Beam parameters: E(GeV)= " << m_ener <<
" pdgID= " << m_PDG[0]
133 <<
"\n eta= " << m_eta <<
" idx_etaEcal= " <<
m_idxetaEcal
134 <<
" idx_etaHcal= " <<
m_idxetaHcal <<
" phi= " << m_phi
136 <<
"\n EcalFactor= " << m_factEcal <<
" EcalWidth= " << m_widthEcal <<
" GeV"
137 <<
"\n HcalFactor= " << m_factHcal <<
" HcalWidth= " << m_widthHcal <<
" GeV"
138 <<
" MIP= " << eMIP <<
" GeV"
139 <<
"\n TimeLimit= " << m_timeLimit <<
" ns"
edm::EDGetTokenT< edm::PCaloHitContainer > m_BeamToken
edm::EDGetTokenT< edm::PCaloHitContainer > m_HcalToken
Log< level::Info, false > LogInfo
T getParameter(std::string const &) const
edm::EDGetTokenT< edm::PCaloHitContainer > m_EcalToken
Implements edm::one::EDAnalyzerBase.
Definition at line 152 of file HcalTB06Analysis.cc.
References funct::abs(), count, HcalTB06Histo::fillEdep(), HcalTB06Histo::fillPrimary(), HcalTB06Histo::fillTree(), edm::Event::getByToken(), HcalOuter, mps_fire::i, EBDetId::ieta(), HcalDetId::ieta(), EBDetId::iphi(), HcalDetId::iphi(), m_BeamToken, m_ECAL, m_EcalToken, m_ener, m_eta, m_factEcal, m_factHcal, m_HcalToken, m_histo, m_idxetaEcal, m_idxetaHcal, m_idxphiEcal, m_idxphiHcal, m_phi, m_timeLimit, m_widthEcal, m_widthHcal, cms::cuda::nh, edm::Handle< T >::product(), HcalDetId::subdet(), and HcalTestBeamNumbering::unpackIndex().
161 std::vector<double> eCalo(6, 0), eTrig(7, 0);
163 const std::vector<PCaloHit>* EcalHits =
nullptr;
169 const std::vector<PCaloHit>* HcalHits = Hcal.
product();
171 const std::vector<PCaloHit>* BeamHits = Beam.
product();
180 ne = EcalHits->size();
181 for (
unsigned int i = 0;
i < ne; ++
i) {
182 EBDetId ecalid((*EcalHits)[
i].
id());
185 << ecalid.iphi() <<
":" <<
m_idxphiEcal <<
" " << (*EcalHits)[
i].time() <<
":"
191 eCalo[0] += (*EcalHits)[
i].energy();
200 nh = HcalHits->size();
201 for (
unsigned int i = 0;
i <
nh; ++
i) {
204 edm::LogVerbatim(
"HcalTBSim") <<
"HC " <<
i <<
" " << hcalid.subdet() <<
" " << hcalid.ieta() <<
":"
206 << (*HcalHits)[
i].time() <<
":" <<
m_timeLimit <<
" " << (*HcalHits)[
i].energy();
212 eCalo[2] += (*HcalHits)[
i].energy();
214 eCalo[4] += (*HcalHits)[
i].energy();
224 double etots = eecals + ehcals;
226 edm::LogInfo(
"HcalTBSim") <<
"HcalTB06Analysis:: Etot(MeV)= " << etots <<
" E(Ecal)= " << eecals
227 <<
" E(Hcal)= " << ehcals <<
" Nhits(ECAL)= " << ne <<
" Nhits(HCAL)= " <<
nh;
231 for (
unsigned int i = 0;
i < BeamHits->size(); ++
i) {
232 unsigned int id = ((*BeamHits)[
i].id());
233 int det, lay, ix, iy;
235 if ((det == 1) && ((*BeamHits)[
i].time() <
m_timeLimit)) {
236 if (lay > 0 && lay <= 4) {
237 eTrig[lay - 1] += (*BeamHits)[
i].energy();
238 }
else if (lay == 7 || lay == 8) {
239 eTrig[lay - 2] += (*BeamHits)[
i].energy();
240 }
else if (lay >= 11 && lay <= 14) {
241 eTrig[4] += (*BeamHits)[
i].energy();
247 edm::LogInfo(
"HcalTBSim") <<
"HcalTB06Analysis:: Trigger Info: " << eTrig[0] <<
":" << eTrig[1] <<
":" << eTrig[2]
248 <<
":" << eTrig[3] <<
":" << eTrig[4] <<
":" << eTrig[5] <<
":" << eTrig[6];
Log< level::Info, true > LogVerbatim
edm::EDGetTokenT< edm::PCaloHitContainer > m_BeamToken
void fillEdep(double etots, double eecals, double ehcals)
void fillTree(std::vector< double > &ecalo, std::vector< double > &etrig)
edm::EDGetTokenT< edm::PCaloHitContainer > m_HcalToken
Abs< T >::type abs(const T &t)
Log< level::Info, false > LogInfo
T const * product() const
static void unpackIndex(const uint32_t &idx, int &det, int &lay, int &x, int &y)
void fillPrimary(double energy, double eta, double phi)
edm::EDGetTokenT< edm::PCaloHitContainer > m_EcalToken