From 2180b564e455238f5ff794baeacb8b1eaa6d979a Mon Sep 17 00:00:00 2001 From: Alexey Rybalchenko Date: Tue, 7 Feb 2023 11:18:36 +0100 Subject: [PATCH] Serialization example: add temporary processing on sender side --- examples/MQ/serialization/sampler.cxx | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/examples/MQ/serialization/sampler.cxx b/examples/MQ/serialization/sampler.cxx index a70cf3af3d..a32600e541 100644 --- a/examples/MQ/serialization/sampler.cxx +++ b/examples/MQ/serialization/sampler.cxx @@ -9,6 +9,7 @@ // this example #include "ExHeader.h" #include "MyDigi.h" +#include "MyHit.h" // temporary for the data check (see below) // FairRoot #include "BoostSerializer.h" @@ -19,6 +20,7 @@ // ROOT #include #include +#include // temporary for the data check (see below) #include // std @@ -64,6 +66,9 @@ struct Sampler : fair::mq::Device ExHeader header; header.eventNumber = idx; + // temporarily apply data processing steps to check that they work before & after serialization + volatile TClonesArray hits = FindHits(*fInput); + auto msgHeader(NewMessage()); BoostSerializer().Serialize(*msgHeader, header); @@ -92,6 +97,25 @@ struct Sampler : fair::mq::Device } private: + // temporary method to check data before transfer + TClonesArray FindHits(const TClonesArray& digis) + { + TClonesArray hits("MyHit"); + const TVector3 dpos(1 / TMath::Sqrt(12), 1 / TMath::Sqrt(12), 1 / TMath::Sqrt(12)); + const Int_t fDetID = 0; + const Int_t fMCIndex = 0; + + for (int i = 0; i < digis.GetEntriesFast(); i++) { + auto digi = static_cast(digis.At(i)); + const TVector3 pos(digi->GetX() + 0.5, digi->GetY() + 0.5, digi->GetZ() + 0.5); + auto hit = new ((hits)[i]) MyHit(fDetID, fMCIndex, pos, dpos); + hit->SetTimeStamp(digi->GetTimeStamp()); + hit->SetTimeStampError(digi->GetTimeStampError()); + } + + return hits; + } + TClonesArray* fInput; TTree* fTree; std::string fFileName;