154{
155
156 const EventContext &ctx = Gaudi::Hive::currentContext();
159
162
163
165
167 ATH_MSG_INFO(
"Initial step ... preparing event cache.");
181
182 std::shared_ptr<Acts::PerigeeSurface> surface =
183 Acts::Surface::makeShared<Acts::PerigeeSurface>(
184 npos);
185
186
188
189 Acts::Vector4 actsStart(
pos.x(),
pos.y(),
pos.z(),0);
190 Acts::Vector3
dir = nmom.normalized();
191 Acts::ParticleHypothesis hypothesis{Acts::makeAbsolutePdgParticle(static_cast<Acts::PdgParticle>(pdg)),
193 Acts::AnyCharge{
static_cast<float>(
charge)}};
195 gctx.
context(), surface, actsStart, dir,
charge/(
mom.mag()/1000), std::nullopt, hypothesis)
196 .value();
197 }
198
199
200 float tX0 =
X0 > 10e-5f ?
t/
X0 : 0.f;
203 if (!isSensitive)
204 {
205 return;
206 }
207
208
210
213 return;
214 }
215
218 return;
219 }
220
222
224
229
232 float X0ATLAS = ecc.materialX0;
233
234 if(eCodeSteps.code != 2 ){
235 ATH_MSG_ERROR(
"Error in the Extrapolator Engine, skip the current step");
236 return;
237 }
238
239
240 auto destinationSurfaceActs = Acts::CurvilinearSurface(destinationSurface.
center(), destinationSurface.
normal()).planeSurface();
241 std::optional<Acts::BoundTrackParameters> actsParameters =
m_actsExtrapolator->propagate(ctx,
243 *destinationSurfaceActs,
244 Acts::Direction::Forward(),
245 std::numeric_limits<double>::max());
246
249 *destinationSurfaceActs,
250 Acts::Direction::Forward(),
251 std::numeric_limits<double>::max()).second.materialInX0;
252
253 if(not actsParameters.has_value()){
254 ATH_MSG_ERROR(
"Error in the Acts extrapolation, skip the current step");
255 return;
256 }
257 int volID = trackingGeometry->lowestTrackingVolume(gctx.
context(), actsParameters->position(gctx.
context()))->geometryId().volume();
258
259
267
273
284
292 }
293
294 else{
298 float tATLAS = (trkParameters->
position() - previousPos).norm();
303 }
304
307 m_treeData->m_acts_pt[
m_treeData->m_g4_steps] = actsParameters ? actsParameters->transverseMomentum()*1000 : 0.;
308 m_treeData->m_acts_eta[
m_treeData->m_g4_steps] = actsParameters ? actsParameters->momentum().eta() : 0.;
309 m_treeData->m_acts_theta[
m_treeData->m_g4_steps] = actsParameters ? actsParameters->momentum().theta() : 0.;
310 m_treeData->m_acts_phi[
m_treeData->m_g4_steps] = actsParameters ? actsParameters->momentum().phi() : 0.;
314
322 }
323
324 else{
328 float tActs = (actsParameters->position(gctx.
context()) - previousPos).norm();
333 }
334
335
341 }
342
343 delete g4Parameters;
344 destinationSurfaceActs.reset();
348}
#define ATH_MSG_WARNING(x)
double charge(const T &p)
Trk::PdgToParticleHypothesis m_pdgToParticleHypothesis
Gaudi::Property< bool > m_extrapolateIncrementally
Acts::GeometryContext context() const
virtual const S & associatedSurface() const override final
Access to the Surface method.
const Amg::Vector3D & momentum() const
Access method for the momentum.
const Amg::Vector3D & position() const
Access method for the position.
double pT() const
Access method for transverse momentum.
virtual const Amg::Vector3D & normal() const
Returns the normal vector of the Surface (i.e.
const Amg::Vector3D & center() const
Returns the center position of the Surface.
Eigen::Matrix< double, 3, 1 > Vector3D
constexpr double mass[PARTICLEHYPOTHESES]
the array of masses
CurvilinearParametersT< TrackParametersDim, Charged, PlaneSurface > CurvilinearParameters
ParticleHypothesis
Enumeration for Particle hypothesis respecting the interaction with material.
ParametersBase< TrackParametersDim, Charged > TrackParameters