CMS 3D CMS Logo

List of all members | Public Member Functions | Protected Member Functions | Protected Attributes
l1tpf_calo::Phase1GridBase Class Reference

#include <CaloClusterer.h>

Inheritance diagram for l1tpf_calo::Phase1GridBase:
l1tpf_calo::Grid l1tpf_calo::Phase1Grid l1tpf_calo::Phase2Grid

Public Member Functions

int find_cell (float eta, float phi) const override
 
int ifind_cell (int ieta, int iphi) const
 
 Phase1GridBase (int nEta, int nPhi, int ietaCoarse, int ietaVeryCoarse, const float *towerEtas)
 
- Public Member Functions inherited from l1tpf_calo::Grid
float eta (int icell) const
 
float etaWidth (int icell) const
 
int ieta (int icell) const
 
int iphi (int icell) const
 
int neighbour (int icell, unsigned int idx) const
 
float phi (int icell) const
 
float phiWidth (int icell) const
 
unsigned int size () const
 
virtual ~Grid ()
 

Protected Member Functions

int imove (int ieta, int iphi, int deta, int dphi)
 
bool valid_ieta_iphi (int ieta, int iphi) const
 
- Protected Member Functions inherited from l1tpf_calo::Grid
 Grid (unsigned int size)
 

Protected Attributes

std::vector< int > cell_map_
 
const int ietaCoarse_
 
const int ietaVeryCoarse_
 
const int nEta_
 
const int nPhi_
 
const float * towerEtas_
 
- Protected Attributes inherited from l1tpf_calo::Grid
std::vector< float > eta_
 
std::vector< float > etaWidth_
 
std::vector< int > ieta_
 
std::vector< int > iphi_
 
unsigned int ncells_
 
std::vector< std::array< int, 8 > > neighbours_
 
std::vector< float > phi_
 
std::vector< float > phiWidth_
 

Detailed Description

Definition at line 51 of file CaloClusterer.h.

Constructor & Destructor Documentation

◆ Phase1GridBase()

l1tpf_calo::Phase1GridBase::Phase1GridBase ( int  nEta,
int  nPhi,
int  ietaCoarse,
int  ietaVeryCoarse,
const float *  towerEtas 
)

Definition at line 19 of file CaloClusterer.cc.

21  : Grid(2 * ((ietaCoarse - 1) * nPhi + (ietaVeryCoarse - ietaCoarse) * (nPhi / 2) +
22  (nEta - ietaVeryCoarse + 1) * (nPhi / 4))),
23  nEta_(nEta),
24  nPhi_(nPhi),
25  ietaCoarse_(ietaCoarse),
26  ietaVeryCoarse_(ietaVeryCoarse),
27  towerEtas_(towerEtas),
28  cell_map_(2 * nEta * nPhi, -1) {
29  int icell = 0;
30  for (int ie = -nEta_; ie <= nEta_; ++ie) {
31  int absie = std::abs(ie);
32  for (int iph = 1; iph <= nPhi_; ++iph) {
33  if (!valid_ieta_iphi(ie, iph))
34  continue;
35  ieta_[icell] = ie;
36  iphi_[icell] = iph;
37  eta_[icell] = (ie > 0 ? 0.5 : -0.5) * (towerEtas_[absie - 1] + towerEtas_[absie]);
38  etaWidth_[icell] = (towerEtas_[absie] - towerEtas_[absie - 1]);
39  phiWidth_[icell] = 2 * M_PI / nPhi_;
40  if (absie >= ietaVeryCoarse_)
41  phiWidth_[icell] *= 4;
42  else if (absie >= ietaCoarse_)
43  phiWidth_[icell] *= 2;
44  phi_[icell] = (iph - 1) * 2 * M_PI / nPhi_ + 0.5 * phiWidth_[icell];
45  if (phi_[icell] > M_PI)
46  phi_[icell] -= 2 * M_PI;
47  std::fill(neighbours_[icell].begin(), neighbours_[icell].end(), -1);
48  cell_map_[(ie + nEta_) + 2 * nEta_ * (iph - 1)] = icell;
49  icell++;
50  }
51  }
52  assert(unsigned(icell) == ncells_);
53  // now link the cells
54  for (icell = 0; icell < int(ncells_); ++icell) {
55  int ie = ieta_[icell], iph = iphi_[icell];
56  int ineigh = 0;
57  for (int deta = -1; deta <= +1; ++deta) {
58  for (int dphi = -1; dphi <= +1; ++dphi) {
59  if (deta == 0 && dphi == 0)
60  continue;
61  neighbours_[icell][ineigh++] = imove(ie, iph, deta, dphi);
62  }
63  }
64  }
67  //for (float teta = 0; teta <= 5.0; teta += 0.02) {
68  // for (float tphi = -M_PI; tphi <= M_PI; tphi += 0.02) {
69  // find_cell(+teta, tphi);
70  // find_cell(-teta, tphi);
71  // }
72  //}
73 }

References funct::abs(), cms::cuda::assert(), begin, cell_map_, end, l1tpf_calo::Grid::eta_, l1tpf_calo::Grid::etaWidth_, ntuplemaker::fill, l1tpf_calo::Grid::ieta_, ietaCoarse_, ietaVeryCoarse_, imove(), createfilelist::int, l1tpf_calo::Grid::iphi_, M_PI, l1tpf_calo::Grid::ncells_, l1tpf_calo::Grid::neighbours_, nEta_, nPhi_, l1tpf_calo::Grid::phi_, l1tpf_calo::Grid::phiWidth_, towerEtas_, and valid_ieta_iphi().

Member Function Documentation

◆ find_cell()

int l1tpf_calo::Phase1GridBase::find_cell ( float  eta,
float  phi 
) const
overridevirtual

Implements l1tpf_calo::Grid.

Definition at line 75 of file CaloClusterer.cc.

75  {
76  int ieta =
78  if (ieta == nEta_)
79  return -1; // outside bounds
80  assert(ieta > 0 && ieta < nEta_);
81  if (ieta > nEta_)
82  ieta = nEta_;
83  if (eta < 0)
84  ieta = -ieta;
85  phi = reco::reduceRange(phi); // [-PI, PI]
86  if (phi < 0) // then bring to [0, 2*PI]
87  phi += 2 * M_PI;
88  int iphi = std::floor(phi * nPhi_ / (2 * M_PI));
89  if (phi >= 2 * M_PI)
90  iphi = nPhi_ - 1; // fix corner case due to roundings etc
91  assert(iphi < nPhi_);
93  iphi -= (iphi % 4);
94  else if (std::abs(ieta) >= ietaCoarse_)
95  iphi -= (iphi % 2);
96  iphi += 1;
98  //if (!valid_ieta_iphi(ieta,iphi)) {
99  // printf("Error in finding cell for eta %+7.4f phi %+7.4f, got ieta = %+3d iphi %2d which is not valid\n",
100  // eta, phi, ieta, iphi);
101  //}
103  int icell = ifind_cell(ieta, iphi);
104  assert(icell != -1);
105 
107  //if (std::abs(eta - eta_[icell]) > 0.501*etaWidth_[icell] || std::abs(deltaPhi(phi, phi_[icell])) > 0.501*phiWidth_[icell]) {
108  // printf("Mismatch in finding cell for eta %+7.4f phi %+7.4f, got ieta = %+3d iphi %2d which has eta %+7.4f +- %.4f phi %+7.4f +- %.4f ; deta = %+7.4f dphi = %+7.4f\n",
109  // eta, phi, ieta, iphi, eta_[icell], etaWidth_[icell], phi_[icell], phiWidth_[icell], eta - eta_[icell], deltaPhi(phi, phi_[icell]));
110  //}
111  //assert(std::abs(eta - eta_[icell]) <= 0.5*etaWidth_[icell]);
112  //assert(std::abs(deltaPhi(phi, phi_[icell])) <= 0.5*phiWidth_[icell]);
113  return icell;
114 }

References funct::abs(), cms::cuda::assert(), HLT_2018_cff::distance, PVValHelper::eta, LEDCalibrationChannels::ieta, LEDCalibrationChannels::iphi, cuda_std::lower_bound(), M_PI, and reco::reduceRange().

◆ ifind_cell()

int l1tpf_calo::Phase1GridBase::ifind_cell ( int  ieta,
int  iphi 
) const
inline

Definition at line 56 of file CaloClusterer.h.

56 { return cell_map_[(ieta + nEta_) + 2 * nEta_ * (iphi - 1)]; }

References cell_map_, l1tpf_calo::Grid::ieta(), l1tpf_calo::Grid::iphi(), and nEta_.

◆ imove()

int l1tpf_calo::Phase1GridBase::imove ( int  ieta,
int  iphi,
int  deta,
int  dphi 
)
protected

Definition at line 116 of file CaloClusterer.cc.

116  {
117  int ie = ieta, iph = iphi;
118  switch (deta) {
119  case -1:
120  ie = (ie == -nEta_ ? 0 : (ie == +1 ? -1 : ie - 1));
121  break;
122  case +1:
123  ie = (ie == +nEta_ ? 0 : (ie == -1 ? +1 : ie + 1));
124  break;
125  case 0:
126  break;
127  default:
128  assert(false);
129  };
130  if (ie == 0)
131  return -1;
132  switch (dphi) {
133  case -1:
134  iph = (iph == 1 ? nPhi_ : iph - 1);
135  break;
136  case +1:
137  iph = (iph == nPhi_ ? 1 : iph + 1);
138  break;
139  case 0:
140  break;
141  default:
142  assert(false);
143  };
144  if (!valid_ieta_iphi(ie, iph))
145  return -1;
146  int icell = ifind_cell(ie, iph);
147  assert(!(ie == ieta && iph == iphi));
148  assert(icell != -1);
149  assert(icell != ifind_cell(ieta, iphi));
150  return icell;
151 }

References cms::cuda::assert(), LEDCalibrationChannels::ieta, and LEDCalibrationChannels::iphi.

Referenced by Phase1GridBase().

◆ valid_ieta_iphi()

bool l1tpf_calo::Phase1GridBase::valid_ieta_iphi ( int  ieta,
int  iphi 
) const
inlineprotected

Definition at line 63 of file CaloClusterer.h.

63  {
64  if (ieta == 0 || iphi == 0)
65  return false;
66  if (std::abs(ieta) >= ietaVeryCoarse_ && (iphi % 4 != 1))
67  return false;
68  if (std::abs(ieta) >= ietaCoarse_ && (iphi % 2 != 1))
69  return false;
70  return true;
71  }

References funct::abs(), l1tpf_calo::Grid::ieta(), ietaCoarse_, ietaVeryCoarse_, and l1tpf_calo::Grid::iphi().

Referenced by Phase1GridBase().

Member Data Documentation

◆ cell_map_

std::vector<int> l1tpf_calo::Phase1GridBase::cell_map_
protected

Definition at line 61 of file CaloClusterer.h.

Referenced by ifind_cell(), and Phase1GridBase().

◆ ietaCoarse_

const int l1tpf_calo::Phase1GridBase::ietaCoarse_
protected

Definition at line 59 of file CaloClusterer.h.

Referenced by Phase1GridBase(), and valid_ieta_iphi().

◆ ietaVeryCoarse_

const int l1tpf_calo::Phase1GridBase::ietaVeryCoarse_
protected

Definition at line 59 of file CaloClusterer.h.

Referenced by Phase1GridBase(), and valid_ieta_iphi().

◆ nEta_

const int l1tpf_calo::Phase1GridBase::nEta_
protected

Definition at line 59 of file CaloClusterer.h.

Referenced by ifind_cell(), and Phase1GridBase().

◆ nPhi_

const int l1tpf_calo::Phase1GridBase::nPhi_
protected

Definition at line 59 of file CaloClusterer.h.

Referenced by Phase1GridBase().

◆ towerEtas_

const float* l1tpf_calo::Phase1GridBase::towerEtas_
protected

Definition at line 60 of file CaloClusterer.h.

Referenced by Phase1GridBase().

l1tpf_calo::Grid::neighbours_
std::vector< std::array< int, 8 > > neighbours_
Definition: CaloClusterer.h:48
l1tpf_calo::Phase1GridBase::nEta_
const int nEta_
Definition: CaloClusterer.h:59
l1tpf_calo::Phase1GridBase::towerEtas_
const float * towerEtas_
Definition: CaloClusterer.h:60
l1tpf_calo::Phase1GridBase::nPhi_
const int nPhi_
Definition: CaloClusterer.h:59
l1tpf_calo::Phase1GridBase::imove
int imove(int ieta, int iphi, int deta, int dphi)
Definition: CaloClusterer.cc:116
l1tpf_calo::Grid::ncells_
unsigned int ncells_
Definition: CaloClusterer.h:45
cms::cuda::assert
assert(be >=bs)
HLT_2018_cff.distance
distance
Definition: HLT_2018_cff.py:6417
l1tpf_calo::Grid::phi_
std::vector< float > phi_
Definition: CaloClusterer.h:46
end
#define end
Definition: vmac.h:39
l1tpf_calo::Phase1GridBase::ifind_cell
int ifind_cell(int ieta, int iphi) const
Definition: CaloClusterer.h:56
l1tpf_calo::Grid::iphi
int iphi(int icell) const
Definition: CaloClusterer.h:33
l1tpf_calo::Grid::etaWidth_
std::vector< float > etaWidth_
Definition: CaloClusterer.h:46
l1tpf_calo::Phase1GridBase::cell_map_
std::vector< int > cell_map_
Definition: CaloClusterer.h:61
l1tpf_calo::Phase1GridBase::valid_ieta_iphi
bool valid_ieta_iphi(int ieta, int iphi) const
Definition: CaloClusterer.h:63
l1tpf_calo::Grid::phi
float phi(int icell) const
Definition: CaloClusterer.h:29
l1tpf_calo::Grid::ieta_
std::vector< int > ieta_
Definition: CaloClusterer.h:47
cuda_std::lower_bound
__host__ constexpr __device__ RandomIt lower_bound(RandomIt first, RandomIt last, const T &value, Compare comp={})
Definition: cudastdAlgorithm.h:27
ntuplemaker.fill
fill
Definition: ntuplemaker.py:304
l1tpf_calo::Phase1GridBase::ietaVeryCoarse_
const int ietaVeryCoarse_
Definition: CaloClusterer.h:59
createfilelist.int
int
Definition: createfilelist.py:10
l1tpf_calo::Grid::phiWidth_
std::vector< float > phiWidth_
Definition: CaloClusterer.h:46
M_PI
#define M_PI
Definition: BXVectorInputProducer.cc:50
HLT_2018_cff.nEta
nEta
Definition: HLT_2018_cff.py:5271
l1tpf_calo::Phase1GridBase::ietaCoarse_
const int ietaCoarse_
Definition: CaloClusterer.h:59
l1tpf_calo::Grid::Grid
Grid(unsigned int size)
Definition: CaloClusterer.h:36
l1tpf_calo::Grid::eta_
std::vector< float > eta_
Definition: CaloClusterer.h:46
l1tpf_calo::Grid::ieta
int ieta(int icell) const
Definition: CaloClusterer.h:32
l1tpf_calo::Grid::iphi_
std::vector< int > iphi_
Definition: CaloClusterer.h:47
HLT_2018_cff.nPhi
nPhi
Definition: HLT_2018_cff.py:5272
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
l1tpf_calo::Grid::eta
float eta(int icell) const
Definition: CaloClusterer.h:28
begin
#define begin
Definition: vmac.h:32
reco::reduceRange
constexpr T reduceRange(T x)
Definition: deltaPhi.h:18