CMS 3D CMS Logo

List of all members | Public Member Functions
EcalClusterLocal Class Reference

#include <EcalClusterLocal.h>

Public Member Functions

 EcalClusterLocal ()
 
void localCoordsEB (const reco::CaloCluster &bclus, const edm::EventSetup &es, float &etacry, float &phicry, int &ieta, int &iphi, float &thetatilt, float &phitilt) const
 
void localCoordsEB (const reco::CaloCluster &bclus, const CaloGeometry &geom, float &etacry, float &phicry, int &ieta, int &iphi, float &thetatilt, float &phitilt) const
 
void localCoordsEE (const reco::CaloCluster &bclus, const edm::EventSetup &es, float &xcry, float &ycry, int &ix, int &iy, float &thetatilt, float &phitilt) const
 
void localCoordsEE (const reco::CaloCluster &bclus, const CaloGeometry &geom, float &xcry, float &ycry, int &ix, int &iy, float &thetatilt, float &phitilt) const
 
 ~EcalClusterLocal ()
 

Detailed Description

Function to compute local coordinates of Ecal clusters (adapted from RecoEcal/EgammaCoreTools/plugins/EcalClusterLocal)

Author
Josh Bendavid, MIT, 2011

Definition at line 17 of file EcalClusterLocal.h.

Constructor & Destructor Documentation

EcalClusterLocal::EcalClusterLocal ( )

Definition at line 16 of file EcalClusterLocal.cc.

17 {}
EcalClusterLocal::~EcalClusterLocal ( )

Definition at line 19 of file EcalClusterLocal.cc.

20 {}

Member Function Documentation

void EcalClusterLocal::localCoordsEB ( const reco::CaloCluster bclus,
const edm::EventSetup es,
float &  etacry,
float &  phicry,
int &  ieta,
int &  iphi,
float &  thetatilt,
float &  phitilt 
) const

Definition at line 22 of file EcalClusterLocal.cc.

References edm::EventSetup::get().

Referenced by EGEnergyCorrector::CorrectedEnergyWithError(), EGEnergyCorrector::CorrectedEnergyWithErrorV3(), EcalRegressionData::fill(), SuperClusterHelper::localCoordinates(), EGRegressionModifierV2::modifyObject(), and EGRegressionModifierV1::modifyObject().

22  {
24  es.get<CaloGeometryRecord>().get(pG);
25  localCoordsEB( bclus, *pG, etacry, phicry, ieta, iphi, thetatilt, phitilt);
26 }
const T & get() const
Definition: EventSetup.h:55
void localCoordsEB(const reco::CaloCluster &bclus, const edm::EventSetup &es, float &etacry, float &phicry, int &ieta, int &iphi, float &thetatilt, float &phitilt) const
void EcalClusterLocal::localCoordsEB ( const reco::CaloCluster bclus,
const CaloGeometry geom,
float &  etacry,
float &  phicry,
int &  ieta,
int &  iphi,
float &  thetatilt,
float &  phitilt 
) const

Definition at line 31 of file EcalClusterLocal.cc.

References reco::deltaR(), particleFlowClusterECALTimeSelected_cfi::depth, runTauDisplay::dr, DetId::Ecal, EcalBarrel, reco::CaloCluster::energy(), reco::tau::disc::Eta(), PV3DBase< T, PVType, FrameType >::eta(), plotBeamSpotDB::first, relativeConstraints::geom, TruncatedPyramid::getPhiAxis(), TruncatedPyramid::getPosition(), CaloGeometry::getSubdetectorGeometry(), TruncatedPyramid::getThetaAxis(), reco::CaloCluster::hitsAndFractions(), EBDetId::ieta(), EBDetId::iphi(), cmsBatch::log, colinearityKinematic::Phi, PV3DBase< T, PVType, FrameType >::phi(), Pi, reco::CaloCluster::position(), PV3DBase< T, PVType, FrameType >::theta(), and X0.

32 {
33 
34  assert(bclus.hitsAndFractions().at(0).first.subdetId()==EcalBarrel);
35 
36  const CaloSubdetectorGeometry* geom=caloGeometry.getSubdetectorGeometry(DetId::Ecal,EcalBarrel);//EcalBarrel = 1
37 
38  const math::XYZPoint& position_ = bclus.position();
39  double Theta = -position_.theta()+0.5*TMath::Pi();
40  double Eta = position_.eta();
41  double Phi = TVector2::Phi_mpi_pi(position_.phi());
42 
43  //Calculate expected depth of the maximum shower from energy (like in PositionCalc::Calculate_Location()):
44  // The parameters X0 and T0 are hardcoded here because these values were used to calculate the corrections:
45  const float X0 = 0.89; const float T0 = 7.4;
46  double depth = X0 * (T0 + log(bclus.energy()));
47 
48  //find max energy crystal
49  std::vector< std::pair<DetId, float> > crystals_vector = bclus.hitsAndFractions();
50  float drmin = 999.;
51  EBDetId crystalseed;
52  //printf("starting loop over crystals, etot = %5f:\n",bclus.energy());
53  for (unsigned int icry=0; icry!=crystals_vector.size(); ++icry) {
54 
55  EBDetId crystal(crystals_vector[icry].first);
56 
57  const CaloCellGeometry* cell=geom->getGeometry(crystal);
58  GlobalPoint center_pos = (dynamic_cast<const TruncatedPyramid*>(cell))->getPosition(depth);
59  double EtaCentr = center_pos.eta();
60  double PhiCentr = TVector2::Phi_mpi_pi(center_pos.phi());
61 
62  float dr = reco::deltaR(Eta,Phi,EtaCentr,PhiCentr);
63  if (dr<drmin) {
64  drmin = dr;
65  crystalseed = crystal;
66  }
67 
68  }
69 
70  ieta = crystalseed.ieta();
71  iphi = crystalseed.iphi();
72 
73  // Get center cell position from shower depth
74  const CaloCellGeometry* cell=geom->getGeometry(crystalseed);
75  const TruncatedPyramid *cpyr = dynamic_cast<const TruncatedPyramid*>(cell);
76 
77  thetatilt = cpyr->getThetaAxis();
78  phitilt = cpyr->getPhiAxis();
79 
80  GlobalPoint center_pos = cpyr->getPosition(depth);
81 
82  double PhiCentr = TVector2::Phi_mpi_pi(center_pos.phi());
83  double PhiWidth = (TMath::Pi()/180.);
84  phicry = (TVector2::Phi_mpi_pi(Phi-PhiCentr))/PhiWidth;
85  //Some flips to take into account ECAL barrel symmetries:
86  if (ieta<0) phicry *= -1.;
87 
88  double ThetaCentr = -center_pos.theta()+0.5*TMath::Pi();
89  double ThetaWidth = (TMath::Pi()/180.)*TMath::Cos(ThetaCentr);
90  etacry = (Theta-ThetaCentr)/ThetaWidth;
91  //flip to take into account ECAL barrel symmetries:
92  if (ieta<0) etacry *= -1.;
93 
94  return;
95 
96 }
const double Pi
const CaloSubdetectorGeometry * getSubdetectorGeometry(const DetId &id) const
access the subdetector geometry for the given subdetector directly
Definition: CaloGeometry.cc:45
const math::XYZPoint & position() const
cluster centroid position
Definition: CaloCluster.h:129
Geom::Phi< T > phi() const
Definition: PV3DBase.h:69
const std::vector< std::pair< DetId, float > > & hitsAndFractions() const
Definition: CaloCluster.h:195
CCGFloat getPhiAxis() const
Geom::Theta< T > theta() const
Definition: PV3DBase.h:75
int iphi() const
get the crystal iphi
Definition: EBDetId.h:53
auto deltaR(const T1 &t1, const T2 &t2) -> decltype(t1.eta())
Definition: deltaR.h:28
double energy() const
cluster energy
Definition: CaloCluster.h:124
int ieta() const
get the crystal ieta
Definition: EBDetId.h:51
CCGFloat getThetaAxis() const
const GlobalPoint getPosition(CCGFloat depth) const
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
A base class to handle the particular shape of Ecal Xtals. Taken from ORCA Calorimetry Code...
T eta() const
Definition: PV3DBase.h:76
static const double X0
void EcalClusterLocal::localCoordsEE ( const reco::CaloCluster bclus,
const edm::EventSetup es,
float &  xcry,
float &  ycry,
int &  ix,
int &  iy,
float &  thetatilt,
float &  phitilt 
) const

Definition at line 98 of file EcalClusterLocal.cc.

References edm::EventSetup::get().

Referenced by EcalRegressionData::fill(), SuperClusterHelper::localCoordinates(), EGRegressionModifierV2::modifyObject(), and EGRegressionModifierV1::modifyObject().

99 {
101  es.get<CaloGeometryRecord>().get(pG);
102  localCoordsEE( bclus, *pG, xcry, ycry, ix, iy, thetatilt, phitilt);
103 }
const T & get() const
Definition: EventSetup.h:55
void localCoordsEE(const reco::CaloCluster &bclus, const edm::EventSetup &es, float &xcry, float &ycry, int &ix, int &iy, float &thetatilt, float &phitilt) const
void EcalClusterLocal::localCoordsEE ( const reco::CaloCluster bclus,
const CaloGeometry geom,
float &  xcry,
float &  ycry,
int &  ix,
int &  iy,
float &  thetatilt,
float &  phitilt 
) const

Definition at line 105 of file EcalClusterLocal.cc.

References Abs(), reco::deltaR(), particleFlowClusterECALTimeSelected_cfi::depth, runTauDisplay::dr, DetId::Ecal, EcalEndcap, reco::CaloCluster::energy(), reco::tau::disc::Eta(), PV3DBase< T, PVType, FrameType >::eta(), reco::CaloCluster::eta(), plotBeamSpotDB::first, relativeConstraints::geom, TruncatedPyramid::getPhiAxis(), TruncatedPyramid::getPosition(), CaloGeometry::getSubdetectorGeometry(), TruncatedPyramid::getThetaAxis(), reco::CaloCluster::hitsAndFractions(), EEDetId::ix(), EEDetId::iy(), cmsBatch::log, colinearityKinematic::Phi, PV3DBase< T, PVType, FrameType >::phi(), reco::CaloCluster::position(), X, PV3DBase< T, PVType, FrameType >::x(), X0, DOFs::Y, and PV3DBase< T, PVType, FrameType >::y().

106 {
107 
108  assert(bclus.hitsAndFractions().at(0).first.subdetId()==EcalEndcap);
109 
110  const CaloSubdetectorGeometry* geom=caloGeometry.getSubdetectorGeometry(DetId::Ecal,EcalEndcap);//EcalBarrel = 1
111 
112  const math::XYZPoint& position_ = bclus.position();
113  //double Theta = -position_.theta()+0.5*TMath::Pi();
114  double Eta = position_.eta();
115  double Phi = TVector2::Phi_mpi_pi(position_.phi());
116  double X = position_.x();
117  double Y = position_.y();
118 
119  //Calculate expected depth of the maximum shower from energy (like in PositionCalc::Calculate_Location()):
120  // The parameters X0 and T0 are hardcoded here because these values were used to calculate the corrections:
121  const float X0 = 0.89; float T0 = 1.2;
122  //different T0 value if outside of preshower coverage
123  if (TMath::Abs(bclus.eta())<1.653) T0 = 3.1;
124 
125  double depth = X0 * (T0 + log(bclus.energy()));
126 
127  //find max energy crystal
128  std::vector< std::pair<DetId, float> > crystals_vector = bclus.hitsAndFractions();
129  float drmin = 999.;
130  EEDetId crystalseed;
131  //printf("starting loop over crystals, etot = %5f:\n",bclus.energy());
132  for (unsigned int icry=0; icry!=crystals_vector.size(); ++icry) {
133 
134  EEDetId crystal(crystals_vector[icry].first);
135 
136  const CaloCellGeometry* cell=geom->getGeometry(crystal);
137  GlobalPoint center_pos = (dynamic_cast<const TruncatedPyramid*>(cell))->getPosition(depth);
138  double EtaCentr = center_pos.eta();
139  double PhiCentr = TVector2::Phi_mpi_pi(center_pos.phi());
140 
141  float dr = reco::deltaR(Eta,Phi,EtaCentr,PhiCentr);
142  if (dr<drmin) {
143  drmin = dr;
144  crystalseed = crystal;
145  }
146 
147  }
148 
149  ix = crystalseed.ix();
150  iy = crystalseed.iy();
151 
152  // Get center cell position from shower depth
153  const CaloCellGeometry* cell=geom->getGeometry(crystalseed);
154  const TruncatedPyramid *cpyr = dynamic_cast<const TruncatedPyramid*>(cell);
155 
156  thetatilt = cpyr->getThetaAxis();
157  phitilt = cpyr->getPhiAxis();
158 
159  GlobalPoint center_pos = cpyr->getPosition(depth);
160 
161  double XCentr = center_pos.x();
162  double XWidth = 2.59;
163  xcry = (X-XCentr)/XWidth;
164 
165 
166  double YCentr = center_pos.y();
167  double YWidth = 2.59;
168  ycry = (Y-YCentr)/YWidth;
169 
170  return;
171 
172 }
const CaloSubdetectorGeometry * getSubdetectorGeometry(const DetId &id) const
access the subdetector geometry for the given subdetector directly
Definition: CaloGeometry.cc:45
const math::XYZPoint & position() const
cluster centroid position
Definition: CaloCluster.h:129
int ix() const
Definition: EEDetId.h:76
Geom::Phi< T > phi() const
Definition: PV3DBase.h:69
T y() const
Definition: PV3DBase.h:63
#define X(str)
Definition: MuonsGrabber.cc:48
const std::vector< std::pair< DetId, float > > & hitsAndFractions() const
Definition: CaloCluster.h:195
CCGFloat getPhiAxis() const
double eta() const
pseudorapidity of cluster centroid
Definition: CaloCluster.h:166
T Abs(T a)
Definition: MathUtil.h:49
auto deltaR(const T1 &t1, const T2 &t2) -> decltype(t1.eta())
Definition: deltaR.h:28
double energy() const
cluster energy
Definition: CaloCluster.h:124
int iy() const
Definition: EEDetId.h:82
CCGFloat getThetaAxis() const
const GlobalPoint getPosition(CCGFloat depth) const
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
A base class to handle the particular shape of Ecal Xtals. Taken from ORCA Calorimetry Code...
T eta() const
Definition: PV3DBase.h:76
static const double X0
T x() const
Definition: PV3DBase.h:62