30 if (minimalPhiSize_ % 2 == 0 || minimalEtaSize_ % 2 == 0)
31 edm::LogError(
"InterestingDetIdFromSuperClusterProducerError") <<
"Size of eta/phi should be odd numbers";
65 std::vector<DetId> indexToStore;
66 indexToStore.reserve(1000);
68 reco::SuperClusterCollection::const_iterator sclusIt;
70 std::vector<DetId> xtalsToStore;
71 xtalsToStore.reserve(50);
74 for (sclusIt = pClusters->begin(); sclusIt != pClusters->end(); sclusIt++) {
82 std::vector<std::pair<DetId, float> > clusterDetIds = (*clusIt)->hitsAndFractions();
83 std::vector<std::pair<DetId, float> >::iterator posCurrent;
87 for (posCurrent = clusterDetIds.begin(); posCurrent != clusterDetIds.end(); posCurrent++) {
89 if ((!((*posCurrent).first.null())) && (itt != recHitsHandle->
end()) && ((*itt).energy() >
eMax)) {
90 eMax = (*itt).energy();
101 std::vector<std::pair<DetId, float> > xtalsInClus = (*clusIt)->hitsAndFractions();
103 for (
unsigned int ii = 0;
ii < xtalsInClus.size();
ii++) {
104 xtalsToStore.push_back(xtalsInClus[
ii].
first);
107 indexToStore.insert(indexToStore.end(), xtalsToStore.begin(), xtalsToStore.end());
114 indexToStore.push_back(it->id());
118 indexToStore.push_back(it->id());
123 indexToStore.push_back(it->id());
131 if (
abs(ebid.ieta()) == 85)
132 indexToStore.push_back(it->id());
135 indexToStore.push_back(it->id());
141 std::sort(indexToStore.begin(), indexToStore.end());
142 std::unique(indexToStore.begin(), indexToStore.end());
144 auto detIdCollection = std::make_unique<DetIdCollection>(indexToStore);
T getParameter(std::string const &) const
const EcalSeverityLevelAlgo * severity_
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
void beginRun(edm::Run const &, const edm::EventSetup &) final
EcalSeverityLevel::SeverityLevel severityLevel(const DetId &id) const
Evaluate status from id use channelStatus from DB.
CaloTopology const * topology(0)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
constexpr bool null() const
is this a null id ?
std::vector< EcalRecHit >::const_iterator const_iterator
edm::EDGetTokenT< EcalRecHitCollection > recHitsToken_
def unique(seq, keepstr=True)
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum) ...
Abs< T >::type abs(const T &t)
static bool isNextToRingBoundary(EEDetId id)
void produce(edm::Event &, const edm::EventSetup &) override
producer
std::string interestingDetIdCollection_
const_iterator end() const
const CaloTopology * caloTopology_
InterestingDetIdFromSuperClusterProducer(const edm::ParameterSet &)
ctor
virtual std::vector< DetId > getWindow(const DetId &id, const int &northSouthSize, const int &eastWestSize) const
edm::EDGetTokenT< reco::SuperClusterCollection > superClustersToken_
const CaloSubdetectorTopology * getSubdetectorTopology(const DetId &id) const
access the subdetector Topology for the given subdetector directly
iterator find(key_type k)
T const * product() const
const_iterator begin() const
constexpr Detector det() const
get the detector field from this detid