51 #ifdef COUNT_ElectronSeeds 56 ~Count() {
std::cout <<
"ElectronSeeds res " << s<<
'/'<<n << std::endl;}
67 : dynamicphiroad_(pset.getParameter<
bool>(
"dynamicPhiRoad")),
68 fromTrackerSeeds_(pset.getParameter<
bool>(
"fromTrackerSeeds")),
69 useRecoVertex_(
false),
70 verticesTag_(ts.token_vtx),
71 beamSpotTag_(ts.token_bs),
72 lowPtThreshold_(pset.getParameter<double>(
"LowPtThreshold")),
73 highPtThreshold_(pset.getParameter<double>(
"HighPtThreshold")),
74 nSigmasDeltaZ1_(pset.getParameter<double>(
"nSigmasDeltaZ1")),
75 deltaZ1WithVertex_(0.5),
76 sizeWindowENeg_(pset.getParameter<double>(
"SizeWindowENeg")),
77 deltaPhi1Low_(pset.getParameter<double>(
"DeltaPhi1Low")),
78 deltaPhi1High_(pset.getParameter<double>(
"DeltaPhi1High")),
79 deltaPhi1Coef1_(0.), deltaPhi1Coef2_(0.),
83 theMeasurementTrackerEventTag(ts.token_measTrkEvt),
85 cacheIDMagField_(0),cacheIDNavSchool_(0),cacheIDCkfComp_(0),cacheIDTrkGeom_(0)
114 phiMin2B_, phiMax2B_, phiMin2F_, phiMax2F_,
126 phiMin2B_, phiMax2B_, phiMin2F_, phiMax2F_,
210 for ( i1=r1.first, i2=
r2.first, nHits=0 ; i1!=r1.second ; ++i1, ++i2, ++nHits )
212 if ( !i1->isValid() || !i2->isValid() )
return false ;
213 if ( i1->geographicalId()!=i2->geographicalId() )
return false ;
214 if ( ! ( i1->localPosition()==i2->localPosition() ) )
return false ;
274 {
throw cms::Exception(
"NotSupported") <<
"Here in ElectronSeedGenerator " << __FILE__ <<
":" << __LINE__ <<
" I would like to do theMeasurementTracker->update(e); but that no longer makes sense.\n";
277 for (
unsigned int i=0;
i<sclRefs.
size();++
i) {
281 LogDebug (
"ElectronSeedGenerator") <<
"new cluster, calling seedsFromThisCluster";
285 LogDebug (
"ElectronSeedGenerator") <<
": For event "<<e.
id();
286 LogDebug (
"ElectronSeedGenerator") <<
"Nr of superclusters after filter: "<<sclRefs.
size()
287 <<
", no. of ElectronSeeds found = " << out.size();
289 #ifdef COUNT_ElectronSeeds 290 stcount.s+=sclRefs.
size();
291 stcount.n+=out.size();
298 float hoe1,
float hoe2,
301 float clusterEnergy = seedCluster->energy() ;
303 ( seedCluster->position().x(),
304 seedCluster->position().y(),
305 seedCluster->position().z() ) ;
346 double sq=
sqrt(sigmaZ*sigmaZ+sigmaZ0Error*sigmaZ0Error);
359 std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> > elePixelHits
365 std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> > posPixelHits
373 std::vector<SeedWithInfo> elePixelSeeds
377 std::vector<SeedWithInfo> posPixelSeeds
390 std::vector<reco::Vertex>::const_iterator vtxIter ;
391 for (vtxIter = vtxCollection->begin(); vtxIter != vtxCollection->end() ; vtxIter++)
394 GlobalPoint vertexPos(vtxIter->position().x(),vtxIter->position().y(),vtxIter->position().z());
395 double myZmin1, myZmax1 ;
400 double sq=
sqrt(sigmaZ*sigmaZ+sigmaZ0Error*sigmaZ0Error);
416 std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> > elePixelHits
420 std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> > posPixelHits
427 std::vector<SeedWithInfo> elePixelSeeds
431 std::vector<SeedWithInfo> posPixelSeeds
442 ( std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> > &
pixelHits,
449 {
LogDebug(
"ElectronSeedGenerator") <<
"Compatible "<<(positron?
"positron":
"electron")<<
" hits found." ; }
451 std::vector<std::pair<RecHitWithDist,ConstRecHitPointer> >::iterator
v ;
455 { (*v).first.invert() ; }
460 addSeed(seed,
nullptr,positron,out) ;
465 (
const std::vector<SeedWithInfo> & pixelSeeds,
467 float hoe1,
float hoe2,
471 if (!pixelSeeds.empty())
472 {
LogDebug(
"ElectronSeedGenerator") <<
"Compatible "<<(positron?
"positron":
"electron")<<
" seeds found." ; }
474 std::vector<SeedWithInfo>::const_iterator
s;
475 for ( s = pixelSeeds.begin() ; s != pixelSeeds.end() ; s++ )
478 seed.setCaloCluster(cluster);
479 seed.initTwoHitSeed(s->hitsMask());
491 { out.emplace_back(seed) ;
return ; }
497 reco::ElectronSeedCollection::iterator resItr ;
498 for ( resItr=out.begin() ; resItr!=out.end() ; ++resItr )
501 (seed.
hitsMask()==resItr->hitsMask()) &&
510 seed.
setNegAttributes(resItr->dRz2(),resItr->dPhi2(),resItr->dRz1(),resItr->dPhi1()) ;
517 if ( resItr->dRz2Pos()!=seed.
dRz2Pos() )
520 <<
"this similar old seed already has another dRz2Pos" 521 <<
"\nold seed mask/dRz2/dPhi2/dRz2Pos/dPhi2Pos: "<<(
unsigned int)resItr->hitsMask()<<
"/"<<resItr->dRz2()<<
"/"<<resItr->dPhi2()<<
"/"<<resItr->dRz2Pos()<<
"/"<<resItr->dPhi2Pos()
547 seed.
setPosAttributes(resItr->dRz2Pos(),resItr->dPhi2Pos(),resItr->dRz1Pos(),resItr->dPhi1Pos()) ;
554 if (resItr->dRz2()!=seed.
dRz2())
557 <<
"this old seed already has another dRz2" 558 <<
"\nold seed mask/dRz2/dPhi2/dRz2Pos/dPhi2Pos: "<<(
unsigned int)resItr->hitsMask()<<
"/"<<resItr->dRz2()<<
"/"<<resItr->dPhi2()<<
"/"<<resItr->dRz2Pos()<<
"/"<<resItr->dPhi2Pos()
582 out.emplace_back(seed) ;
592 LogDebug(
"") <<
"[ElectronSeedGenerator::prepareElTrackSeed] inner PixelHit x,y,z "<<innerhit->globalPosition();
593 LogDebug(
"") <<
"[ElectronSeedGenerator::prepareElTrackSeed] outer PixelHit x,y,z "<<outerhit->globalPosition();
604 constpixhit = dynamic_cast <
const SiPixelRecHit *> (outerhit->hit());
624 FastHelix helix(outerhit->globalPosition(),innerhit->globalPosition(),vertexPos,nomField,&*bfield);
625 if ( !helix.isValid()) {
630 if (!propagatedState.isValid())
635 if (!propagatedState_out.
isValid())
PropagationDirection direction() const
T getParameter(std::string const &) const
unsigned long long cacheIdentifier() const
unsigned long long cacheIDNavSchool_
double sigmaZ0Error() const
error on sigma z
PixelHitMatcher * myMatchEle
void setupES(const edm::EventSetup &setup)
void setEvent(const MeasurementTrackerEvent &event)
void setPosAttributes(const float dRZ2=std::numeric_limits< float >::infinity(), const float dPhi2=std::numeric_limits< float >::infinity(), const float dRZ1=std::numeric_limits< float >::infinity(), const float dPhi1=std::numeric_limits< float >::infinity())
int nominalValue() const
The nominal field value for this map in kGauss.
bool getByToken(EDGetToken token, Handle< PROD > &result) const
LocalPoint position() const
Local x and y position coordinates.
TransientTrackingRecHit::ConstRecHitPointer ConstRecHitPointer
void setES(const MagneticField *, const MeasurementTracker *theMeasurementTracker, const TrackerGeometry *trackerGeometry)
const NavigationSchool * theNavigationSchool
edm::EDGetTokenT< MeasurementTrackerEvent > theMeasurementTrackerEventTag
const edm::EventSetup * theSetup
def setup(process, global_tag, zero_tesla=False)
GlobalPoint globalPosition() const
const CaloClusterRef & caloCluster() const
unsigned long long cacheIDMagField_
void run(edm::Event &, const edm::EventSetup &setup, const reco::SuperClusterRefVector &, const std::vector< float > &hoe1s, const std::vector< float > &hoe2s, TrajectorySeedCollection *seeds, reco::ElectronSeedCollection &)
edm::Handle< std::vector< reco::Vertex > > theVertices
unsigned long long cacheIDTrkGeom_
void set2ndLayer(float dummyphi2minB, float dummyphi2maxB, float dummyphi2minF, float dummyphi2maxF)
TrajectorySeedCollection * theInitialSeedColl
void set1stLayerZRange(float zmin1, float zmax1)
TrajectoryStateOnSurface update(const TrajectoryStateOnSurface &, const TrackingRecHit &) const override
const SurfaceType & surface() const
PTrajectoryStateOnDet pts_
edm::ESHandle< TrackerGeometry > theTrackerGeometry
void seedsFromThisCluster(edm::Ref< reco::SuperClusterCollection > seedCluster, float hoe1, float hoe2, reco::ElectronSeedCollection &out, const TrackerTopology *tTopo)
std::vector< TrajectorySeed > TrajectorySeedCollection
PRecHitContainer recHits_
recHitContainer::const_iterator const_iterator
std::pair< const_iterator, const_iterator > range
unsigned int detId() const
PropagatorWithMaterial * thePropagator
edm::Handle< reco::BeamSpot > theBeamSpot
edm::EDGetTokenT< std::vector< reco::Vertex > > verticesTag_
LocalVector momentum() const
Momentum vector in the local frame.
std::vector< ElectronSeed > ElectronSeedCollection
collection of ElectronSeed objects
PixelHitMatcher * myMatchPos
void seedsFromRecHits(std::vector< std::pair< RecHitWithDist, ConstRecHitPointer > > &elePixelHits, PropagationDirection &dir, const GlobalPoint &vertexPos, const reco::ElectronSeed::CaloClusterRef &cluster, reco::ElectronSeedCollection &out, bool positron)
bool prepareElTrackSeed(ConstRecHitPointer outerhit, ConstRecHitPointer innerhit, const GlobalPoint &vertexPos)
TrajectoryStateOnSurface TSOS
edm::EDGetTokenT< reco::BeamSpot > beamSpotTag_
PTrajectoryStateOnDet const & startingState() const
T const * product() const
void set1stLayer(float dummyphi1min, float dummyphi1max)
void addSeed(reco::ElectronSeed &seed, const SeedWithInfo *info, bool positron, reco::ElectronSeedCollection &out)
void setNegAttributes(const float dRZ2=std::numeric_limits< float >::infinity(), const float dPhi2=std::numeric_limits< float >::infinity(), const float dRZ1=std::numeric_limits< float >::infinity(), const float dPhi1=std::numeric_limits< float >::infinity())
double sigmaZ() const
sigma z
ElectronSeedGenerator(const edm::ParameterSet &, const Tokens &)
void ele_convert(const Type1 &obj1, Type2 &obj2)
TrajectoryStateOnSurface propagate(STA const &state, SUR const &surface) const
TrackCharge charge() const
Charge (-1, 0 or 1)
edm::ESHandle< MagneticField > theMagField
void setCaloCluster(const CaloClusterRef &clus)
bool equivalent(const TrajectorySeed &s1, const TrajectorySeed &s2)
unsigned int nHits() const
char data[epos_bytes_allocation]
GlobalVector globalMomentum() const
void display_seed(const std::string &title1, const std::string &title2, const reco::ElectronSeed &seed, edm::ESHandle< TrackerGeometry > trackerGeometry)
const MeasurementTracker * theMeasurementTracker
unsigned int hitsMask() const
size_type size() const
Size of the RefVector.
const Point & position() const
position
std::vector< SeedWithInfo > compatibleSeeds(TrajectorySeedCollection *seeds, const GlobalPoint &xmeas, const GlobalPoint &vprim, float energy, float charge)
std::vector< std::pair< RecHitWithDist, ConstRecHitPointer > > compatibleHits(const GlobalPoint &xmeas, const GlobalPoint &vprim, float energy, float charge, const TrackerTopology *tTopo, const NavigationSchool &navigationSchool)
void setUseRecoVertex(bool val)
T const * product() const
void seedsFromTrajectorySeeds(const std::vector< SeedWithInfo > &elePixelSeeds, const reco::ElectronSeed::CaloClusterRef &cluster, float hoe1, float hoe2, reco::ElectronSeedCollection &out, bool positron)
std::string theMeasurementTrackerName
const LocalTrajectoryParameters & parameters() const
unsigned long long cacheIDCkfComp_