1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
#ifndef RecoCandidate_RecoChargedRefCandidate_h
#define RecoCandidate_RecoChargedRefCandidate_h
#include "DataFormats/Candidate/interface/LeafRefCandidateT.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"
#include "DataFormats/TrackReco/interface/Track.h"
namespace reco {
typedef LeafRefCandidateT RecoChargedRefCandidateBase;
class RecoChargedRefCandidate : public LeafRefCandidateT {
public:
RecoChargedRefCandidate() {}
RecoChargedRefCandidate(TrackRef ref, float m) : LeafRefCandidateT(ref, m) {}
~RecoChargedRefCandidate() override {}
RecoChargedRefCandidate* clone() const override { return new RecoChargedRefCandidate(*this); }
reco::TrackRef track() const { return getRef<reco::TrackRef>(); }
// return a pointer to the best track, if available.
// otherwise, return a null pointer
const reco::Track* bestTrack() const override {
if (track().isNonnull() && track().isAvailable())
return &(*track());
else
return nullptr;
}
/// uncertainty on dz
float dzError() const override {
const Track* tr = bestTrack();
if (tr != nullptr)
return tr->dzError();
else
return 0;
}
/// uncertainty on dxy
float dxyError() const override {
const Track* tr = bestTrack();
if (tr != nullptr)
return tr->dxyError();
else
return 0;
}
};
} // namespace reco
#endif
|