CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
egammaisolation::EgammaHcalExtractor Class Reference

#include <EgammaHcalExtractor.h>

Inheritance diagram for egammaisolation::EgammaHcalExtractor:
reco::isodeposit::IsoDepositExtractor

Public Member Functions

virtual reco::IsoDeposit deposit (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Track &track) const
 
virtual reco::IsoDeposit deposit (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Candidate &c) const
 
 EgammaHcalExtractor (const edm::ParameterSet &par)
 
virtual void fillVetos (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::TrackCollection &tracks)
 
virtual ~EgammaHcalExtractor ()
 
- Public Member Functions inherited from reco::isodeposit::IsoDepositExtractor
virtual reco::IsoDeposit deposit (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::TrackBaseRef &track) const
 make single IsoDeposit based on trackRef as input More...
 
virtual reco::IsoDeposit deposit (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::CandidateBaseRef &track) const
 make single IsoDeposit based on a CandidateBaseRef as input More...
 
virtual std::vector
< reco::IsoDeposit
deposits (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Track &track) const
 
virtual std::vector
< reco::IsoDeposit
deposits (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::TrackBaseRef &track) const
 
virtual std::vector
< reco::IsoDeposit
deposits (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Candidate &track) const
 
virtual std::vector
< reco::IsoDeposit
deposits (const edm::Event &ev, const edm::EventSetup &evSetup, const reco::CandidateBaseRef &track) const
 
virtual ~IsoDepositExtractor ()
 Destructor. More...
 

Private Attributes

double etLow_
 
double extRadius_
 
edm::InputTag hcalRecHitProducer_
 
double intRadius_
 

Detailed Description

Definition at line 38 of file EgammaHcalExtractor.h.

Constructor & Destructor Documentation

EgammaHcalExtractor::EgammaHcalExtractor ( const edm::ParameterSet par)

Definition at line 35 of file EgammaHcalExtractor.cc.

35  :
36  extRadius_(par.getParameter<double>("extRadius")),
37  intRadius_(par.getParameter<double>("intRadius")),
38  etLow_(par.getParameter<double>("etMin")),
39  hcalRecHitProducer_(par.getParameter<edm::InputTag>("hcalRecHits")) {
40 }
T getParameter(std::string const &) const
EgammaHcalExtractor::~EgammaHcalExtractor ( )
virtual

Definition at line 42 of file EgammaHcalExtractor.cc.

42 {}

Member Function Documentation

virtual reco::IsoDeposit egammaisolation::EgammaHcalExtractor::deposit ( const edm::Event ev,
const edm::EventSetup evSetup,
const reco::Track track 
) const
inlinevirtual

make single IsoDeposit based on track as input purely virtual: have to implement in concrete implementations

Implements reco::isodeposit::IsoDepositExtractor.

Definition at line 46 of file EgammaHcalExtractor.h.

References edm::hlt::Exception, and mergeVDriftHistosByStation::name.

Referenced by deposit().

47  {
48  throw cms::Exception("Configuration Error") <<
49  "This extractor " << (typeid(this).name()) << " is not made for tracks";
50  }
reco::IsoDeposit EgammaHcalExtractor::deposit ( const edm::Event ev,
const edm::EventSetup evSetup,
const reco::Candidate track 
) const
virtual

make single IsoDeposit based on a candidate as input purely virtual: have to implement in concrete implementations

Reimplemented from reco::isodeposit::IsoDepositExtractor.

Definition at line 44 of file EgammaHcalExtractor.cc.

References deposit(), PV3DBase< T, PVType, FrameType >::eta(), etLow_, create_public_lumi_plots::exp, extRadius_, edm::EventSetup::get(), reco::Candidate::get(), edm::Event::getByLabel(), CaloGeometry::getPosition(), DetId::Hcal, hcalRecHitProducer_, i, intRadius_, PV3DBase< T, PVType, FrameType >::phi(), point, edm::ESHandle< class >::product(), CaloDualConeSelector::select(), and funct::sin().

45  {
46 
47  //Get MetaRecHit collection
48  edm::Handle<HBHERecHitCollection> hcalRecHitHandle;
49  iEvent.getByLabel(hcalRecHitProducer_, hcalRecHitHandle);
50  HBHERecHitMetaCollection mhbhe = HBHERecHitMetaCollection(*hcalRecHitHandle);
51 
52  //Get Calo Geometry
54  iSetup.get<CaloGeometryRecord>().get(pG);
55  const CaloGeometry* caloGeom = pG.product();
57 
58  //Take the SC position
60  math::XYZPoint caloPosition = sc->position();
61  GlobalPoint point(caloPosition.x(), caloPosition.y() , caloPosition.z());
62  // needed: coneSel.select(eta,phi,hits) is not the same!
63 
64  Direction candDir(caloPosition.eta(), caloPosition.phi());
65  reco::IsoDeposit deposit( candDir );
67  double sinTheta = sin(2*atan(exp(-sc->eta())));
68  deposit.addCandEnergy(sc->energy()*sinTheta);
69 
70  //Compute the HCAL energy behind ECAL
71  std::auto_ptr<CaloRecHitMetaCollectionV> chosen = coneSel.select(point, mhbhe);
72  for (CaloRecHitMetaCollectionV::const_iterator i = chosen->begin (), ed = chosen->end() ;
73  i!= ed; ++i) {
74  const GlobalPoint & hcalHit_position = caloGeom->getPosition(i->detid());
75  double hcalHit_eta = hcalHit_position.eta();
76  double hcalHit_Et = i->energy()*sin(2*atan(exp(-hcalHit_eta)));
77  if ( hcalHit_Et > etLow_) {
78  deposit.addDeposit( Direction(hcalHit_eta, hcalHit_position.phi()), hcalHit_Et);
79  }
80  }
81 
82  return deposit;
83 }
int i
Definition: DBlmapReader.cc:9
void setVeto(const Veto &aVeto)
Set veto.
Definition: IsoDeposit.h:80
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
Geom::Phi< T > phi() const
Definition: PV3DBase.h:69
void addDeposit(double dr, double deposit)
Add deposit (ie. transverse energy or pT)
Definition: IsoDeposit.cc:23
int iEvent
Definition: GenABIO.cc:243
void addCandEnergy(double et)
Set energy or pT attached to cand trajectory.
Definition: IsoDeposit.h:139
const GlobalPoint & getPosition(const DetId &id) const
Get the position of a given detector id.
Definition: CaloGeometry.cc:68
SimpleCaloRecHitMetaCollection< HBHERecHitCollection > HBHERecHitMetaCollection
virtual reco::IsoDeposit deposit(const edm::Event &ev, const edm::EventSetup &evSetup, const reco::Track &track) const
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:13
T const * product() const
Definition: ESHandle.h:62
T eta() const
Definition: PV3DBase.h:76
T const * get() const
Returns C++ pointer to the item.
Definition: Ref.h:242
*vegas h *****************************************************used in the default bin number in original ***version of VEGAS is ***a higher bin number might help to derive a more precise ***grade subtle point
Definition: invegas.h:5
virtual void egammaisolation::EgammaHcalExtractor::fillVetos ( const edm::Event ev,
const edm::EventSetup evSetup,
const reco::TrackCollection tracks 
)
inlinevirtual

fill vetoes: to exclude deposits at IsoDeposit creation stage check concrete extractors if it's no-op !

Implements reco::isodeposit::IsoDepositExtractor.

Definition at line 44 of file EgammaHcalExtractor.h.

45  { }

Member Data Documentation

double egammaisolation::EgammaHcalExtractor::etLow_
private

Definition at line 57 of file EgammaHcalExtractor.h.

Referenced by deposit().

double egammaisolation::EgammaHcalExtractor::extRadius_
private

Definition at line 55 of file EgammaHcalExtractor.h.

Referenced by deposit().

edm::InputTag egammaisolation::EgammaHcalExtractor::hcalRecHitProducer_
private

Definition at line 59 of file EgammaHcalExtractor.h.

Referenced by deposit().

double egammaisolation::EgammaHcalExtractor::intRadius_
private

Definition at line 56 of file EgammaHcalExtractor.h.

Referenced by deposit().