test
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 Member Functions | Private Attributes
HBHEHitMapOrganizer Class Reference

#include <HBHEIsolatedNoiseAlgos.h>

Public Member Functions

void getDiHits (std::vector< HBHEHitMap > &v, double energy) const
 
void getHPDs (std::vector< HBHEHitMap > &v, double energy) const
 
void getMonoHits (std::vector< HBHEHitMap > &v, double energy) const
 
void getRBXs (std::vector< HBHEHitMap > &v, double energy) const
 
 HBHEHitMapOrganizer (const edm::Handle< HBHERecHitCollection > &hbhehitcoll_h, const ObjectValidatorAbs &objvalidator, const PhysicsTowerOrganizer &pto, const HcalFrontEndMap *hfemap)
 
virtual ~HBHEHitMapOrganizer ()
 

Private Member Functions

void getHPDNeighbors (const HBHERecHit *hit, std::vector< const HBHERecHit * > &neighbors, const PhysicsTowerOrganizer &pto)
 

Private Attributes

std::vector< HBHEHitMapdihits_
 
const HcalFrontEndMaphfemap_
 
std::map< int, HBHEHitMaphpds_
 
std::vector< HBHEHitMapmonohits_
 
std::map< int, HBHEHitMaprbxs_
 

Detailed Description

Definition at line 333 of file HBHEIsolatedNoiseAlgos.h.

Constructor & Destructor Documentation

HBHEHitMapOrganizer::HBHEHitMapOrganizer ( const edm::Handle< HBHERecHitCollection > &  hbhehitcoll_h,
const ObjectValidatorAbs objvalidator,
const PhysicsTowerOrganizer pto,
const HcalFrontEndMap hfemap 
)

Definition at line 710 of file HBHEIsolatedNoiseAlgos.cc.

References dihits_, CaloRecHit::energy(), PhysicsTowerOrganizer::findNeighbors(), PhysicsTowerOrganizer::findTower(), getHPDNeighbors(), hfemap_, hpds_, HBHERecHit::id(), HcalDetId::ieta(), HBHEHitMap::insert(), HcalDetId::iphi(), HcalFrontEndMap::lookupRBXIndex(), HcalFrontEndMap::lookupRMIndex(), monohits_, rbxs_, and ObjectValidatorAbs::validHit().

714  : hfemap_(hfemap)
715 {
716  // loop over the hits
717  for(HBHERecHitCollection::const_iterator it=hbhehitcoll_h->begin(); it!=hbhehitcoll_h->end(); ++it) {
718  const HBHERecHit *hit=&(*it);
719  if(!objvalidator.validHit(*hit)) continue;
720 
721  // get the Physics Tower and the neighbors
722  const PhysicsTower* tower=pto.findTower(hit->id().ieta(), hit->id().iphi());
723 
724  std::set<const PhysicsTower*> neighbors;
725  pto.findNeighbors(hit->id().ieta(), hit->id().iphi(), neighbors);
726 
727  // organize the RBXs
728  int rbxidnum = hfemap_->lookupRBXIndex(hit->id());
729  rbxs_[rbxidnum].insert(hit, tower, neighbors);
730 
731  // organize the HPDs
732  int hpdidnum = hfemap_->lookupRMIndex(hit->id());
733  hpds_[hpdidnum].insert(hit, tower, neighbors);
734 
735 
736  // organize the dihits
737  std::vector<const HBHERecHit*> hpdneighbors;
738  getHPDNeighbors(hit, hpdneighbors, pto);
739 
740  if(hpdneighbors.size()==1) {
741  std::vector<const HBHERecHit*> hpdneighborsneighbors;
742  getHPDNeighbors(hpdneighbors[0], hpdneighborsneighbors, pto);
743 
744  if(hpdneighborsneighbors.size()==1 && hpdneighborsneighbors[0]==hit && hit->energy()>hpdneighbors[0]->energy()) {
745  // we've found two hits who are neighbors in the same HPD, but who have no other
746  // neighbors (in the same HPD) in common. In order not to double-count, we
747  // require that the first hit has more energy
748 
749  const PhysicsTower* tower2=pto.findTower(hpdneighbors[0]->id().ieta(), hpdneighbors[0]->id().iphi());
750  std::set<const PhysicsTower*> neighbors2;
751  pto.findNeighbors(hpdneighbors[0]->id().ieta(), hpdneighbors[0]->id().iphi(), neighbors2);
752 
753  HBHEHitMap dihit;
754  dihit.insert(hit, tower, neighbors);
755  dihit.insert(hpdneighbors[0], tower2, neighbors2);
756  dihits_.push_back(dihit);
757  }
758  } else if(hpdneighbors.size()==0) {
759 
760  // organize the monohits
761  HBHEHitMap monohit;
762  monohit.insert(hit, tower, neighbors);
763  monohits_.push_back(monohit);
764  }
765 
766  } // finished looping over HBHERecHits
767  return;
768 }
void getHPDNeighbors(const HBHERecHit *hit, std::vector< const HBHERecHit * > &neighbors, const PhysicsTowerOrganizer &pto)
std::vector< HBHEHitMap > dihits_
HcalDetId id() const
get the id
Definition: HBHERecHit.h:23
const int lookupRMIndex(DetId fId) const
std::vector< HBHERecHit >::const_iterator const_iterator
void insert(const HBHERecHit *hit, const PhysicsTower *twr, std::set< const PhysicsTower * > &neighbors)
const PhysicsTower * findTower(const CaloTowerDetId &id) const
const int lookupRBXIndex(DetId fId) const
std::map< int, HBHEHitMap > rbxs_
float energy() const
Definition: CaloRecHit.h:17
int ieta() const
get the cell ieta
Definition: HcalDetId.h:56
std::map< int, HBHEHitMap > hpds_
int iphi() const
get the cell iphi
Definition: HcalDetId.cc:103
virtual bool validHit(const HBHERecHit &) const =0
std::vector< HBHEHitMap > monohits_
const HcalFrontEndMap * hfemap_
void findNeighbors(const CaloTowerDetId &id, std::set< const PhysicsTower * > &neighbors) const
virtual HBHEHitMapOrganizer::~HBHEHitMapOrganizer ( )
inlinevirtual

Definition at line 341 of file HBHEIsolatedNoiseAlgos.h.

341 {}

Member Function Documentation

void HBHEHitMapOrganizer::getDiHits ( std::vector< HBHEHitMap > &  v,
double  energy 
) const

Definition at line 788 of file HBHEIsolatedNoiseAlgos.cc.

References dihits_, and relval_parameters_module::energy.

Referenced by HBHEIsolatedNoiseReflagger::produce().

789 {
790  for(std::vector<HBHEHitMap>::const_iterator it=dihits_.begin(); it!=dihits_.end(); ++it) {
791  if(it->hitEnergy()>energy) v.push_back(*it);
792  }
793  return;
794 }
std::vector< HBHEHitMap > dihits_
void HBHEHitMapOrganizer::getHPDNeighbors ( const HBHERecHit hit,
std::vector< const HBHERecHit * > &  neighbors,
const PhysicsTowerOrganizer pto 
)
private

Definition at line 806 of file HBHEIsolatedNoiseAlgos.cc.

References PhysicsTowerOrganizer::findNeighbors(), PhysicsTowerOrganizer::findTower(), hfemap_, HBHERecHit::id(), HcalDetId::ieta(), HcalDetId::iphi(), HcalFrontEndMap::lookupRMIndex(), and groupFilesInBlocks::temp.

Referenced by HBHEHitMapOrganizer().

807 {
808  std::set<const PhysicsTower*> temp;
809  pto.findNeighbors(hit->id().ieta(), hit->id().iphi(), temp);
810 
811  // make sure to include the same tower that the hit is in
812  temp.insert(pto.findTower(hit->id().ieta(), hit->id().iphi()));
813 
814  // loop over the rechits in the temp neighbors
815  for(std::set<const PhysicsTower*>::const_iterator it1=temp.begin(); it1!=temp.end(); ++it1) {
816  for(std::set<const HBHERecHit*>::const_iterator it2=(*it1)->hcalhits.begin(); it2!=(*it1)->hcalhits.end(); ++it2) {
817  const HBHERecHit* hit2(*it2);
818  if(hit!=hit2 && hfemap_->lookupRMIndex(hit->id())==hfemap_->lookupRMIndex(hit2->id())) {
819  neighbors.push_back(hit2);
820  }
821  }
822  }
823  return;
824 }
HcalDetId id() const
get the id
Definition: HBHERecHit.h:23
const int lookupRMIndex(DetId fId) const
const PhysicsTower * findTower(const CaloTowerDetId &id) const
int ieta() const
get the cell ieta
Definition: HcalDetId.h:56
int iphi() const
get the cell iphi
Definition: HcalDetId.cc:103
const HcalFrontEndMap * hfemap_
void findNeighbors(const CaloTowerDetId &id, std::set< const PhysicsTower * > &neighbors) const
void HBHEHitMapOrganizer::getHPDs ( std::vector< HBHEHitMap > &  v,
double  energy 
) const

Definition at line 779 of file HBHEIsolatedNoiseAlgos.cc.

References relval_parameters_module::energy, HBHEHitMap::hitEnergy(), and hpds_.

Referenced by HBHEIsolatedNoiseReflagger::produce().

780 {
781  for(std::map<int, HBHEHitMap>::const_iterator it=hpds_.begin(); it!=hpds_.end(); ++it) {
782  const HBHEHitMap &map=it->second;
783  if(map.hitEnergy()>energy) v.push_back(map);
784  }
785  return;
786 }
std::map< int, HBHEHitMap > hpds_
double hitEnergy(void) const
void HBHEHitMapOrganizer::getMonoHits ( std::vector< HBHEHitMap > &  v,
double  energy 
) const

Definition at line 796 of file HBHEIsolatedNoiseAlgos.cc.

References relval_parameters_module::energy, and monohits_.

Referenced by HBHEIsolatedNoiseReflagger::produce().

797 {
798  for(std::vector<HBHEHitMap>::const_iterator it=monohits_.begin(); it!=monohits_.end(); ++it) {
799  if(it->hitEnergy()>energy) v.push_back(*it);
800  }
801  return;
802 }
std::vector< HBHEHitMap > monohits_
void HBHEHitMapOrganizer::getRBXs ( std::vector< HBHEHitMap > &  v,
double  energy 
) const

Definition at line 770 of file HBHEIsolatedNoiseAlgos.cc.

References relval_parameters_module::energy, HBHEHitMap::hitEnergy(), and rbxs_.

Referenced by HBHEIsolatedNoiseReflagger::produce().

771 {
772  for(std::map<int, HBHEHitMap>::const_iterator it=rbxs_.begin(); it!=rbxs_.end(); ++it) {
773  const HBHEHitMap &map=it->second;
774  if(map.hitEnergy()>energy) v.push_back(map);
775  }
776  return;
777 }
std::map< int, HBHEHitMap > rbxs_
double hitEnergy(void) const

Member Data Documentation

std::vector<HBHEHitMap> HBHEHitMapOrganizer::dihits_
private

Definition at line 352 of file HBHEIsolatedNoiseAlgos.h.

Referenced by getDiHits(), and HBHEHitMapOrganizer().

const HcalFrontEndMap* HBHEHitMapOrganizer::hfemap_
private

Definition at line 350 of file HBHEIsolatedNoiseAlgos.h.

Referenced by getHPDNeighbors(), and HBHEHitMapOrganizer().

std::map<int, HBHEHitMap> HBHEHitMapOrganizer::hpds_
private

Definition at line 351 of file HBHEIsolatedNoiseAlgos.h.

Referenced by getHPDs(), and HBHEHitMapOrganizer().

std::vector<HBHEHitMap> HBHEHitMapOrganizer::monohits_
private

Definition at line 352 of file HBHEIsolatedNoiseAlgos.h.

Referenced by getMonoHits(), and HBHEHitMapOrganizer().

std::map<int, HBHEHitMap> HBHEHitMapOrganizer::rbxs_
private

Definition at line 351 of file HBHEIsolatedNoiseAlgos.h.

Referenced by getRBXs(), and HBHEHitMapOrganizer().