112 produces<std::vector<Trajectory>>();
113 produces<TrajTrackAssociationCollection>();
148 auto trajectoryCollection = std::make_unique<std::vector<Trajectory>>();
158 reco::TrackCollection::const_iterator globalMuonTrack = globalMuonTracks->begin();
159 for (; globalMuonTrack != globalMuonTracks->end(); ++globalMuonTrack) {
161 if (fabs(
globalMuon->combinedMuon()->phi() - globalMuonTrack->phi()) < 1
e-10 &&
162 fabs(
globalMuon->combinedMuon()->eta() - globalMuonTrack->eta()) < 1
e-10)
165 if (globalMuonTrack == globalMuonTracks->end()) {
166 throw cms::Exception(
"BadConfig") <<
"The tracks label doesn't correspond to the same objects as the muons label"
174 if (trackerTrajectories.size() == 1) {
175 const Trajectory trackerTrajectory = *(trackerTrajectories.begin());
208 std::vector<TrajectoryStateOnSurface> TSOSes;
209 for (
auto const&
hit :
globalMuon->combinedMuon()->recHits()) {
213 bool extrapolated =
false;
222 if (extrapolated && extrapolation.
isValid()) {
224 TSOSes.push_back(extrapolation);
229 if (!muonHits.
empty()) {
234 for (
unsigned int i = 0;
i < muonHits.
size();
i++) {
240 trajectoryCollection->push_back(trajectory);
244 reference_map[trajCounter] = trackCounter;
250 unsigned int numTrajectories = trajectoryCollection->size();
256 auto trajTrackMap = std::make_unique<TrajTrackAssociationCollection>();
258 for (trajCounter = 0; trajCounter < numTrajectories; trajCounter++) {
261 trajTrackMap->insert(
edm::Ref<std::vector<Trajectory>>(ohTrajs, trajCounter),