File indexing completed on 2024-04-06 12:04:51
0001 #ifndef DataFormat_ParticleFlowReco_PFDisplacedVertexSeed_h
0002 #define DataFormat_ParticleFlowReco_PFDisplacedVertexSeed_h
0003
0004 #include "DataFormats/GeometryVector/interface/GlobalPoint.h"
0005 #include "DataFormats/TrackReco/interface/TrackFwd.h"
0006
0007 #include <vector>
0008 #include <iostream>
0009
0010 namespace reco {
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025 class PFDisplacedVertexSeed {
0026 public:
0027
0028 PFDisplacedVertexSeed();
0029
0030
0031
0032 void addElement(TrackBaseRef);
0033
0034
0035 void reserveElements(size_t);
0036
0037
0038
0039 void updateSeedPoint(const GlobalPoint& dcaPoint, const TrackBaseRef, const TrackBaseRef, double weight = 1);
0040
0041
0042 void mergeWith(const PFDisplacedVertexSeed& displacedVertex);
0043
0044
0045 bool isEmpty() const { return (elements_.empty()); }
0046
0047
0048 const std::vector<TrackBaseRef>& elements() const { return elements_; }
0049
0050 const double nTracks() const { return elements_.size(); }
0051
0052
0053 const GlobalPoint& seedPoint() const { return seedPoint_; }
0054
0055
0056 const double totalWeight() const { return totalWeight_; }
0057
0058
0059 void Dump(std::ostream& out = std::cout) const;
0060
0061 private:
0062 friend std::ostream& operator<<(std::ostream& out, const PFDisplacedVertexSeed& co);
0063
0064
0065
0066
0067 std::vector<TrackBaseRef> elements_;
0068
0069 GlobalPoint seedPoint_;
0070
0071
0072 float totalWeight_;
0073 };
0074 }
0075
0076 #endif