CMS 3D CMS Logo

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

#include <ConversionVertexFinder.h>

Public Member Functions

 ConversionVertexFinder (const edm::ParameterSet &config)
 
TransientVertex run (const std::vector< reco::TransientTrack > &pair)
 
bool run (const std::vector< reco::TransientTrack > &pair, reco::Vertex &the_vertex)
 
 ~ConversionVertexFinder ()
 

Private Attributes

edm::ParameterSet conf_
 
KinematicConstrainedVertexFitterkcvFitter_
 
double maxDelta_
 
int maxNbrOfIterations_
 
double maxReducedChiSq_
 
double minChiSqImprovement_
 

Detailed Description

Author
N. Marinelli - Univ. of Notre Dame
Version

Definition at line 29 of file ConversionVertexFinder.h.

Constructor & Destructor Documentation

ConversionVertexFinder::ConversionVertexFinder ( const edm::ParameterSet config)

Definition at line 19 of file ConversionVertexFinder.cc.

References conf_, edm::ParameterSet::getParameter(), kcvFitter_, LogDebug, maxDelta_, maxNbrOfIterations_, maxReducedChiSq_, and minChiSqImprovement_.

19  : conf_(config) {
20  LogDebug("ConversionVertexFinder") << "ConversionVertexFinder CTOR "
21  << "\n";
22  maxDelta_ = conf_.getParameter<double>("maxDelta");
23  maxReducedChiSq_ = conf_.getParameter<double>("maxReducedChiSq");
24  minChiSqImprovement_ = conf_.getParameter<double>("minChiSqImprovement");
25  maxNbrOfIterations_ = conf_.getParameter<int>("maxNbrOfIterations");
27  kcvFitter_->setParameters(conf_);
28 }
#define LogDebug(id)
T getParameter(std::string const &) const
KinematicConstrainedVertexFitter * kcvFitter_
ConversionVertexFinder::~ConversionVertexFinder ( )

Definition at line 30 of file ConversionVertexFinder.cc.

References kcvFitter_, and LogDebug.

30  {
31  LogDebug("ConversionVertexFinder") << "ConversionVertexFinder DTOR "
32  << "\n";
33  delete kcvFitter_;
34 }
#define LogDebug(id)
KinematicConstrainedVertexFitter * kcvFitter_

Member Function Documentation

TransientVertex ConversionVertexFinder::run ( const std::vector< reco::TransientTrack > &  pair)

Definition at line 135 of file ConversionVertexFinder.cc.

References MillePedeFileConverter_cfg::e, cms::Exception::explainSelf(), LogDebug, metname, AlCaHLTBitMon_QueryRunRegistry::string, and KalmanVertexFitter::vertex().

Referenced by ConvertedPhotonProducer::buildCollections(), and ConversionProducer::checkVertex().

135  {
136  LogDebug("ConversionVertexFinder") << "ConversionVertexFinder run pair size " << pair.size() << "\n";
137 
138  //for ( std::vector<reco::TransientTrack>::const_iterator iTk=pair.begin(); iTk!=pair.end(); ++iTk) {
139  // LogDebug("ConversionVertexFinder") << " ConversionVertexFinder Tracks in the pair charge " << iTk->charge() << " Num of RecHits " << iTk->recHitsSize() << " inner momentum " << iTk->track().innerMomentum() << "\n";
140  //}
141 
142  reco::Vertex theVertex;
143  KalmanVertexFitter fitter(true);
144  TransientVertex transientVtx;
145 
146  const std::string metname = "ConversionVertexFinder| ConversionVertexFinder";
147  try {
148  transientVtx = fitter.vertex(pair);
149 
150  } catch (cms::Exception& e) {
151  edm::LogWarning(metname) << "cms::Exception caught in ConversionVertexFinder::run\n" << e.explainSelf();
152  }
153 
154  return transientVtx;
155 }
#define LogDebug(id)
const std::string metname
virtual std::string explainSelf() const
Definition: Exception.cc:108
bool ConversionVertexFinder::run ( const std::vector< reco::TransientTrack > &  pair,
reco::Vertex the_vertex 
)

Definition at line 36 of file ConversionVertexFinder.cc.

References ChiSquaredProbability(), conf_, gather_cfg::cout, KinematicConstrainedVertexFitter::fit(), KinematicConstrainedVertexFitterT< nTrk, nConstraint >::fit(), newFWLiteAna::found, KinematicConstrainedVertexFitter::getNit(), KinematicConstrainedVertexFitterT< nTrk, nConstraint >::getNit(), kcvFitter_, GetRecoTauVFromDQM_MC_cff::kk, EgHLTOffHistBins_cfi::mass, KinematicParticleFactoryFromTransientTrack::particle(), ecalTrigSettings_cff::particles, ColinearityKinematicConstraint::PhiTheta, and KinematicConstrainedVertexFitterT< nTrk, nConstraint >::setParameters().

36  {
37  std::vector<reco::TransientTrack> pair = _pair;
38  bool found = false;
39 
40  if (pair.size() < 2)
41  return found;
42 
43  float sigma = 0.00000001;
44  float chi = 0.;
45  float ndf = 0.;
46  float mass = 0.000511;
47 
49 
50  std::vector<RefCountedKinematicParticle> particles;
51 
52  particles.push_back(
53  pFactory.particle(pair[0], mass, chi, ndf, sigma, *pair[0].innermostMeasurementState().freeState()));
54  particles.push_back(
55  pFactory.particle(pair[1], mass, chi, ndf, sigma, *pair[1].innermostMeasurementState().freeState()));
56 
57 #ifdef OldKineFit
59 
60  RefCountedKinematicTree myTree = kcvFitter_->fit(particles, &constr);
61 #else
62 
63  // bizzare way to the get the field...
64  const MagneticField* mf = pair[0].field();
65 
68  kcvFitter.setParameters(conf_);
69  RefCountedKinematicTree myTree = kcvFitter.fit(particles, &constr);
70 
71 #ifdef KineFitDebug
72 
74 
75  RefCountedKinematicTree oldTree = kcvFitter_->fit(particles, &oldconstr);
76 
77  if (oldTree->isValid()) {
78  std::cout << "old " << kcvFitter_->getNit() << std::endl;
79  RefCountedKinematicVertex gamma_dec_vertex = oldTree->currentDecayVertex();
80  if (gamma_dec_vertex->vertexIsValid())
81  std::cout << gamma_dec_vertex->chiSquared() << " " << gamma_dec_vertex->degreesOfFreedom() << std::endl;
82  std::cout << oldTree->currentParticle()->currentState().globalMomentum()
83  << oldTree->currentParticle()->currentState().globalPosition() << std::endl;
84  std::vector<RefCountedKinematicParticle> fStates = oldTree->finalStateParticles();
85  for (unsigned int kk = 0; kk < fStates.size(); kk++) {
86  std::cout << fStates[kk]->currentState().globalMomentum() << fStates[kk]->currentState().globalPosition()
87  << std::endl;
88  std::cout << fStates[kk]->currentState().kinematicParametersError().matrix() << std::endl;
89  }
90  } else
91  std::cout << "old invalid " << kcvFitter_->getNit() << std::endl;
92 
93  if (myTree->isValid()) {
94  std::cout << "new " << kcvFitter.getNit() << std::endl;
95  RefCountedKinematicVertex gamma_dec_vertex = myTree->currentDecayVertex();
96  if (gamma_dec_vertex->vertexIsValid())
97  std::cout << gamma_dec_vertex->chiSquared() << " " << gamma_dec_vertex->degreesOfFreedom() << std::endl;
98  std::cout << myTree->currentParticle()->currentState().globalMomentum()
99  << myTree->currentParticle()->currentState().globalPosition() << std::endl;
100  std::vector<RefCountedKinematicParticle> fStates = myTree->finalStateParticles();
101  for (unsigned int kk = 0; kk < fStates.size(); kk++) {
102  std::cout << fStates[kk]->currentState().globalMomentum() << fStates[kk]->currentState().globalPosition()
103  << std::endl;
104  std::cout << fStates[kk]->currentState().kinematicParametersError().matrix() << std::endl;
105  }
106  } else
107  std::cout << "new invalid " << kcvFitter.getNit() << std::endl;
108 
109 #endif // TemplateKineFitDebug
110 
111 #endif
112 
113  if (myTree->isValid()) {
114  myTree->movePointerToTheTop();
115  RefCountedKinematicParticle the_photon = myTree->currentParticle();
116  if (the_photon->currentState().isValid()) {
117  //const ParticleMass photon_mass = the_photon->currentState().mass();
118  RefCountedKinematicVertex gamma_dec_vertex;
119  gamma_dec_vertex = myTree->currentDecayVertex();
120  if (gamma_dec_vertex->vertexIsValid()) {
121  const float chi2Prob =
122  ChiSquaredProbability(gamma_dec_vertex->chiSquared(), gamma_dec_vertex->degreesOfFreedom());
123  if (chi2Prob > 0.) { // no longer cut here, only ask positive probability here
124  //const math::XYZPoint vtxPos(gamma_dec_vertex->position());
125  the_vertex = *gamma_dec_vertex;
126  found = true;
127  }
128  }
129  }
130  }
131 
132  return found;
133 }
RefCountedKinematicTree fit(const std::vector< RefCountedKinematicParticle > &part)
float ChiSquaredProbability(double chiSquared, double nrDOF)
KinematicConstrainedVertexFitter * kcvFitter_
RefCountedKinematicParticle particle(const reco::TransientTrack &initialTrack, const ParticleMass &massGuess, float chiSquared, float degreesOfFr, float &m_sigma) const

Member Data Documentation

edm::ParameterSet ConversionVertexFinder::conf_
private

Definition at line 40 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder(), and run().

KinematicConstrainedVertexFitter* ConversionVertexFinder::kcvFitter_
private

Definition at line 45 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder(), run(), and ~ConversionVertexFinder().

double ConversionVertexFinder::maxDelta_
private

Definition at line 41 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder().

int ConversionVertexFinder::maxNbrOfIterations_
private

Definition at line 44 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder().

double ConversionVertexFinder::maxReducedChiSq_
private

Definition at line 42 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder().

double ConversionVertexFinder::minChiSqImprovement_
private

Definition at line 43 of file ConversionVertexFinder.h.

Referenced by ConversionVertexFinder().