CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Attributes
CombinedHitTripletGenerator Class Reference

#include <CombinedHitTripletGenerator.h>

Inheritance diagram for CombinedHitTripletGenerator:
HitTripletGenerator OrderedHitsGenerator

Public Types

typedef LayerHitMapCache LayerCacheType
 

Public Member Functions

 CombinedHitTripletGenerator (const edm::ParameterSet &cfg, edm::ConsumesCollector &iC)
 
void hitTriplets (const TrackingRegion &reg, OrderedHitTriplets &triplets, const edm::Event &ev, const edm::EventSetup &es) override
 from base class More...
 
 ~CombinedHitTripletGenerator () override
 
- Public Member Functions inherited from HitTripletGenerator
void clear () final
 
 HitTripletGenerator (HitTripletGenerator const &other)
 
 HitTripletGenerator (unsigned int size=500)
 
virtual void hitTriplets (const TrackingRegion &reg, OrderedHitTriplets &prs, const edm::EventSetup &es)
 
const OrderedHitTripletsrun (const TrackingRegion &region, const edm::Event &ev, const edm::EventSetup &es) final
 
 ~HitTripletGenerator () override
 
- Public Member Functions inherited from OrderedHitsGenerator
 OrderedHitsGenerator ()
 
virtual ~OrderedHitsGenerator ()
 

Private Attributes

std::unique_ptr< HitTripletGeneratorFromPairAndLayerstheGenerator
 
LayerCacheType theLayerCache
 
edm::EDGetTokenT< SeedingLayerSetsHitstheSeedingLayerToken
 

Additional Inherited Members

- Public Attributes inherited from OrderedHitsGenerator
unsigned int theMaxElement
 

Detailed Description

Definition at line 30 of file CombinedHitTripletGenerator.h.

Member Typedef Documentation

◆ LayerCacheType

Definition at line 32 of file CombinedHitTripletGenerator.h.

Constructor & Destructor Documentation

◆ CombinedHitTripletGenerator()

CombinedHitTripletGenerator::CombinedHitTripletGenerator ( const edm::ParameterSet cfg,
edm::ConsumesCollector iC 
)

Definition at line 11 of file CombinedHitTripletGenerator.cc.

12  : theSeedingLayerToken(iC.consumes<SeedingLayerSetsHits>(cfg.getParameter<edm::InputTag>("SeedingLayers"))) {
13  edm::ParameterSet generatorPSet = cfg.getParameter<edm::ParameterSet>("GeneratorPSet");
14  std::string generatorName = generatorPSet.getParameter<std::string>("ComponentName");
15  theGenerator = HitTripletGeneratorFromPairAndLayersFactory::get()->create(generatorName, generatorPSet, iC);
16  theGenerator->init(std::make_unique<HitPairGeneratorFromLayerPair>(0, 1, &theLayerCache), &theLayerCache);
17 }

References looper::cfg, get, edm::ParameterSet::getParameter(), AlCaHLTBitMon_QueryRunRegistry::string, theGenerator, and theLayerCache.

◆ ~CombinedHitTripletGenerator()

CombinedHitTripletGenerator::~CombinedHitTripletGenerator ( )
override

Definition at line 19 of file CombinedHitTripletGenerator.cc.

19 {}

Member Function Documentation

◆ hitTriplets()

void CombinedHitTripletGenerator::hitTriplets ( const TrackingRegion reg,
OrderedHitTriplets triplets,
const edm::Event ev,
const edm::EventSetup es 
)
overridevirtual

from base class

Implements HitTripletGenerator.

Definition at line 21 of file CombinedHitTripletGenerator.cc.

24  {
26  ev.getByToken(theSeedingLayerToken, hlayers);
27  const SeedingLayerSetsHits& layers = *hlayers;
28  if (layers.numberOfLayersInSet() != 3)
29  throw cms::Exception("Configuration")
30  << "CombinedHitTripletGenerator expects SeedingLayerSetsHits::numberOfLayersInSet() to be 3, got "
31  << layers.numberOfLayersInSet();
32 
33  std::vector<LayerTriplets::LayerSetAndLayers> trilayers = LayerTriplets::layers(layers);
34  for (const auto& setAndLayers : trilayers) {
35  theGenerator->hitTriplets(region, result, ev, es, setAndLayers.first, setAndLayers.second);
36  }
38 }

References LayerHitMapCache::clear(), ev, LayerTriplets::layers(), hgcalTopologyTester_cfi::layers, HLT_FULL_cff::region, mps_fire::result, theGenerator, theLayerCache, and theSeedingLayerToken.

Member Data Documentation

◆ theGenerator

std::unique_ptr<HitTripletGeneratorFromPairAndLayers> CombinedHitTripletGenerator::theGenerator
private

Definition at line 50 of file CombinedHitTripletGenerator.h.

Referenced by CombinedHitTripletGenerator(), and hitTriplets().

◆ theLayerCache

LayerCacheType CombinedHitTripletGenerator::theLayerCache
private

Definition at line 48 of file CombinedHitTripletGenerator.h.

Referenced by CombinedHitTripletGenerator(), and hitTriplets().

◆ theSeedingLayerToken

edm::EDGetTokenT<SeedingLayerSetsHits> CombinedHitTripletGenerator::theSeedingLayerToken
private

Definition at line 46 of file CombinedHitTripletGenerator.h.

Referenced by hitTriplets().

CombinedHitTripletGenerator::theGenerator
std::unique_ptr< HitTripletGeneratorFromPairAndLayers > theGenerator
Definition: CombinedHitTripletGenerator.h:50
SeedingLayerSetsHits
Definition: SeedingLayerSetsHits.h:18
CombinedHitTripletGenerator::theSeedingLayerToken
edm::EDGetTokenT< SeedingLayerSetsHits > theSeedingLayerToken
Definition: CombinedHitTripletGenerator.h:46
edm::Handle
Definition: AssociativeIterator.h:50
edm::ConsumesCollector::consumes
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
Definition: ConsumesCollector.h:55
CombinedHitTripletGenerator::theLayerCache
LayerCacheType theLayerCache
Definition: CombinedHitTripletGenerator.h:48
edm::ParameterSet
Definition: ParameterSet.h:47
HLT_FULL_cff.region
region
Definition: HLT_FULL_cff.py:88286
get
#define get
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
looper.cfg
cfg
Definition: looper.py:296
ev
bool ev
Definition: Hydjet2Hadronizer.cc:97
LayerHitMapCache::clear
void clear()
Definition: LayerHitMapCache.h:69
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
mps_fire.result
result
Definition: mps_fire.py:311
cms::Exception
Definition: Exception.h:70
LayerTriplets::layers
std::vector< LayerSetAndLayers > layers(const SeedingLayerSetsHits &sets)
Definition: LayerTriplets.cc:4
edm::InputTag
Definition: InputTag.h:15
hgcalTopologyTester_cfi.layers
layers
Definition: hgcalTopologyTester_cfi.py:8