110 using namespace reco;
124 if(it->pt() > 40 && fabs(it->eta()) < 1.6)
128 selectedJets.push_back(*ca);
146 float lengthBmodule=6.66;
147 std::vector<float> zProjections;
148 for(CaloJetCollection::const_iterator jit = selectedJets.begin() ; jit != selectedJets.end() ; jit++)
155 float jetZOverRho = jit->momentum().Z()/jit->momentum().Rho();
156 int minSizeY = fabs(2.*jetZOverRho)-1;
157 int maxSizeY = fabs(2.*jetZOverRho)+2;
158 if( fabs(jit->eta()) > 1.6)
165 DetId id = it->detId();
168 float zmodule = modulepos.
z() - ((modulepos.
x()-
beamSpot->x0())*px+(modulepos.
y()-
beamSpot->y0())*py)/pt * pz/pt;
171 for(
size_t j = 0 ;
j < detset.
size() ;
j ++)
175 Point3DBase<float, GlobalTag> v = trackerGeometry->idToDet(
id)->surface().toGlobal(
pp->localParametersV( aCluster,( *trackerGeometry->idToDetUnit(
id)))[0].first) ;
182 zProjections.push_back(z);
191 std::sort(zProjections.begin(),zProjections.end());
193 std::vector<float>::iterator itCenter = zProjections.begin();
194 std::vector<float>::iterator itLeftSide = zProjections.begin();
195 std::vector<float>::iterator itRightSide = zProjections.begin();
196 std::vector<int> counts;
199 std::vector<float>::iterator left,right;
200 for(;itCenter!=zProjections.end(); itCenter++)
203 while(itLeftSide != zProjections.end() && (*itCenter - *itLeftSide) > zCluster ) itLeftSide++;
204 while(itRightSide != zProjections.end() && (*itRightSide - *itCenter) < zCluster ) itRightSide++;
206 int n= itRightSide-itLeftSide;
224 if(zProjections.size() > 0)
226 res=*(left+(right-left)/2);
229 e(0, 0) = 0.0015 * 0.0015;
230 e(1, 1) = 0.0015 * 0.0015;
235 pOut->push_back(thePV);
242 e(0, 0) = 0.0015 * 0.0015;
243 e(1, 1) = 0.0015 * 0.0015;
248 pOut->push_back(thePV);
boost::indirect_iterator< typename seq_t::const_iterator > const_iterator
boost::transform_iterator< IterHelp, const_IdIter > const_iterator
Jets made from CaloTowers.
Geom::Phi< T > phi() const
math::Error< dimension >::type Error
covariance error matrix (3x3)
std::vector< Vertex > VertexCollection
collection of Vertex objects
const T & max(const T &a, const T &b)
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
math::XYZPoint Point
point in the space
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Pixel cluster – collection of neighboring pixels above threshold.
std::vector< CaloJet > CaloJetCollection
collection of CaloJet objects