Line Code
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 51 52 53 54 55 56 57 58 59
//
// Original Author:  Marco Zanetti
//         Created:  Tue Sep  9 15:56:24 CEST 2008

// user include files
#include "CalibMuon/DTCalibration/interface/DTCalibMuonSelection.h"

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/InputTag.h"

#include "DataFormats/MuonReco/interface/Muon.h"

#include "DataFormats/TrackReco/interface/Track.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"

using namespace edm;
using namespace reco;

DTCalibMuonSelection::DTCalibMuonSelection(const edm::ParameterSet& iConfig) {
  muonList = consumes<MuonCollection>(iConfig.getParameter<edm::InputTag>("src"));
  etaMin = iConfig.getParameter<double>("etaMin");
  etaMax = iConfig.getParameter<double>("etaMax");
  ptMin = iConfig.getParameter<double>("ptMin");
}

DTCalibMuonSelection::~DTCalibMuonSelection() {}

bool DTCalibMuonSelection::filter(edm::Event& iEvent, const edm::EventSetup& iSetup) {
  bool result = false;

  //Retrieve the muons list
  Handle<MuonCollection> MuHandle;
  iEvent.getByToken(muonList, MuHandle);

  for (MuonCollection::const_iterator nmuon = MuHandle->begin(); nmuon != MuHandle->end(); ++nmuon) {
    double ptMuon(0.);
    double etaMuon(-999.);

    if (nmuon->isGlobalMuon()) {
      ptMuon = nmuon->globalTrack()->pt();
      etaMuon = nmuon->globalTrack()->eta();
    } else
      continue;

    if (ptMuon > ptMin && etaMuon > etaMin && etaMuon < etaMax) {
      result = true;
      break;
    }
  }

  return result;
}

// ------------ method called once each job just before starting event loop  ------------
void DTCalibMuonSelection::beginStream(edm::StreamID) {}

// ------------ method called once each job just after ending the event loop  ------------
void DTCalibMuonSelection::endStream() {}