CMS 3D CMS Logo

List of all members | Public Member Functions
RPCMaskReClusterizer Class Reference

#include <RPCMaskReClusterizer.h>

Public Member Functions

RPCClusterContainer doAction (const RPCDetId &id, RPCClusterContainer &initClusters, const RollMask &mask) const
 
bool get (const RollMask &mask, int strip) const
 
 RPCMaskReClusterizer ()
 
 ~RPCMaskReClusterizer ()
 

Detailed Description

\Class RPCMaskReClusterizer

Author
J.C. Sanabria – UniAndes, Bogota

Definition at line 12 of file RPCMaskReClusterizer.h.

Constructor & Destructor Documentation

◆ RPCMaskReClusterizer()

RPCMaskReClusterizer::RPCMaskReClusterizer ( )
inline

Definition at line 14 of file RPCMaskReClusterizer.h.

14 {};

◆ ~RPCMaskReClusterizer()

RPCMaskReClusterizer::~RPCMaskReClusterizer ( )
inline

Definition at line 15 of file RPCMaskReClusterizer.h.

15 {};

Member Function Documentation

◆ doAction()

RPCClusterContainer RPCMaskReClusterizer::doAction ( const RPCDetId id,
RPCClusterContainer initClusters,
const RollMask mask 
) const

\Class RPCMaskReClusterizer

Author
J.C. Sanabria – UniAndes, Bogota

Definition at line 9 of file RPCMaskReClusterizer.cc.

11  {
12  RPCClusterContainer finClusters;
13  if (initClusters.empty())
14  return finClusters;
15 
16  RPCCluster prev = *initClusters.begin();
17  for (auto cl = std::next(initClusters.begin()); cl != initClusters.end(); ++cl) {
18  // Merge this cluster if it is adjacent by 1 masked strip
19  // Note that the RPCClusterContainer collection is sorted in DECREASING ORDER of strip #
20  // So the prev. cluster is placed after the current cluster (check the < operator of RPCCluster carefully)
21  if ((prev.firstStrip() - cl->lastStrip()) == 2 and this->get(mask, cl->lastStrip() + 1) and prev.bx() == cl->bx()) {
22  RPCCluster merged(cl->firstStrip(), prev.lastStrip(), cl->bx());
23  prev = merged;
24  } else {
25  finClusters.insert(prev);
26  prev = *cl;
27  }
28  }
29 
30  // Finalize by putting the last cluster to the collection
31  finClusters.insert(prev);
32 
33  return finClusters;
34 }

References RPCCluster::bx(), GetRecoTauVFromDQM_MC_cff::cl, RPCCluster::firstStrip(), get(), RPCCluster::lastStrip(), and GetRecoTauVFromDQM_MC_cff::next.

Referenced by RPCRecHitBaseAlgo::reconstruct().

◆ get()

bool RPCMaskReClusterizer::get ( const RollMask mask,
int  strip 
) const
RPCCluster::firstStrip
int firstStrip() const
Definition: RPCCluster.cc:16
RPCClusterContainer
std::set< RPCCluster > RPCClusterContainer
Definition: RPCClusterContainer.h:4
digitizers_cfi.strip
strip
Definition: digitizers_cfi.py:19
GetRecoTauVFromDQM_MC_cff.cl
cl
Definition: GetRecoTauVFromDQM_MC_cff.py:38
RPCCluster::bx
int bx() const
Definition: RPCCluster.cc:19
RPCCluster::lastStrip
int lastStrip() const
Definition: RPCCluster.cc:17
RPCCluster
Definition: RPCCluster.h:4
RPCMaskReClusterizer::get
bool get(const RollMask &mask, int strip) const
Definition: RPCMaskReClusterizer.cc:36
GetRecoTauVFromDQM_MC_cff.next
next
Definition: GetRecoTauVFromDQM_MC_cff.py:31