RecoPixelVertexing
PixelVertexFinding
src
PVClusterComparer.cc
Go to the documentation of this file.
1
#include "
RecoPixelVertexing/PixelVertexFinding/interface/PVClusterComparer.h
"
2
#include "
DataFormats/TrackReco/interface/Track.h
"
3
#include "
DataFormats/TrackReco/interface/TrackFwd.h
"
4
5
#include "TMath.h"
6
7
PVClusterComparer::PVClusterComparer
()
8
: track_pT_min_(2.5), track_pT_max_(10.), track_chi2_max_(9999999.), track_prob_min_(-1.) {
9
setChisquareQuantile
();
10
}
11
12
PVClusterComparer::PVClusterComparer
(
double
track_pt_min
,
13
double
track_pt_max
,
14
double
track_chi2_max
,
15
double
track_prob_min
)
16
: track_pT_min_(
track_pt_min
),
17
track_pT_max_(
track_pt_max
),
18
track_chi2_max_(
track_chi2_max
),
19
track_prob_min_(
track_prob_min
) {
20
setChisquareQuantile
();
21
}
22
23
double
PVClusterComparer::pTSquaredSum
(
const
PVCluster
&
v
) {
24
double
sum = 0;
25
for
(
size_t
i
= 0;
i
<
v
.tracks().size(); ++
i
) {
26
double
pt
=
v
.tracks()[
i
]->pt();
27
if
(
pt
<
track_pT_min_
)
28
continue
;
// Don't count tracks below track_pT_min_ (2.5 GeV)
29
30
// RM : exclude badly reconstructed tracks from the sum
31
// if (track_prob_min_ >= 0. && track_prob_min_ <= 1.)
32
// if (TMath::Prob(v.tracks()[i]->chi2(),v.tracks()[i]->ndof()) < track_prob_min_) continue ;
33
if
(
track_prob_min_
>= 0. &&
track_prob_min_
<= 1.) {
34
size_t
ndof
=
v
.tracks()[
i
]->ndof();
35
if
(
ndof
>=
maxChi2_
.size())
36
updateChisquareQuantile
(
ndof
);
37
// cut on chi2 which corresponds to the configured probability
38
if
(
v
.tracks()[
i
]->chi2() >
maxChi2_
[
ndof
])
39
continue
;
40
}
41
if
(
v
.tracks()[
i
]->normalizedChi2() >
track_chi2_max_
)
42
continue
;
43
if
(
pt
>
track_pT_max_
)
44
pt
=
track_pT_max_
;
45
sum +=
pt
*
pt
;
46
}
47
return
sum;
48
}
49
50
double
PVClusterComparer::pTSquaredSum
(
const
reco::Vertex
&
v
) {
51
double
sum = 0;
52
for
(
reco::Vertex::trackRef_iterator
i
=
v
.tracks_begin(), ie =
v
.tracks_end();
i
!= ie; ++
i
) {
53
double
pt
= (*i)->pt();
54
if
(
pt
<
track_pT_min_
)
55
continue
;
// Don't count tracks below track_pT_min_ (2.5 GeV)
56
57
// RM : exclude badly reconstructed tracks from the sum
58
// if (track_prob_min_ >= 0. && track_prob_min_ <= 1.)
59
// if (TMath::Prob((*i)->chi2(),(*i)->ndof()) < track_prob_min_) continue ;
60
if
(
track_prob_min_
>= 0. &&
track_prob_min_
<= 1.) {
61
unsigned
int
ndof
= (*i)->ndof();
62
if
(
ndof
>=
maxChi2_
.size())
63
updateChisquareQuantile
(
ndof
);
64
// cut on chi2 which corresponds to the configured probability
65
if
((*i)->chi2() >
maxChi2_
[
ndof
])
66
continue
;
67
}
68
if
((*i)->normalizedChi2() >
track_chi2_max_
)
69
continue
;
70
71
if
(
pt
>
track_pT_max_
)
72
pt
=
track_pT_max_
;
73
sum +=
pt
*
pt
;
74
}
75
return
sum;
76
}
77
78
void
PVClusterComparer::setChisquareQuantile
() {
79
std::vector<double>
maxChi2
(20, 0.);
80
if
(
track_prob_min_
>= 0. &&
track_prob_min_
<= 1.)
81
for
(
size_t
ndof
= 0;
ndof
<
maxChi2_
.size(); ++
ndof
)
82
// http://root.cern.ch/root/html/TMath.html#TMath:ChisquareQuantile
83
maxChi2
[
ndof
] = TMath::ChisquareQuantile(1 -
track_prob_min_
,
ndof
);
84
85
maxChi2_
=
maxChi2
;
86
}
87
88
void
PVClusterComparer::updateChisquareQuantile
(
size_t
ndof
) {
89
size_t
oldsize =
maxChi2_
.size();
90
// maxChi2_.resize(ndof+1);
91
for
(
size_t
i
= oldsize;
i
<=
ndof
; ++
i
) {
92
double
chi2
= TMath::ChisquareQuantile(1 -
track_prob_min_
,
i
);
93
maxChi2_
.push_back(
chi2
);
94
}
95
}
96
97
bool
PVClusterComparer::operator()
(
const
PVCluster
&v1,
const
PVCluster
&v2) {
98
return
(
pTSquaredSum
(v1) >
pTSquaredSum
(v2));
99
}
100
bool
PVClusterComparer::operator()
(
const
reco::Vertex
&v1,
const
reco::Vertex
&v2) {
101
return
(
pTSquaredSum
(v1) >
pTSquaredSum
(v2));
102
}
reco::Vertex::trackRef_iterator
std::vector< TrackBaseRef >::const_iterator trackRef_iterator
The iteratator for the vector<TrackRef>
Definition:
Vertex.h:38
PVClusterComparer::track_prob_min_
const double track_prob_min_
Definition:
PVClusterComparer.h:37
mps_fire.i
i
Definition:
mps_fire.py:355
PVClusterComparer::track_pT_min_
const double track_pT_min_
Definition:
PVClusterComparer.h:34
DiDispStaMuonMonitor_cfi.pt
pt
Definition:
DiDispStaMuonMonitor_cfi.py:39
HLT_2018_cff.track_pt_min
track_pt_min
Definition:
HLT_2018_cff.py:256
HLT_2018_cff.track_prob_min
track_prob_min
Definition:
HLT_2018_cff.py:255
PVClusterComparer::setChisquareQuantile
void setChisquareQuantile()
Definition:
PVClusterComparer.cc:78
beam_dqm_sourceclient-live_cfg.maxChi2
maxChi2
Definition:
beam_dqm_sourceclient-live_cfg.py:139
findQualityFiles.v
v
Definition:
findQualityFiles.py:179
hltPixelTracks_cff.chi2
chi2
Definition:
hltPixelTracks_cff.py:25
ndof
Definition:
HIMultiTrackSelector.h:49
Track.h
TrackFwd.h
PVClusterComparer::pTSquaredSum
double pTSquaredSum(const PVCluster &v)
Calculate sum of square of the pT's of the tracks in the vertex.
Definition:
PVClusterComparer.cc:23
PVClusterComparer::maxChi2_
std::vector< double > maxChi2_
Definition:
PVClusterComparer.h:32
PVClusterComparer::track_pT_max_
const double track_pT_max_
Definition:
PVClusterComparer.h:35
PVClusterComparer::updateChisquareQuantile
void updateChisquareQuantile(size_t ndof)
Definition:
PVClusterComparer.cc:88
PVClusterComparer.h
PVCluster
HLT_2018_cff.track_chi2_max
track_chi2_max
Definition:
HLT_2018_cff.py:253
PVClusterComparer::PVClusterComparer
PVClusterComparer()
Constructor does nothing, no data members.
Definition:
PVClusterComparer.cc:7
PVClusterComparer::track_chi2_max_
const double track_chi2_max_
Definition:
PVClusterComparer.h:36
PVClusterComparer::operator()
bool operator()(const PVCluster &v1, const PVCluster &v2)
Use this operator in a std::sort to sort them in decreasing sumPt.
Definition:
PVClusterComparer.cc:97
HLT_2018_cff.track_pt_max
track_pt_max
Definition:
HLT_2018_cff.py:254
reco::Vertex
Definition:
Vertex.h:35
Generated for CMSSW Reference Manual by
1.8.16