CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Private Member Functions | Private Attributes
CTPPSDirectProtonSimulationValidator Class Reference
Inheritance diagram for CTPPSDirectProtonSimulationValidator:
edm::one::EDAnalyzer<> edm::one::EDAnalyzerBase edm::EDConsumerBase

Classes

struct  RPPlots
 

Public Member Functions

 CTPPSDirectProtonSimulationValidator (const edm::ParameterSet &)
 
- Public Member Functions inherited from edm::one::EDAnalyzer<>
 EDAnalyzer ()=default
 
 EDAnalyzer (const EDAnalyzer &)=delete
 
SerialTaskQueueglobalLuminosityBlocksQueue () final
 
SerialTaskQueueglobalRunsQueue () final
 
const EDAnalyzeroperator= (const EDAnalyzer &)=delete
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
bool wantsInputProcessBlocks () const final
 
bool wantsProcessBlocks () const final
 
- Public Member Functions inherited from edm::one::EDAnalyzerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzerBase ()
 
ModuleDescription const & moduleDescription () const
 
bool wantsStreamLuminosityBlocks () const
 
bool wantsStreamRuns () const
 
 ~EDAnalyzerBase () override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () 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
 
ESResolverIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
std::vector< ESResolverIndex > 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
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, 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::ESRecordsToProductResolverIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Private Member Functions

void analyze (const edm::Event &, const edm::EventSetup &) override
 
void beginJob () override
 
void endJob () override
 

Private Attributes

std::string outputFile_
 
edm::EDGetTokenT< CTPPSLocalTrackLiteCollectionrecoTracksToken_
 
std::map< unsigned int, RPPlotsrpPlots_
 
edm::EDGetTokenT< CTPPSLocalTrackLiteCollectionsimuTracksToken_
 

Additional Inherited Members

- Public Types inherited from edm::one::EDAnalyzerBase
typedef EDAnalyzerBase ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::one::EDAnalyzerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
template<BranchType B = InEvent>
EDConsumerBaseAdaptor< Bconsumes (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 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 ()
 
template<Transition Tr = Transition::Event>
auto esConsumes (ESInputTag tag)
 
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)
 

Detailed Description

Definition at line 30 of file CTPPSDirectProtonSimulationValidator.cc.

Constructor & Destructor Documentation

◆ CTPPSDirectProtonSimulationValidator()

CTPPSDirectProtonSimulationValidator::CTPPSDirectProtonSimulationValidator ( const edm::ParameterSet iConfig)
explicit

Definition at line 75 of file CTPPSDirectProtonSimulationValidator.cc.

76  : simuTracksToken_(consumes<CTPPSLocalTrackLiteCollection>(iConfig.getParameter<edm::InputTag>("simuTracksTag"))),
77  recoTracksToken_(consumes<CTPPSLocalTrackLiteCollection>(iConfig.getParameter<edm::InputTag>("recoTracksTag"))),
78  outputFile_(iConfig.getParameter<std::string>("outputFile")) {}
T getParameter(std::string const &) const
Definition: ParameterSet.h:307
edm::EDGetTokenT< CTPPSLocalTrackLiteCollection > recoTracksToken_
edm::EDGetTokenT< CTPPSLocalTrackLiteCollection > simuTracksToken_

Member Function Documentation

◆ analyze()

void CTPPSDirectProtonSimulationValidator::analyze ( const edm::Event iEvent,
const edm::EventSetup  
)
overrideprivatevirtual

Implements edm::one::EDAnalyzerBase.

Definition at line 82 of file CTPPSDirectProtonSimulationValidator.cc.

References CTPPSDetId::arm(), iEvent, recoTracksToken_, rpPlots_, and simuTracksToken_.

82  {
83  // get input
85  iEvent.getByToken(simuTracksToken_, simuTracks);
86 
88  iEvent.getByToken(recoTracksToken_, recoTracks);
89 
90  // process tracks
91  for (const auto& simuTrack : *simuTracks) {
92  const CTPPSDetId rpId(simuTrack.rpId());
93  for (const auto& recoTrack : *recoTracks) {
94  if (simuTrack.rpId() == recoTrack.rpId()) {
95  unsigned int rpDecId = rpId.arm() * 100 + rpId.station() * 10 + rpId.rp();
96  rpPlots_[rpDecId].fill(simuTrack.x(), simuTrack.y(), recoTrack.x(), recoTrack.y());
97  }
98  }
99  }
100 }
uint32_t arm() const
Definition: CTPPSDetId.h:57
int iEvent
Definition: GenABIO.cc:224
edm::EDGetTokenT< CTPPSLocalTrackLiteCollection > recoTracksToken_
edm::EDGetTokenT< CTPPSLocalTrackLiteCollection > simuTracksToken_
Base class for CTPPS detector IDs.
Definition: CTPPSDetId.h:32

◆ beginJob()

void CTPPSDirectProtonSimulationValidator::beginJob ( void  )
inlineoverrideprivatevirtual

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 35 of file CTPPSDirectProtonSimulationValidator.cc.

35 {}

◆ endJob()

void CTPPSDirectProtonSimulationValidator::endJob ( void  )
overrideprivatevirtual

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 104 of file CTPPSDirectProtonSimulationValidator.cc.

References ALPAKA_ACCELERATOR_NAMESPACE::vertexFinder::it, outputFile_, and rpPlots_.

104  {
105  auto f_out = std::make_unique<TFile>(outputFile_.c_str(), "recreate");
106 
107  for (const auto& it : rpPlots_) {
108  gDirectory = f_out->mkdir(Form("RP %u", it.first));
109  it.second.write();
110  }
111 }

Member Data Documentation

◆ outputFile_

std::string CTPPSDirectProtonSimulationValidator::outputFile_
private

Definition at line 42 of file CTPPSDirectProtonSimulationValidator.cc.

Referenced by endJob().

◆ recoTracksToken_

edm::EDGetTokenT<CTPPSLocalTrackLiteCollection> CTPPSDirectProtonSimulationValidator::recoTracksToken_
private

Definition at line 40 of file CTPPSDirectProtonSimulationValidator.cc.

Referenced by analyze().

◆ rpPlots_

std::map<unsigned int, RPPlots> CTPPSDirectProtonSimulationValidator::rpPlots_
private

Definition at line 70 of file CTPPSDirectProtonSimulationValidator.cc.

Referenced by analyze(), and endJob().

◆ simuTracksToken_

edm::EDGetTokenT<CTPPSLocalTrackLiteCollection> CTPPSDirectProtonSimulationValidator::simuTracksToken_
private

Definition at line 39 of file CTPPSDirectProtonSimulationValidator.cc.

Referenced by analyze().