CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
DivisiveVertexFinder Class Reference

#include <RecoPixelVertexing/PixelVertexFinding/interface/DivisiveVertexFinder.h>

Public Member Functions

 DivisiveVertexFinder (double zOffset=5.0, int ntrkMin=5, bool useError=true, double zSeparation=0.05, bool wtAverage=true, int verbosity=0)
 
bool findVertexes (const reco::TrackRefVector &trks, reco::VertexCollection &vertexes)
 Run the divisive algorithm and return a vector of vertexes for the input track collection. More...
 
bool findVertexesAlt (const reco::TrackRefVector &trks, reco::VertexCollection &vertexes, const math::XYZPoint &bs)
 
 ~DivisiveVertexFinder ()
 

Private Attributes

pixeltemp::DivisiveClusterizer1D
< reco::Track
divmeth_
 We use Wolfgang's templated class that implements the actual divisive method. More...
 
int ntrkMin_
 
bool useError_
 
int verbose_
 
bool wtAverage_
 
double zOffset_
 Cuts on vertex formation and other options. More...
 
double zSeparation_
 

Detailed Description

Description: Fits a primary vertex in 1D (z) using the "divisive method"

Implementation: This class was ported from ORCA by me (Aaron). It was originally written by ... Find the PV candidates with a simple divisive method. Divide the luminosity region in several regions according to the track distance and for each of them make a PVCluster. Iteratively discard tracks and recover them in a new PVCluster. Return a sorted vector<Vertex> (aka VertexCollection) with the z coordinate of PV candidates

Parameters
ntkminMinimum number of tracks required to form a cluster.
useErrorphysical distances or weighted distances.
zsepMaximum distance between two adjacent tracks that belong to the same initial cluster.
weiCompute the cluster "center" with an unweighted or a weighted average of the tracks. Weighted means weighted with the error of the data point.
Date:
2010/02/10 14:14:44
Revision:
1.7
Author
Aaron Dominguez (UNL)

Definition at line 34 of file DivisiveVertexFinder.h.

Constructor & Destructor Documentation

DivisiveVertexFinder::DivisiveVertexFinder ( double  zOffset = 5.0,
int  ntrkMin = 5,
bool  useError = true,
double  zSeparation = 0.05,
bool  wtAverage = true,
int  verbosity = 0 
)

Definition at line 13 of file DivisiveVertexFinder.cc.

16  : zOffset_(zOffset), zSeparation_(zSeparation), ntrkMin_(ntrkMin), useError_(useError),
17  wtAverage_(wtAverage),
18  divmeth_(zOffset, ntrkMin, useError, zSeparation, wtAverage),
20 {
21 
22 }
pixeltemp::DivisiveClusterizer1D< reco::Track > divmeth_
We use Wolfgang&#39;s templated class that implements the actual divisive method.
double zOffset_
Cuts on vertex formation and other options.
DivisiveVertexFinder::~DivisiveVertexFinder ( )

Definition at line 24 of file DivisiveVertexFinder.cc.

24 {}

Member Function Documentation

bool DivisiveVertexFinder::findVertexes ( const reco::TrackRefVector trks,
reco::VertexCollection vertexes 
)

Run the divisive algorithm and return a vector of vertexes for the input track collection.

Definition at line 26 of file DivisiveVertexFinder.cc.

References PVPositionBuilder::average(), Measurement1D::error(), i, edm::detail::isnan(), pos, edm::RefVector< C, T, F >::size(), v, Measurement1D::value(), PVPositionBuilder::wtAverage(), and wtAverage_.

Referenced by PixelVertexProducer::produce().

27  { // output
29  Measurement1D vz;
30  if (wtAverage_) {
31  vz = pos.wtAverage(trks);
32  }
33  else {
34  vz = pos.average(trks);
35  }
37  err(2,2) = vz.error()*vz.error();
38 
39  reco::Vertex v( reco::Vertex::Point(0,0,vz.value()), err, 0, 1, trks.size() );
40  for (unsigned int i=0; i<trks.size(); i++) {
41  double vz = trks[i]->vz();
42  if(std::isnan(vz)) continue;
43  v.add(reco::TrackBaseRef(trks[i]));
44  }
45 
46  vertexes.push_back(v);
47 
48  return true;
49 }
int i
Definition: DBlmapReader.cc:9
double error() const
Definition: Measurement1D.h:30
math::Error< dimension >::type Error
covariance error matrix (3x3)
Definition: Vertex.h:44
bool isnan(float x)
Definition: math.h:13
math::XYZPoint Point
point in the space
Definition: Vertex.h:40
Measurement1D average(const reco::TrackRefVector &trks) const
Calculate unweighted average of Z of tracks from const collection of track pointers.
double value() const
Definition: Measurement1D.h:28
size_type size() const
Size of the RefVector.
Definition: RefVector.h:89
mathSSE::Vec4< T > v
Measurement1D wtAverage(const reco::TrackRefVector &trks) const
Calculate Error-Weighted average of Z of tracks from const collection of track pointers.
bool DivisiveVertexFinder::findVertexesAlt ( const reco::TrackRefVector trks,
reco::VertexCollection vertexes,
const math::XYZPoint bs 
)

Definition at line 51 of file DivisiveVertexFinder.cc.

References divmeth_, i, recoMuon::in, edm::detail::isnan(), dbtoconf::out, pixeltemp::DivisiveClusterizer1D< T >::setBeamSpot(), edm::RefVector< C, T, F >::size(), python.multivaluedict::sort(), mathSSE::sqrt(), groupFilesInBlocks::temp, v, and verbose_.

Referenced by PixelVertexProducer::produce().

52  { // output
53  std::vector< PVCluster > in;
54  std::pair< std::vector< PVCluster >, std::vector< const reco::Track* > > out;
55 
56  // Convert input track collection into container needed by Wolfgang's templated code
57  // Need to save a map to reconvert from bare pointers, oy vey
58  std::map< const reco::Track*, reco::TrackRef > mapa;
59  // std::vector< std::vector< const reco::Track* > > trkps;
60  for (unsigned int i=0; i<trks.size(); ++i) {
61  double vz = trks[i]->vz();
62  if(std::isnan(vz)) continue;
63  std::vector< const reco::Track* > temp;
64  temp.clear();
65  temp.push_back( &(*trks[i]) );
66 
67  in.push_back( PVCluster( Measurement1D(trks[i]->dz(bs), trks[i]->dzError() ), temp ) );
68  mapa[temp[0]] = trks[i];
69  }
70 
71  if (verbose_ > 0 ) {
72  edm::LogInfo("DivisiveVertexFinder") << "size of input vector of clusters " << in.size();
73  for (unsigned int i=0; i<in.size(); ++i) {
74  edm::LogInfo("DivisiveVertexFinder") << "Track " << i << " addr " << in[i].tracks()[0]
75  << " dz " << in[i].tracks()[0]->dz(bs)
76  << " +- " << in[i].tracks()[0]->dzError()
77  << " prodID " << mapa[in[i].tracks()[0]].id()
78  << " dz from RefTrack " << mapa[in[i].tracks()[0]]->dz(bs)
79  << " +- " << mapa[in[i].tracks()[0]]->dzError();
80  }
81  }
82 
83  // Run the darn thing
85  out = divmeth_(in);
86 
87  if (verbose_ > 0) edm::LogInfo("DivisiveVertexFinder") << " DivisiveClusterizer1D found "
88  << out.first.size() << " vertexes";
89 
90  // Now convert the output yet again into something we can safely store in the event
91  for (unsigned int iv=0; iv<out.first.size(); ++iv) { // loop over output vertexes
93  err(2,2) = out.first[iv].position().error()*out.first[iv].position().error();
94 
95  reco::Vertex v( reco::Vertex::Point(0,0,out.first[iv].position().value()), err, 0, 1, out.second.size() );
96  if (verbose_ > 0 ) edm::LogInfo("DivisiveVertexFinder") << " DivisiveClusterizer1D vertex " << iv
97  << " has " << out.first[iv].tracks().size()
98  << " tracks and a position of " << v.z()
99  << " +- " << std::sqrt(v.covariance(2,2));
100  for (unsigned int itrk=0; itrk<out.first[iv].tracks().size(); ++itrk) {
101  v.add( reco::TrackBaseRef(mapa[out.first[iv].tracks()[itrk]] ) );
102  }
103  vertexes.push_back(v); // Done with horrible conversion, save it
104  }
105 
106  // Finally, sort the vertexes in decreasing sumPtSquared
107  std::sort(vertexes.begin(), vertexes.end(), PVClusterComparer());
108 
109  return true;
110 }
int i
Definition: DBlmapReader.cc:9
pixeltemp::DivisiveClusterizer1D< reco::Track > divmeth_
We use Wolfgang&#39;s templated class that implements the actual divisive method.
math::Error< dimension >::type Error
covariance error matrix (3x3)
Definition: Vertex.h:44
bool isnan(float x)
Definition: math.h:13
T sqrt(T t)
Definition: SSEVec.h:46
math::XYZPoint Point
point in the space
Definition: Vertex.h:40
tuple out
Definition: dbtoconf.py:99
void setBeamSpot(const math::XYZPoint &bs)
size_type size() const
Size of the RefVector.
Definition: RefVector.h:89
Cluster1D< reco::Track > PVCluster
Definition: PVCluster.h:16
mathSSE::Vec4< T > v

Member Data Documentation

pixeltemp::DivisiveClusterizer1D< reco::Track > DivisiveVertexFinder::divmeth_
private

We use Wolfgang's templated class that implements the actual divisive method.

Definition at line 52 of file DivisiveVertexFinder.h.

Referenced by findVertexesAlt().

int DivisiveVertexFinder::ntrkMin_
private

Definition at line 48 of file DivisiveVertexFinder.h.

bool DivisiveVertexFinder::useError_
private

Definition at line 49 of file DivisiveVertexFinder.h.

int DivisiveVertexFinder::verbose_
private

Definition at line 56 of file DivisiveVertexFinder.h.

Referenced by findVertexesAlt().

bool DivisiveVertexFinder::wtAverage_
private

Definition at line 49 of file DivisiveVertexFinder.h.

Referenced by findVertexes().

double DivisiveVertexFinder::zOffset_
private

Cuts on vertex formation and other options.

Definition at line 47 of file DivisiveVertexFinder.h.

double DivisiveVertexFinder::zSeparation_
private

Definition at line 47 of file DivisiveVertexFinder.h.