13 inline double sqr(
double a){
return a*
a;}
17 :_conf(conf),seedCollection(0),seedCollectionOfSourceTracks(0),
18 hitsfactoryPSet(conf.getParameter<edm::
ParameterSet>(
"OrderedHitsFactoryPSet")),
19 creatorPSet(conf.getParameter<edm::
ParameterSet>(
"SeedCreatorPSet")),
20 regfactoryPSet(conf.getParameter<edm::
ParameterSet>(
"RegionFactoryPSet")),
21 theClusterCheck(conf.getParameter<edm::
ParameterSet>(
"ClusterCheckPSet")),
22 theSilentOnClusterCheck(conf.getParameter<edm::
ParameterSet>(
"ClusterCheckPSet").getUntrackedParameter<bool>(
"silentClusterCheck",
false)),
23 _vtxMinDoF(conf.getParameter<double>(
"vtxMinDoF")),
24 _maxDZSigmas(conf.getParameter<double>(
"maxDZSigmas")),
25 _maxNumSelVtx(conf.getParameter<uint32_t>(
"maxNumSelVtx")),
26 _applyTkVtxConstraint(conf.getParameter<bool>(
"applyTkVtxConstraint")),
28 _primaryVtxInputTag(conf.getParameter<edm::InputTag>(
"primaryVerticesTag")),
29 _beamSpotInputTag(conf.getParameter<edm::InputTag>(
"beamSpotInputTag"))
69 edm::LogError(
"TooManyClusters") <<
"Found too many clusters (" << clustsOrZero <<
"), bailing out.\n";
100 ss <<
"\n++++++++++++++++++\n";
111 for (
IR ir=
regions.begin(), irEnd=
regions.end(); ir < irEnd; ++ir)
delete (*ir);
139 std::vector<reco::Vertex> selectedPriVtxCompatibleWithTrack;
141 selectedPriVtxCompatibleWithTrack.push_back(*(
vertexHandle->begin()));
151 edm::LogInfo(
"debugTrajSeedFromSingleLeg") <<
"Inspected " <<
sel <<
" tracks over " << idx <<
" tracks. \t # tracks providing at least one seed " <<
_countSeedTracks ;
158 std::vector< std::pair< double, short> >
idx;
161 double cosPhi=tk.
px()/tk.
pt();
162 double sinPhi=tk.
py()/tk.
pt();
173 double cotTheta=tk.
pz()/tk.
pt();
179 double sxy2=
sqr(cosPhi*cotTheta)*sx2+
180 sqr(sinPhi*cotTheta)*sy2+
181 sqr(cotTheta*(-dx*sinPhi+dy*cosPhi))*sphi2+
182 sqr((1+cotTheta*cotTheta)*(dx*cosPhi+dy*sinPhi))*stheta2;
187 ss <<
" primary vtx " << vtx.
position() <<
" \tk vz " << tk.
vz() <<
" vx " << tk.
vx() <<
" vy " << tk.
vy() <<
" pz/pt " << tk.
pz()/tk.
pt() <<
" \t dz " << _dz <<
" \t " << _dzError <<
" sxy2 "<< sxy2<<
" \t dz/dzErr " << _dz/_dzError<< std::endl;
192 idx.push_back(std::pair<double,short>(fabs(_dz),count));
196 ss <<
"no vertex selected " << std::endl;
201 std::stable_sort(idx.begin(),idx.end(),
lt_);
205 ss <<
"selected vtx dz " << idx[0].first <<
" position" << idx[0].second << std::endl;
215 bool foundAtLeastASeedCand=
false;
216 BOOST_FOREACH(
const reco::Vertex vtx, selectedPriVtxCompatibleWithTrack){
224 ss <<
"[PrintRegion] " << region.
print() << std::endl;
234 !foundAtLeastASeedCand
236 foundAtLeastASeedCand=
true;
326 float originRBound = 3;
327 float originZBound = 3.;
343 GlobalVector originBounds(originRBound,originRBound,originZBound);
346 primaryVertexPoint.y(),
347 primaryVertexPoint.z()
352 ss <<
"\nConversion Point " << originPos <<
" " << originPos.
perp() <<
"\n";
357 unsigned int nHitss = hitss.
size();
363 ss <<
"\n nHitss " << nHitss <<
"\n";
368 for (
unsigned int iHits = 0; iHits < nHitss; ++iHits) {
371 ss <<
"\n iHits " << iHits <<
"\n";
edm::ParameterSet hitsfactoryPSet
T getParameter(std::string const &) const
SeedForPhotonConversion1Leg * theSeedCreator
void analyze(const edm::Event &event, const edm::EventSetup &setup)
IdealHelixParameters _IdealHelixParameters
void setMagnField(const MagneticField *magnField)
virtual GlobalVector inTesla(const GlobalPoint &gp) const =0
Field value ad specified global point, in Tesla.
ClusterChecker theClusterCheck
Global3DPoint GlobalPoint
edm::InputTag _primaryVtxInputTag
edm::ParameterSet regfactoryPSet
virtual unsigned int size() const =0
const TrajectorySeed * trajectorySeed(TrajectorySeedCollection &seedCollection, const SeedingHitSet &hits, const GlobalPoint &vertex, const GlobalVector &vertexBounds, float ptmin, const edm::EventSetup &es, float cotTheta, std::stringstream &ss)
double covariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
TrajectorySeedCollection * seedCollection
double px() const
x coordinate of momentum vector
CombinedHitPairGeneratorForPhotonConversion * theHitsGenerator
const Point & position() const
position
CovarianceMatrix covariance() const
return track covariance matrix
math::XYZVector GetMomentumAtTangentPoint() const
U second(std::pair< T, U > const &p)
const OrderedHitPairs & run(const ConversionRegion &convRegion, const TrackingRegion ®ion, const edm::Event &ev, const edm::EventSetup &es)
const edm::EventSetup * myEsetup
const edm::ParameterSet _conf
math::XYZVector GetTangentPoint() const
edm::ParameterSet creatorPSet
std::vector< TrajectorySeed > TrajectorySeedCollection
const MagneticField * magField
edm::InputTag _beamSpotInputTag
double pt() const
track transverse momentum
size_t tooManyClusters(const edm::Event &e) const
void print(std::stringstream &ss, const SiStripCluster &clus)
How EventSelector::AcceptEvent() decides whether to accept an event for output otherwise it is excluding the probing of A single or multiple positive and the trigger will pass if any such matching triggers are PASS or EXCEPTION[A criterion thatmatches no triggers at all is detected and causes a throw.] A single negative with an expectation of appropriate bit checking in the decision and the trigger will pass if any such matching triggers are FAIL or EXCEPTION A wildcarded negative criterion that matches more than one trigger in the trigger but the state exists so we define the behavior If all triggers are the negative crieriion will lead to accepting the event(this again matches the behavior of"!*"before the partial wildcard feature was incorporated).The per-event"cost"of each negative criterion with multiple relevant triggers is about the same as!*was in the past
bool inspectTrack(const reco::Track *track, const TrackingRegion ®ion, math::XYZPoint &primaryVertexPoint)
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
double pz() const
z coordinate of momentum vector
bool _applyTkVtxConstraint
double dz() const
dz parameter (= dsz/cos(lambda)). This is the track z0 w.r.t (0,0,0) only if the refPoint is close to...
double dzError() const
error on dz
double vz() const
z coordinate of the reference point on track
void loopOnPriVtx(const reco::Track &tk, const std::vector< reco::Vertex > &selectedPriVtxCompatibleWithTrack)
const edm::Event * myEvent
XYZVectorD XYZVector
spatial vector with cartesian internal representation
XYZPointD XYZPoint
point in space with cartesian internal representation
tuple idx
DEBUGGING if hasattr(process,"trackMonIterativeTracking2012"): print "trackMonIterativeTracking2012 D...
T const * product() const
bool rejectTrack(const reco::Track &track)
virtual std::string print() const
TrajectorySeedCollection * seedCollectionOfSourceTracks
edm::Handle< reco::VertexCollection > vertexHandle
double vy() const
y coordinate of the reference point on track
virtual std::vector< TrackingRegion * > regions(const edm::Event &ev, const edm::EventSetup &) const
Square< F >::type sqr(const F &f)
bool theSilentOnClusterCheck
bool lt_(std::pair< double, short > a, std::pair< double, short > b)
Regions::const_iterator IR
edm::Handle< reco::BeamSpot > recoBeamSpotHandle
edm::Handle< reco::TrackCollection > trackCollectionH
int charge() const
track electric charge
void setData(const reco::Track *track, math::XYZVector refPoint=math::XYZVector(0, 0, 0))
GlobalTrackingRegionProducerFromBeamSpot * theRegionProducer
void setup(std::vector< TH2F > &depth, std::string name, std::string units="")
bool selectPriVtxCompatibleWithTrack(const reco::Track &tk, std::vector< reco::Vertex > &selectedPriVtxCompatibleWithTrack)
PhotonConversionTrajectorySeedProducerFromSingleLegAlgo(const edm::ParameterSet &)
double py() const
y coordinate of momentum vector
double vx() const
x coordinate of the reference point on track
double thetaError() const
error on theta