51 endcapSClusterToken_ =
60 produces< reco::PreshowerClusterCollection >(preshClusterCollectionX_);
61 produces< reco::PreshowerClusterCollection >(preshClusterCollectionY_);
62 produces< reco::SuperClusterCollection >(assocSClusterCollection_);
64 float esStripECut = ps.
getParameter<
double>(
"esStripEnergyCut");
65 esPhiClusterDeltaEta_ = ps.
getParameter<
double>(
"esPhiClusterDeltaEta");
66 esPhiClusterDeltaPhi_ = ps.
getParameter<
double>(
"esPhiClusterDeltaPhi");
93 auto clusters_p1 = std::make_unique<reco::PreshowerClusterCollection>();
94 auto clusters_p2 = std::make_unique<reco::PreshowerClusterCollection>();
96 auto superclusters_p = std::make_unique<reco::SuperClusterCollection>();
103 evt.
getByToken(endcapSClusterToken_, pSuperClusters);
111 LogTrace(
"EcalClusters") <<
"PreshowerPhiClusterProducerInfo: ### Total # of preshower RecHits: "<< rechits->
size();
114 std::map<DetId, EcalRecHit> rechits_map;
116 for (it = rechits->
begin(); it != rechits->
end(); it++) {
118 if (it->recoFlag()==1 || it->recoFlag()==14 || (it->recoFlag()<=10 && it->recoFlag()>=5))
continue;
120 rechits_map.insert(std::make_pair(it->id(), *it));
123 std::set<DetId> used_strips;
125 LogTrace(
"EcalClusters") <<
"PreshowerPhiClusterProducerInfo: ### rechits_map of size " << rechits_map.size() <<
" was created!";
131 reco::SuperClusterCollection::const_iterator it_super;
133 for (it_super=SClusts->begin(); it_super!=SClusts->end(); ++it_super) {
141 LogTrace(
"EcalClusters")<<
" superE = " << it_super->energy() <<
" superETA = " << it_super->eta() <<
" superPHI = " << it_super->phi() ;
154 for ( ; bc_iter !=it_super->clustersEnd(); ++bc_iter) {
156 refPhi = (*bc_iter)->phi();
167 maxDeltaPhi += esPhiClusterDeltaPhi_;
168 minDeltaPhi -= esPhiClusterDeltaPhi_;
171 for (bc_iter = it_super->clustersBegin() ; bc_iter !=it_super->clustersEnd(); ++bc_iter) {
175 double X = (*bc_iter)->x();
176 double Y = (*bc_iter)->y();
177 double Z = (*bc_iter)->z();
189 if (status_p1->getStatusCode() == 1) condP1 = 0;
190 if (status_p2->getStatusCode() == 1) condP2 = 0;
191 }
else if (strip1 ==
ESDetId(0)) {
193 }
else if (strip2 ==
ESDetId(0)) {
200 reco::PreshowerCluster cl1 = presh_algo->makeOneCluster(strip1,&used_strips,&rechits_map,geometry_p,topology_p,esPhiClusterDeltaEta_,minDeltaPhi,maxDeltaPhi);
202 clusters1.push_back(cl1);
206 reco::PreshowerCluster cl2 = presh_algo->makeOneCluster(strip2,&used_strips,&rechits_map,geometry_p,topology_p,esPhiClusterDeltaEta_,minDeltaPhi,maxDeltaPhi);
208 clusters2.push_back(cl2);
217 LogTrace(
"EcalClusters") <<
" For SC #" << isc-1 <<
", containing " 218 << it_super->clustersSize()
219 <<
" basic clusters, PreshowerPhiClusterAlgo made " 220 << clusters1.size() <<
" in X plane and " 222 <<
" in Y plane " <<
" preshower clusters " ;
225 if(e1+e2 > 1.0
e-10) {
230 if (condP1 == 1 && condP2 == 1) {
231 deltaE = gamma0_*(e1 + alpha0_*e2);
232 }
else if (condP1 == 1 && condP2 == 0) {
233 deltaE = gamma1_*(e1 + alpha1_*e2);
234 }
else if (condP1 == 0 && condP2 == 1) {
235 deltaE = gamma2_*(e1 + alpha2_*e2);
236 }
else if (condP1 == 0 && condP2 == 0) {
237 deltaE = gamma3_*(e1 + alpha3_*e2);
242 float E = it_super->energy() + deltaE;
244 LogTrace(
"EcalClusters") <<
" Creating corrected SC ";
247 sc.setPreshowerEnergyPlane1(e1*mip_);
248 sc.setPreshowerEnergyPlane2(e2*mip_);
249 if (condP1 == 1 && condP2 == 1)
sc.setPreshowerPlanesStatus(0);
250 else if (condP1 == 1 && condP2 == 0)
sc.setPreshowerPlanesStatus(1);
251 else if (condP1 == 0 && condP2 == 1)
sc.setPreshowerPlanesStatus(2);
252 else if (condP1 == 0 && condP2 == 0)
sc.setPreshowerPlanesStatus(3);
256 new_SC.push_back(
sc);
258 new_SC.push_back(
sc);
264 clusters_p1->assign(clusters1.begin(), clusters1.end());
265 clusters_p2->assign(clusters2.begin(), clusters2.end());
267 evt.
put(
std::move(clusters_p1), preshClusterCollectionX_ );
268 evt.
put(
std::move(clusters_p2), preshClusterCollectionY_ );
269 LogTrace(
"EcalClusters") <<
"Preshower clusters added to the event" ;
272 superclusters_p->assign(new_SC.begin(), new_SC.end());
273 evt.
put(
std::move(superclusters_p), assocSClusterCollection_);
274 LogTrace(
"EcalClusters") <<
"Corrected SClusters added to the event" ;
276 if (topology_p)
delete topology_p;
297 gamma0_ = (ESGain == 1) ? 0.02 : esEEInterCalib->
getGammaHigh0();
309 gamma3_ = (ESGain == 1) ? 0.02 : esEEInterCalib->
getGammaHigh3();
constexpr double deltaPhi(double phi1, double phi2)
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
void set(const edm::EventSetup &es)
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
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
void produce(edm::Event &evt, const edm::EventSetup &es) override
~PreshowerPhiClusterProducer() override
T const * product() const
float getAlphaHigh0() const
float getAlphaLow3() const
float getAlphaHigh2() const
float getAlphaLow2() const
std::vector< Item >::const_iterator const_iterator
float getGammaLow1() const
float getAlphaHigh1() const
float getConstBEta3() const
float getGammaHigh0() const
float getAlphaLow1() const
float getESValueHigh() const
PreshowerPhiClusterProducer(const edm::ParameterSet &ps)
*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