CMS 3D CMS Logo

Public Member Functions | Private Member Functions | Private Attributes

SelectReplacementCandidates Class Reference

#include <SelectReplacementCandidates.h>

Inheritance diagram for SelectReplacementCandidates:
edm::EDProducer edm::ProducerBase edm::ProductRegistryHelper

List of all members.

Public Member Functions

virtual void beginJob ()
virtual void endJob ()
virtual void produce (edm::Event &iEvent, const edm::EventSetup &iConfig)
 SelectReplacementCandidates (const edm::ParameterSet &iSetup)
 ~SelectReplacementCandidates ()

Private Member Functions

int determineMuonsToUse (const edm::Event &iEvent, const edm::EventSetup &iConfig, reco::Muon *muon1, reco::Muon *muon2)
int determineMuonsToUse_old (const edm::Event &iEvent, const edm::EventSetup &iConfig, reco::Muon *muon1, reco::Muon *muon2)
void getRawIDsAdvanced (const edm::Event &iEvent, const edm::EventSetup &iConfig, std::vector< uint32_t > *L, reco::Muon *muon, bool includeHCAL)
template<typename T >
void ProductNotFound (const edm::Event &iEvent, edm::InputTag inputTag)
void transformMuMu2TauTau (reco::Muon *muon1, reco::Muon *muon2)
 transform muon into tau

Private Attributes

edm::InputTag muonInputTag_
TrackAssociatorParameters parameters_
double targetParticleMass_
int targetParticlePdgID_
TrackDetectorAssociator trackAssociator_

Detailed Description

Definition at line 26 of file SelectReplacementCandidates.h.


Constructor & Destructor Documentation

SelectReplacementCandidates::SelectReplacementCandidates ( const edm::ParameterSet iSetup)

Definition at line 4 of file SelectReplacementCandidates.cc.

References edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), TrackAssociatorParameters::loadParameters(), muonInputTag_, Parameters::parameters, parameters_, targetParticleMass_, targetParticlePdgID_, trackAssociator_, and TrackDetectorAssociator::useDefaultPropagator().

{
        using namespace edm;
        using namespace std;
        produces< vector<uint32_t> >();
        produces< vector<uint32_t> >("assocHitsWithHCAL");
        produces< std::vector<reco::Muon> >();
        
        targetParticleMass_=iConfig.getUntrackedParameter<double>("targetParticlesMass",1.77690);
        targetParticlePdgID_=iConfig.getUntrackedParameter<int>("targetParticlesPdgID",15);
        
        muonInputTag_ = iConfig.getParameter<edm::InputTag>("muonInputTag");
        edm::ParameterSet parameters = iConfig.getParameter<edm::ParameterSet>("TrackAssociatorParameters");
        parameters_.loadParameters( parameters );
        
        trackAssociator_.useDefaultPropagator();
}
SelectReplacementCandidates::~SelectReplacementCandidates ( )

Definition at line 22 of file SelectReplacementCandidates.cc.

{

}

Member Function Documentation

void SelectReplacementCandidates::beginJob ( void  ) [virtual]

Reimplemented from edm::EDProducer.

Definition at line 60 of file SelectReplacementCandidates.cc.

{

}
int SelectReplacementCandidates::determineMuonsToUse ( const edm::Event iEvent,
const edm::EventSetup iConfig,
reco::Muon muon1,
reco::Muon muon2 
) [private]

Definition at line 71 of file SelectReplacementCandidates.cc.

References gather_cfg::cout, deltaR(), edm::Event::getByLabel(), edm::Event::getManyByType(), i, muonInputTag_, patZpeak::muons, p4, dt_dqm_sourceclient_common_cff::reco, edm::View< T >::size(), and z.

Referenced by produce().

{
        using namespace edm;
        using namespace reco;
        using namespace std;

        Handle< edm::RefToBaseVector<reco::Candidate> > zCandidate_handle;
        if (!iEvent.getByLabel("dimuonsGlobal", zCandidate_handle))
        {
                std::cout << "Could not find product: " << "dimuonsGlobal" << "\n";    
    std::vector< edm::Handle< edm::RefToBaseVector<reco::Candidate> >  > allHandles;
    iEvent.getManyByType(allHandles);
    std::vector< edm::Handle< edm::RefToBaseVector<reco::Candidate> > >::iterator it;
    for (it = allHandles.begin(); it != allHandles.end(); it++)
    {
      std::cout << "available product: " << (*it).provenance()->moduleLabel() << ", " << (*it).provenance()->productInstanceName() << ", " << (*it).provenance()->processName();
    }

          std::cout << "Objekt nicht gefunden: dimuonsGloal\n";
          return -1;
        }
//      std::cout << zCandidate_handle->size() << " Kandidaten gefunden!\n";

        unsigned int nMuons = zCandidate_handle->size();
        if (nMuons==0)
                return -1;

        for (edm::RefToBaseVector<reco::Candidate>::const_iterator z = zCandidate_handle->begin(); z!=zCandidate_handle->end(); ++z)
        {
                reco::Particle::LorentzVector muon1p4 = z->get()->daughter(0)->p4();
                reco::Particle::LorentzVector muon2p4 = z->get()->daughter(1)->p4();

                edm::Handle<edm::View<reco::Muon> > trackCollection;
                iEvent.getByLabel(muonInputTag_, trackCollection);
                const edm::View<reco::Muon>& muons = * trackCollection;

                bool found1=false, found2=false;
                for (unsigned int i=0;i<muons.size() && !(found1 && found2);i++)
                {
                        if (deltaR(muon1p4,muons[i].p4())<0.1)
                        {
                                *muon1 = muons[i];
                                found1=true;
                        }
                        if (deltaR(muon2p4,muons[i].p4())<0.1)
                        {
                                *muon2 = muons[i];
                                found2=true;
                        }
                }

                break;
        }
        return 0;
}
int SelectReplacementCandidates::determineMuonsToUse_old ( const edm::Event iEvent,
const edm::EventSetup iConfig,
reco::Muon muon1,
reco::Muon muon2 
) [private]

Definition at line 128 of file SelectReplacementCandidates.cc.

References gather_cfg::cout, edm::Event::getByLabel(), muonInputTag_, patZpeak::muons, and dt_dqm_sourceclient_common_cff::reco.

{
    using namespace edm;
    using namespace reco;
    using namespace std;

        Handle<MuonCollection> muonHandle;
        if (!iEvent.getByLabel(muonInputTag_,muonHandle))
                ProductNotFound<reco::MuonCollection>(iEvent, muonInputTag_);
        
        edm::Handle<edm::View<reco::Muon> > trackCollection;
        iEvent.getByLabel(muonInputTag_, trackCollection);
        const edm::View<reco::Muon>& muons = * trackCollection;

        unsigned int nMuons = muons.size();
        if (nMuons<2)
                return -1;
        
        *muon1 = muons[0];
        *muon2 = muons[1];
        std::cout << muons[0].p4() << "\n";
        std::cout << muons[1].p4() << "\n";
    
  return 0;
}
void SelectReplacementCandidates::endJob ( void  ) [virtual]

Reimplemented from edm::EDProducer.

Definition at line 65 of file SelectReplacementCandidates.cc.

{

}
void SelectReplacementCandidates::getRawIDsAdvanced ( const edm::Event iEvent,
const edm::EventSetup iConfig,
std::vector< uint32_t > *  L,
reco::Muon muon,
bool  includeHCAL 
) [private]

Definition at line 154 of file SelectReplacementCandidates.cc.

References TrackDetectorAssociator::associate(), reco::Muon::bestTrackRef(), gather_cfg::cout, TrackDetMatchInfo::ecalRecHits, edm::RefToBase< T >::get(), TrackDetMatchInfo::hcalRecHits, i, info, edm::RefToBase< T >::isNonnull(), parameters_, dt_dqm_sourceclient_common_cff::reco, and trackAssociator_.

Referenced by produce().

{
  using namespace edm;
  using namespace reco;
  using namespace std;

        if (muon->bestTrackRef().isNonnull())
        {
                TrackDetMatchInfo info = trackAssociator_.associate(iEvent, iConfig, *(muon->bestTrackRef().get()), parameters_);
                if (includeHCAL)
                {
                        for(std::vector<const EcalRecHit*>::const_iterator hit = info.ecalRecHits.begin(); hit != info.ecalRecHits.end(); ++hit)
        L->push_back((*hit)->detid().rawId());
                                                                                                
                        for(std::vector<const HBHERecHit*>::const_iterator hit = info.hcalRecHits.begin(); hit != info.hcalRecHits.end(); ++hit)
                                L->push_back((*hit)->detid().rawId());
                                                                                                                                                              }
                        int recs = (muon->bestTrackRef().get())->recHitsSize();
                        for (int i=0; i<recs; i++)
                                L->push_back(((muon->bestTrackRef().get())->recHit(i).get())->geographicalId().rawId());
        }
        else
                std::cout << "ERROR: Muon has no bestTrackRef!!\n";

    std::cout << " with " <<  L->size() << " muon hits found\n";
//     return L;
}
void SelectReplacementCandidates::produce ( edm::Event iEvent,
const edm::EventSetup iConfig 
) [virtual]

Implements edm::EDProducer.

Definition at line 27 of file SelectReplacementCandidates.cc.

References gather_cfg::cout, determineMuonsToUse(), getRawIDsAdvanced(), patZpeak::muons, edm::Event::put(), and transformMuMu2TauTau().

{
        using namespace std;
        using namespace edm;
        reco::Muon muon1, muon2;

        // determine the muons to be used
        // these can be reconstructed muons or muons from a HepMC::Event
        if (determineMuonsToUse(iEvent, iSetup, &muon1, &muon2)!=0)
                return;
        
        vector<uint32_t> hits ; 
        getRawIDsAdvanced(iEvent, iSetup, &hits, &muon1, false);
        getRawIDsAdvanced(iEvent, iSetup, &hits, &muon2, false);
        std::auto_ptr< vector<uint32_t> > selectedHitsAutoPtr(new vector<uint32_t>(hits) );
        iEvent.put( selectedHitsAutoPtr );

        vector<uint32_t> assoc_hits_withHCAL;   
        getRawIDsAdvanced(iEvent, iSetup, &assoc_hits_withHCAL, &muon1, true);
        getRawIDsAdvanced(iEvent, iSetup, &assoc_hits_withHCAL, &muon2, true);
        std::cout << "found in total " << assoc_hits_withHCAL.size() << " cells with associated hits with hcal\n";
        std::auto_ptr< vector<uint32_t> > selectedAssocHitsWithHCALAutoPtr(new vector<uint32_t>(assoc_hits_withHCAL) );
        iEvent.put( selectedAssocHitsWithHCALAutoPtr, "assocHitsWithHCAL");
                                                        
        std::vector<reco::Muon> muons;
        transformMuMu2TauTau(&muon1, &muon2);
        muons.push_back(muon1);
        muons.push_back(muon2);
        std::auto_ptr< std::vector<reco::Muon> > selectedMuonsPtr(new std::vector<reco::Muon>(muons) );
        iEvent.put( selectedMuonsPtr );

}
template<typename T >
void SelectReplacementCandidates::ProductNotFound ( const edm::Event iEvent,
edm::InputTag  inputTag 
) [private]

Definition at line 183 of file SelectReplacementCandidates.cc.

References gather_cfg::cout, and edm::Event::getManyByType().

{
    std::cout << "--- TauHitSelector ------------------------------------\n";
    std::cout << "Could not find product with:\n"<< inputTag << "\n";
    std::vector< edm::Handle< T > > allHandles; 
    iEvent.getManyByType(allHandles);
    typename std::vector< edm::Handle< T > >::iterator it;
    for (it = allHandles.begin(); it != allHandles.end(); it++)
    {
            std::cout << "module label:        " << (*it).provenance()->moduleLabel() << "\n";
            std::cout << "productInstanceName: " << (*it).provenance()->productInstanceName() << "\n";
            std::cout << "processName:         " << (*it).provenance()->processName() << "\n\n";
    }
    std::cout << "-------------------------------------------------------\n";           
                return;
}
void SelectReplacementCandidates::transformMuMu2TauTau ( reco::Muon muon1,
reco::Muon muon2 
) [private]

transform muon into tau

Definition at line 202 of file SelectReplacementCandidates.cc.

References abs, reco::LeafCandidate::p4(), reco::LeafCandidate::pdgId(), dt_dqm_sourceclient_common_cff::reco, reco::LeafCandidate::setP4(), reco::LeafCandidate::setPdgId(), reco::LeafCandidate::setStatus(), mathSSE::sqrt(), targetParticleMass_, and targetParticlePdgID_.

Referenced by produce().

{
        using namespace edm;
        using namespace reco;
        using namespace std;
        
        reco::Particle::LorentzVector muon1_momentum = muon1->p4();
        reco::Particle::LorentzVector muon2_momentum =  muon2->p4();
        reco::Particle::LorentzVector z_momentum = muon1_momentum + muon2_momentum;

        ROOT::Math::Boost booster(z_momentum.BoostToCM());
        ROOT::Math::Boost invbooster(booster.Inverse());
        
        reco::Particle::LorentzVector Zb = booster(z_momentum);

        reco::Particle::LorentzVector muon1b = booster(muon1_momentum);
        reco::Particle::LorentzVector muon2b = booster(muon2_momentum);
        
        double tau_mass2 = targetParticleMass_*targetParticleMass_;

        double muonxb_mom2 = muon1b.x()*muon1b.x() + muon1b.y()*muon1b.y() + muon1b.z() * muon1b.z();
        double tauxb_mom2 = 0.25 * Zb.t() * Zb.t() - tau_mass2;

        float scaling1 = sqrt(tauxb_mom2 / muonxb_mom2);
        float scaling2 = scaling1;

        float tauEnergy= Zb.t() / 2.;

        if (tauEnergy*tauEnergy<tau_mass2)
                return;
        
        reco::Particle::LorentzVector tau1b_mom = reco::Particle::LorentzVector(scaling1*muon1b.x(),scaling1*muon1b.y(),scaling1*muon1b.z(),tauEnergy);
        reco::Particle::LorentzVector tau2b_mom = reco::Particle::LorentzVector(scaling2*muon2b.x(),scaling2*muon2b.y(),scaling2*muon2b.z(),tauEnergy);

        // some checks
        // the following test guarantees a deviation
        // of less than 0.1% for phi and theta for the
        // original muons and the placed taus
        // (in the centre-of-mass system of the z boson)
        assert((muon1b.phi()-tau1b_mom.phi())/muon1b.phi()<0.001);
        assert((muon2b.phi()-tau2b_mom.phi())/muon2b.phi()<0.001);
        assert((muon1b.theta()-tau1b_mom.theta())/muon1b.theta()<0.001);
        assert((muon2b.theta()-tau2b_mom.theta())/muon2b.theta()<0.001);        

        reco::Particle::LorentzVector tau1_mom = (invbooster(tau1b_mom));
        reco::Particle::LorentzVector tau2_mom = (invbooster(tau2b_mom));
        
        // some additional checks
        // the following tests guarantee a deviation of less
        // than 0.1% for the following values of the original
        // muons and the placed taus
        //      invariant mass
        //      transverse momentum
        assert(((muon1_momentum+muon1_momentum).mass()-(tau1_mom+tau2_mom).mass())/(muon1_momentum+muon1_momentum).mass()<0.001);
        assert(((muon1_momentum+muon2_momentum).pt()-(tau1_mom+tau2_mom).pt())/(muon1_momentum+muon1_momentum).pt()<0.001);

        muon1->setP4(tau1_mom);
        muon2->setP4(tau2_mom);

        muon1->setPdgId(targetParticlePdgID_*muon1->pdgId()/abs(muon1->pdgId()));
        muon2->setPdgId(targetParticlePdgID_*muon2->pdgId()/abs(muon2->pdgId()));

        muon1->setStatus(1);
        muon2->setStatus(1);

        return;
}

Member Data Documentation

Definition at line 45 of file SelectReplacementCandidates.h.

Referenced by getRawIDsAdvanced(), and SelectReplacementCandidates().

Definition at line 44 of file SelectReplacementCandidates.h.

Referenced by getRawIDsAdvanced(), and SelectReplacementCandidates().