From 19be5ff5abbc1ee75df6229ee0556e40bcc2f740 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?JulienD=C3=B6rner?= Date: Wed, 7 Aug 2024 18:00:36 +0200 Subject: [PATCH] add trajectory length observer feature --- include/crpropa/module/Observer.h | 11 +++++++++++ src/module/Observer.cpp | 13 +++++++++++++ 2 files changed, 24 insertions(+) diff --git a/include/crpropa/module/Observer.h b/include/crpropa/module/Observer.h index adf7c8fc4..42234998e 100644 --- a/include/crpropa/module/Observer.h +++ b/include/crpropa/module/Observer.h @@ -281,6 +281,17 @@ class ObserverTimeEvolution: public ObserverFeature { DetectionState checkDetection(Candidate *candidate) const; std::string getDescription() const; }; + +class ObserverTrajectoryLength: public ObserverFeature { +private: + double maxLength; +public: + ObserverTrajectoryLength(double l); + + DetectionState checkDetection(Candidate *candidate) const; +}; + + /** @} */ } diff --git a/src/module/Observer.cpp b/src/module/Observer.cpp index c600dce50..3b464ed15 100644 --- a/src/module/Observer.cpp +++ b/src/module/Observer.cpp @@ -365,4 +365,17 @@ std::string ObserverSurface::getDescription() const { return ss.str(); } +// ObserverTrajectoryLength --------------------------------------------------- + +ObserverTrajectoryLength::ObserverTrajectoryLength(double l) : maxLength(l) { } + +DetectionState ObserverTrajectoryLength::checkDetection(Candidate *cand) const { + double currentLength = cand -> getTrajectoryLength(); + + if (currentLength > maxLength) + return DETECTED; + + cand -> limitNextStep(maxLength - currentLength); + return NOTHING; +} } // namespace crpropa