CbmRoot
Loading...
Searching...
No Matches
bmon/Unpack.cxx
Go to the documentation of this file.
1/* Copyright (C) 2024 FIAS Frankfurt Institute for Advanced Studies, Frankfurt / Main
2 SPDX-License-Identifier: GPL-3.0-only
3 Authors: Felix Weiglhofer [committer], Dominik Smith */
4
5#include "Unpack.h"
6
8
9using namespace cbm::algo::bmon;
10using fles::Subsystem;
11
12Unpack::Unpack(const ReadoutConfig& readout) : fReadout(readout)
13{
14 constexpr u8 SystemVersion = 0x00;
15 i32 SysTimeOffset = fReadout.GetSystemTimeOffset();
16
17 // Create one algorithm per component for Bmon and configure it with parameters
18 auto equipIdsBmon = fReadout.GetEquipmentIds();
19 for (auto& equip : equipIdsBmon) {
20 bmon::UnpackPar par{};
21 const size_t numElinks = fReadout.GetNumElinks(equip);
22 for (size_t elink = 0; elink < numElinks; elink++) {
23 bmon::UnpackElinkPar elinkPar;
24 elinkPar.fChannelUId = fReadout.Map(equip, elink); // Vector of Bmon addresses for this elink
25 elinkPar.fTimeOffset = SysTimeOffset + fReadout.GetElinkTimeOffset(equip, elink); // Time offset for this elink
26 par.fElinkParams.push_back(elinkPar);
27 }
28 auto algo = std::make_unique<UnpackMS>(par);
29 fAlgos[{equip, SystemVersion}] = std::move(algo);
30
31 L_(debug) << "--- Configured equipment " << equip << " with " << numElinks << " elinks";
32 }
33 L_(info) << "--- Configured " << fAlgos.size() << " unpacker algorithms for Bmon.";
34}
35
36Unpack::Result_t Unpack::operator()(const fles::Timeslice& ts) const { return DoUnpack(Subsystem::BMON, ts); }
#define L_(level)
Result_t DoUnpack(const fles::Subsystem subsystem, const fles::Timeslice &ts) const
std::map< UnpackKey, std::unique_ptr< Unpack_t > > fAlgos
int32_t GetElinkTimeOffset(uint16_t equipId, uint16_t elink)
API: Mapping from component and elink to time offset.
std::vector< uint16_t > GetEquipmentIds()
Equipment in the configuration.
i32 GetSystemTimeOffset() const
System time offset for BMon.
std::vector< uint32_t > Map(uint16_t equipId, uint16_t elink)
API: Mapping from component and elink to addresses per channel.
size_t GetNumElinks(uint16_t equipmentId)
Number of elinks of a component.
ReadoutConfig fReadout
Definition bmon/Unpack.h:29
Unpack(const ReadoutConfig &readout)
Result_t operator()(const fles::Timeslice &) const
detail::UnpackBase::Result_t Result_t
Definition bmon/Unpack.h:22
std::int32_t i32
Definition Definitions.h:20
std::uint8_t u8
Definition Definitions.h:17
Bmon Unpacking parameters for one eLink / ASIC.
int32_t fTimeOffset
Time calibration parameter.
std::vector< uint32_t > fChannelUId
CbmBmonAddress for different channels.
Parameters required for the BMON unpacking (specific to one component)