104 const auto& orig = origin.first;
106 LogDebug(
"AreaSeededTrackingRegionsProducer") <<
"Origin x,y,z " << orig.x() <<
"," << orig.y() <<
"," << orig.z();
108 auto vecFromOrigPlusRadius = [&](
const std::array<float, 2>& vec) {
111 return std::array<float, 2>{{vec[0] *
tmp, vec[1] * tmp}};
113 auto tangentVec = [&](
const std::array<float, 2>& vec,
int sign) {
118 const auto orthvec =
sign > 0 ? std::array<float, 2>{{-vec[1] *
tmp, vec[0] * tmp}}
119 : std::array<float, 2>{{vec[1] *
tmp, -vec[0] * tmp}};
120 return std::array<float, 2>{{vec[0] - orthvec[0], vec[1] - orthvec[1]}};
123 for (
const auto& area : areas) {
126 LogTrace(
"AreaSeededTrackingRegionsBuilder")
127 <<
" area x,y points " << area.x_rmin_phimin() <<
"," << area.y_rmin_phimin() <<
" "
128 << area.x_rmin_phimax() <<
"," << area.y_rmin_phimax() <<
" " << area.x_rmax_phimax() <<
","
129 << area.y_rmax_phimax() <<
" " << area.x_rmax_phimin() <<
"," << area.y_rmax_phimin() <<
" "
130 <<
"z " << area.zmin() <<
"," << area.zmax();
133 const float x_rmin_phimin = area.x_rmin_phimin() - orig.x();
134 const float x_rmin_phimax = area.x_rmin_phimax() - orig.x();
135 const float y_rmin_phimin = area.y_rmin_phimin() - orig.y();
136 const float y_rmin_phimax = area.y_rmin_phimax() - orig.y();
138 const std::array<float, 2> p_rmin_phimin = {{x_rmin_phimin, y_rmin_phimin}};
139 const std::array<float, 2> p_rmin_phimax = {{x_rmin_phimax, y_rmin_phimax}};
140 const std::array<float, 2> p_rmax_phimin = {{area.x_rmax_phimin() - orig.x(), area.y_rmax_phimin() - orig.y()}};
141 const std::array<float, 2> p_rmax_phimax = {{area.x_rmax_phimax() - orig.x(), area.y_rmax_phimax() - orig.y()}};
148 const std::array<float, 2> p_rmin =
perp2(p_rmin_phimin) <
perp2(p_rmin_phimax) ? p_rmin_phimin : p_rmin_phimax;
149 const std::array<float, 2> p_rmax =
perp2(p_rmax_phimin) >
perp2(p_rmax_phimax) ? p_rmax_phimin : p_rmax_phimax;
154 const auto p_min = vecFromOrigPlusRadius(p_rmin);
155 const auto p_max = vecFromOrigPlusRadius(p_rmax);
158 const auto etamin =
std::min(etaFromXYZ(p_min[0], p_min[1], area.zmin() - (orig.z() + origin.second)),
159 etaFromXYZ(p_max[0], p_max[1], area.zmin() - (orig.z() + origin.second)));
160 const auto etamax =
std::max(etaFromXYZ(p_min[0], p_min[1], area.zmax() - (orig.z() - origin.second)),
161 etaFromXYZ(p_max[0], p_max[1], area.zmax() - (orig.z() - origin.second)));
163 LogTrace(
"AreaSeededTrackingRegionBuilder") <<
" eta min,max " << etamin <<
"," << etamax;
189 const auto phi_ref = std::atan2(y_rmin_phimin + y_rmin_phimax, x_rmin_phimin + x_rmin_phimax);
192 const auto tan_rmin_phimax = tangentVec(p_rmin_phimax, +1);
193 const auto tan_rmax_phimax = tangentVec(p_rmax_phimax, +1);
194 const auto phi_rmin_phimax = std::atan2(tan_rmin_phimax[1], tan_rmin_phimax[0]);
195 const auto phi_rmax_phimax = std::atan2(tan_rmax_phimax[1], tan_rmax_phimax[0]);
202 LogTrace(
"AreaSeededTrackingRegionBuilder")
203 <<
" rmin_phimax vec " << p_rmin_phimax[0] <<
"," << p_rmin_phimax[1] <<
" tangent " << tan_rmin_phimax[0]
204 <<
"," << tan_rmin_phimax[1] <<
" phi " << phi_rmin_phimax <<
"\n"
205 <<
" rmax_phimax vec " << p_rmax_phimax[0] <<
"," << p_rmax_phimax[1] <<
" tangent " << tan_rmax_phimax[0]
206 <<
"," << tan_rmax_phimax[1] <<
" phi " << phi_rmax_phimax <<
"\n"
210 const auto tan_rmin_phimin = tangentVec(p_rmin_phimin, -1);
211 const auto tan_rmax_phimin = tangentVec(p_rmax_phimin, -1);
212 const auto phi_rmin_phimin = std::atan2(tan_rmin_phimin[1], tan_rmin_phimin[0]);
213 const auto phi_rmax_phimin = std::atan2(tan_rmax_phimin[1], tan_rmax_phimin[0]);
220 LogTrace(
"AreaSeededTrackingRegionBuilder")
221 <<
" rmin_phimin vec " << p_rmin_phimin[0] <<
"," << p_rmin_phimin[1] <<
" tangent " << tan_rmin_phimin[0]
222 <<
"," << tan_rmin_phimin[1] <<
" phi " << phi_rmin_phimin <<
"\n"
223 <<
" rmax_phimin vec " << p_rmax_phimin[0] <<
"," << p_rmax_phimin[1] <<
" tangent " << tan_rmax_phimin[0]
224 <<
"," << tan_rmax_phimin[1] <<
" phi " << phi_rmax_phimin <<
"\n"
228 if (phimax < phimin) {
235 LogTrace(
"AreaSeededTrackingRegionBuilder") <<
" phi min,max " << phimin <<
"," <<
phimax;
241 LogTrace(
"AreaSeededTrackingRegionBuilder")
242 <<
" windows after this area eta " << minEta <<
"," <<
maxEta <<
" phi " << minPhi <<
"," <<
maxPhi;
245 const auto meanEta = (minEta +
maxEta) / 2.
f;
246 const auto meanPhi = (minPhi +
maxPhi) / 2.
f;
250 auto useCandidates =
false;
252 useCandidates =
true;
256 for (
const auto&
object : *
candidates.first) {
259 float eta_Cand =
object.eta();
260 float phi_Cand =
object.phi();
261 float dEta_Cand_Point =
std::abs(eta_Cand - meanEta);
264 if (dEta_Cand_Point > (dEta_Cand + dEta) || dPhi_Cand_Point > (dPhi_Cand + dPhi))
267 float etaMin_RoI =
std::max(eta_Cand - dEta_Cand, meanEta - dEta);
268 float etaMax_RoI =
std::min(eta_Cand + dEta_Cand, meanEta + dEta);
275 float phiMin_RoI =
deltaPhi(phi_Cand_minus, phi_Point_minus) > 0. ? phi_Cand_minus : phi_Point_minus;
276 float phiMax_RoI =
deltaPhi(phi_Cand_plus, phi_Point_plus) < 0. ? phi_Cand_plus : phi_Point_plus;
278 const auto meanEtaTemp = (etaMin_RoI + etaMax_RoI) / 2.
f;
279 auto meanPhiTemp = (phiMin_RoI + phiMax_RoI) / 2.
f;
280 if (phiMax_RoI < phiMin_RoI)
284 const auto dPhiTemp =
deltaPhi(phiMax_RoI, meanPhiTemp);
285 const auto dEtaTemp = etaMax_RoI - meanEtaTemp;
291 LogTrace(
"AreaSeededTrackingRegionsBuilder")
292 <<
"Direction x,y,z " <<
x <<
"," <<
y <<
"," <<
z <<
" eta,phi " << meanEtaTemp <<
"," << meanPhiTemp
293 <<
" window eta " << (meanEtaTemp - dEtaTemp) <<
"," << (meanEtaTemp + dEtaTemp) <<
" phi "
294 << (meanPhiTemp - dPhiTemp) <<
"," << (meanPhiTemp + dPhiTemp);
296 return std::make_unique<RectangularEtaPhiTrackingRegion>(
GlobalVector(
x,
y,
z),
318 LogTrace(
"AreaSeededTrackingRegionsBuilder")
319 <<
"Direction x,y,z " <<
x <<
"," <<
y <<
"," <<
z <<
" eta,phi " << meanEta <<
"," << meanPhi <<
" window eta "
320 << (meanEta - dEta) <<
"," << (meanEta + dEta) <<
" phi " << (meanPhi - dPhi) <<
"," << (meanPhi + dPhi);
322 return std::make_unique<RectangularEtaPhiTrackingRegion>(
GlobalVector(
x,
y,
z),
constexpr double deltaPhi(double phi1, double phi2)
const AreaSeededTrackingRegionsBuilder * m_conf
constexpr T normalizedPhi(T phi)
Sin< T >::type sin(const T &t)
Exp< T >::type exp(const T &t)
TrackingSeedCandidates::Objects candidates
RectangularEtaPhiTrackingRegion::UseMeasurementTracker m_whereToUseMeasurementTracker
Cos< T >::type cos(const T &t)
Tan< T >::type tan(const T &t)
Abs< T >::type abs(const T &t)
const MeasurementTrackerEvent * m_measurementTracker
T perp2() const
Squared magnitude of transverse component.
const MagneticField * m_field
const MultipleScatteringParametrisationMaker * m_msmaker
Global3DVector GlobalVector