From aeb680f63826c0041bde98b480bd4818b5948998 Mon Sep 17 00:00:00 2001 From: swagata87 Date: Tue, 21 May 2024 14:03:40 +0200 Subject: [PATCH] fix dz nan-issue --- DataFormats/PatCandidates/src/PackedCandidate.cc | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/DataFormats/PatCandidates/src/PackedCandidate.cc b/DataFormats/PatCandidates/src/PackedCandidate.cc index df49e7fd67b28..8186df7b31699 100644 --- a/DataFormats/PatCandidates/src/PackedCandidate.cc +++ b/DataFormats/PatCandidates/src/PackedCandidate.cc @@ -39,8 +39,11 @@ void pat::PackedCandidate::packVtx(bool unpackAfterwards) { // if we want to go back to the full x,y,z we need to store also // float dl = dxPV * c + dyPV * s; // float xRec = - dxy_ * s + dl * c, yRec = dxy_ * c + dl * s; - float pzpt = p4_.load()->Pz() / p4_.load()->Pt(); - dz_ = vertex_.load()->Z() - pv.Z() - (dxPV * c + dyPV * s) * pzpt; + dz_ = 0; + if (p4_.load()->Pt() != 0.f) { + float pzpt = p4_.load()->Pz() / p4_.load()->Pt(); + dz_ = vertex_.load()->Z() - pv.Z() - (dxPV * c + dyPV * s) * pzpt; + } packedDxy_ = MiniFloatConverter::float32to16(dxy_ * 100); packedDz_ = pvRef.isNonnull() ? MiniFloatConverter::float32to16(dz_ * 100) : int16_t(std::round(dz_ / 40.f * std::numeric_limits::max()));