|
|
Go to the documentation of this file.
101 , m_vertexConstraint(
cfg.getParameter<
bool>(
"vertexConstraint"))
117 m_diMuon_Z =
book1D(
"/iterN/",
"diMuon_Z",
"Di-muon mass (GeV)", 200, 90. - 50., 90. + 50.);
118 m_diMuon_Zforward =
book1D(
"/iterN/",
"diMuon_Zforward",
"Di-muon mass (GeV) eta > 1.4", 200, 90. - 50., 90. + 50.);
119 m_diMuon_Zbarrel =
book1D(
"/iterN/",
"diMuon_Zbarrel",
"Di-muon mass (GeV) -1.4 < eta < 1.4", 200, 90. - 50., 90. + 50.);
120 m_diMuon_Zbackward =
book1D(
"/iterN/",
"diMuon_Zbackward",
"Di-muon mass (GeV) eta < -1.4", 200, 90. - 50., 90. + 50.);
121 m_diMuon_Ups =
book1D(
"/iterN/",
"diMuon_Ups",
"Di-muon mass (GeV)", 200, 9. - 3., 9. + 3.);
122 m_diMuon_Jpsi =
book1D(
"/iterN/",
"diMuon_Jpsi",
"Di-muon mass (GeV)", 200, 3. - 1., 3. + 1.);
127 m_chi2_log =
book1D(
"/iterN/",
"m_chi2_log",
"Log track chi^2", 100, -3, 7);
133 m_chi2DOF_improvement =
book1D(
"/iterN/",
"m_chi2DOF_improvement",
"Track-by-track (chi^2/DOF)/(original chi^2/original DOF)", 100, 0., 10.);
134 for (
int i = 0;
i < 36;
i++) {
136 snprintf(
name,
sizeof(
name),
"m_pt_phi%d",
i);
137 snprintf(
title,
sizeof(
title),
"Track pt (GeV) in phi bin %d/36",
i);
156 for (ConstTrajTrackPairCollection::const_iterator it =
tracks.begin(); it !=
tracks.end(); ++it) {
162 double closest = 10000.;
164 std::vector<TrajectoryMeasurement> measurements = traj->
measurements();
165 for (std::vector<TrajectoryMeasurement>::const_iterator im = measurements.begin(); im != measurements.end(); ++im) {
170 nDOF +=
hit->dimension();
175 if (where.
mag() < closest) {
176 closest = where.
mag();
183 if (closest != 10000.) {
184 std::pair<bool, FreeTrajectoryState>
state;
196 double chi2DOF =
chi2 / double(nDOF);
224 double pt = momentum.
perp();
225 double phi = momentum.
phi();
231 for (
int i = 0;
i < 36;
i++) {
242 if (
e1 > 0. && e2 > 0.) {
243 double energy_tot =
e1 + e2;
245 double mass =
sqrt(energy_tot*energy_tot - momentum_tot.
mag2());
246 double eta = momentum_tot.
eta();
TH1F * m_chi2_improvement
void book()
Book or retrieve histograms; MUST be reimplemented.
~AlignmentMonitorTracksFromTrajectories()
Point3DBase< Scalar, LocalTag > LocalPoint
void event(const edm::Event &iEvent, const edm::EventSetup &iSetup, const ConstTrajTrackPairCollection &iTrajTracks)
Called for each event (by "run()"): may be reimplemented.
MuonServiceProxy * theMuonServiceProxy
TrajectoryStateOnSurface const & backwardPredictedState() const
Access to backward predicted state (from smoother)
GlobalPoint toGlobal(const Point2DBase< Scalar, LocalTag > lp) const
#define DEFINE_EDM_PLUGIN(factory, type, name)
std::pair< bool, FreeTrajectoryState > propagateWithUpdate(const TrajectoryStateOnSurface &tsos, const reco::BeamSpot &beamSpot) const
Propagate to the 2D-PCA and apply the vertex constraint.
void update(const edm::EventSetup &setup, bool duringEvent=true)
update the services each event
MuonUpdatorAtVertex * theMuonUpdatorAtVertex
const uint32_t *__restrict__ const HitContainer *__restrict__ TkSoA *__restrict__ tracks
AlignmentMonitorTracksFromTrajectories(const edm::ParameterSet &cfg)
TH1F * m_diMuon_Zbackward
std::pair< bool, FreeTrajectoryState > propagate(const TrajectoryStateOnSurface &tsos, const reco::BeamSpot &beamSpot) const
Propagate the state to the 2D-PCA.
DataContainer const & measurements() const
TH1F * book1D(std::string dir, std::string name, std::string title, int nchX, double lowX, double highX)
ConstRecHitPointer const & recHit() const
TH1F * m_chi2DOF_improvement
const SurfaceType & surface() const
std::vector< ConstTrajTrackPair > ConstTrajTrackPairCollection
TrajectoryStateOnSurface TSOS
Geom::Phi< T > phi() const