55 endcapSClusterToken_ =
67 produces< reco::PreshowerClusterCollection >(preshClusterCollectionX_);
68 produces< reco::PreshowerClusterCollection >(preshClusterCollectionY_);
69 produces< reco::SuperClusterCollection >(assocSClusterCollection_);
71 float preshStripECut = ps.
getParameter<
double>(
"preshStripEnergyCut");
72 int preshSeededNst = ps.
getParameter<
int>(
"preshSeededNstrip");
73 preshClustECut = ps.
getParameter<
double>(
"preshClusterEnergyCut");
102 auto clusters_p1 = std::make_unique<reco::PreshowerClusterCollection>();
103 auto clusters_p2 = std::make_unique<reco::PreshowerClusterCollection>();
105 auto superclusters_p = std::make_unique<reco::SuperClusterCollection>();
112 evt.
getByToken(endcapSClusterToken_, pSuperClusters);
120 LogTrace(
"EcalClusters") <<
"PreshowerClusterProducerInfo: ### Total # of preshower RecHits: "<< rechits->
size();
123 std::map<DetId, EcalRecHit> rechits_map;
125 for (it = rechits->
begin(); it != rechits->
end(); it++) {
127 if (it->recoFlag()==1 || it->recoFlag()==14 || (it->recoFlag()<=10 && it->recoFlag()>=5))
continue;
129 rechits_map.insert(std::make_pair(it->id(), *it));
132 std::set<DetId> used_strips;
134 LogTrace(
"EcalClusters") <<
"PreshowerClusterProducerInfo: ### rechits_map of size " << rechits_map.size() <<
" was created!";
141 reco::SuperClusterCollection::const_iterator it_super;
143 for (it_super=SClusts->begin(); it_super!=SClusts->end(); ++it_super) {
151 LogTrace(
"EcalClusters")<<
" superE = " << it_super->energy() <<
" superETA = " << it_super->eta() <<
" superPHI = " << it_super->phi() ;
157 for ( ; bc_iter !=it_super->clustersEnd(); ++bc_iter ) {
161 double X = (*bc_iter)->x();
162 double Y = (*bc_iter)->y();
163 double Z = (*bc_iter)->z();
175 if (status_p1->getStatusCode() == 1) condP1 = 0;
176 if (status_p2->getStatusCode() == 1) condP2 = 0;
177 }
else if (strip1 ==
ESDetId(0))
184 for (
int i=0;
i<preshNclust_;
i++) {
185 reco::PreshowerCluster cl1 = presh_algo->makeOneCluster(strip1,&used_strips,&rechits_map,geometry_p,topology_p);
187 if (cl1.
energy() > preshClustECut) {
188 clusters1.push_back(cl1);
194 if ( cl2.
energy() > preshClustECut) {
195 clusters2.push_back(cl2);
205 LogTrace(
"EcalClusters") <<
" For SC #" << isc-1 <<
", containing " 206 << it_super->clustersSize()
207 <<
" basic clusters, PreshowerClusterAlgo made " 208 << clusters1.size() <<
" in X plane and " 210 <<
" in Y plane " <<
" preshower clusters " ;
213 if(e1+e2 > 1.0
e-10) {
218 if (condP1 == 1 && condP2 == 1) {
219 deltaE = gamma0_*(e1 + alpha0_*
e2);
220 }
else if (condP1 == 1 && condP2 == 0) {
221 deltaE = gamma1_*(e1 + alpha1_*
e2);
222 }
else if (condP1 == 0 && condP2 == 1) {
223 deltaE = gamma2_*(e1 + alpha2_*
e2);
224 }
else if (condP1 == 0 && condP2 == 0) {
225 deltaE = gamma3_*(e1 + alpha3_*
e2);
230 float E = it_super->energy() + deltaE;
232 LogTrace(
"EcalClusters") <<
" Creating corrected SC ";
235 if (condP1 == 1 && condP2 == 1)
sc.setPreshowerPlanesStatus(0);
236 else if (condP1 == 1 && condP2 == 0)
sc.setPreshowerPlanesStatus(1);
237 else if (condP1 == 0 && condP2 == 1)
sc.setPreshowerPlanesStatus(2);
238 else if (condP1 == 0 && condP2 == 0)
sc.setPreshowerPlanesStatus(3);
241 new_SC.push_back(
sc);
242 LogTrace(
"EcalClusters") <<
" SuperClusters energies: new E = " <<
sc.
energy() <<
" vs. old E =" << it_super->energy();
247 clusters_p1->assign(clusters1.begin(), clusters1.end());
248 clusters_p2->assign(clusters2.begin(), clusters2.end());
250 evt.
put(
std::move(clusters_p1), preshClusterCollectionX_);
251 evt.
put(
std::move(clusters_p2), preshClusterCollectionY_);
252 LogTrace(
"EcalClusters") <<
"Preshower clusters added to the event" ;
255 superclusters_p->assign(new_SC.begin(), new_SC.end());
256 evt.
put(
std::move(superclusters_p), assocSClusterCollection_);
257 LogTrace(
"EcalClusters") <<
"Corrected SClusters added to the event" ;
284 gamma0_ = (ESGain == 1) ? 0.02 : esEEInterCalib->
getGammaHigh0();
296 gamma3_ = (ESGain == 1) ? 0.02 : esEEInterCalib->
getGammaHigh3();
T getParameter(std::string const &) const
const CaloSubdetectorGeometry * getSubdetectorGeometry(const DetId &id) const
access the subdetector geometry for the given subdetector directly
float getConstAEta1() const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
bool getByToken(EDGetToken token, Handle< PROD > &result) const
void push_back(Ptr< T > const &iPtr)
const self & getMap() const
float getESValueLow() const
Sin< T >::type sin(const T &t)
float getConstAEta2() const
std::vector< EcalRecHit >::const_iterator const_iterator
float getGammaLow2() const
float getAlphaHigh3() const
float getGammaHigh2() const
float getConstAEta0() const
std::vector< SuperCluster > SuperClusterCollection
collection of SuperCluser objectr
void setBCRef(const CaloClusterPtr &r)
DetIds of component RecHits – now inherited from CaloCluster.
const_iterator find(uint32_t rawId) const
~PreshowerClusterProducer()
float energy() const
Energy. Note this is taken from the first SimTrack only.
float getConstBEta0() const
std::vector< PreshowerCluster > PreshowerClusterCollection
collection of PreshowerCluster objects
double energy() const
cluster energy
float getConstBEta2() const
float getConstAEta3() const
float getGammaHigh3() const
float theta() const
Momentum polar angle. Note this is taken from the first SimTrack only.
float getConstBEta1() const
float getGammaHigh1() const
const_iterator end() const
virtual void produce(edm::Event &evt, const edm::EventSetup &es)
T const * product() const
float getAlphaHigh0() const
float getAlphaLow3() const
float getAlphaHigh2() const
PreshowerClusterProducer(const edm::ParameterSet &ps)
void set(const edm::EventSetup &es)
float getAlphaLow2() const
std::vector< Item >::const_iterator const_iterator
float getGammaLow1() const
float getAlphaHigh1() const
ESHandle< TrackerGeometry > geometry
float getConstBEta3() const
float getGammaHigh0() const
float getAlphaLow1() const
float getESValueHigh() const
*vegas h *****************************************************used in the default bin number in original ***version of VEGAS is ***a higher bin number might help to derive a more precise ***grade subtle point
float getAlphaLow0() const
const_iterator begin() const