CbmRoot
Loading...
Searching...
No Matches
much/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::much;
10using fles::Subsystem;
11
12Unpack::Unpack(const ReadoutConfig& readout) : fReadout(readout)
13{
14 constexpr i64 SystemTimeOffset = -980;
15 constexpr u8 SystemVersion = 0x20;
16
17 // Create one algorithm per component for MUCH and configure it with parameters
18 auto equipIdsMuch = fReadout.GetEquipmentIds();
19 for (auto& equip : equipIdsMuch) {
20 much::UnpackPar par{};
21 const size_t numElinks = fReadout.GetNumElinks(equip);
22 for (size_t elink = 0; elink < numElinks; elink++) {
23 much::UnpackElinkPar elinkPar;
24 elinkPar.fAddress = fReadout.Map(equip, elink); // Vector of MUCH addresses for this elink
25 elinkPar.fTimeOffset = SystemTimeOffset;
26 elinkPar.fChanMask = fReadout.MaskMap(equip, elink);
27 par.fElinkParams.push_back(elinkPar);
28 }
29 auto algo = std::make_unique<UnpackMS>(par);
30 fAlgos[{equip, SystemVersion}] = std::move(algo);
31 L_(debug) << "--- Configured equipment " << equip << " with " << numElinks << " elinks";
32 }
33 L_(info) << "--- Configured " << fAlgos.size() << " unpacker algorithms for MUCH.";
34}
35
36Unpack::Result_t Unpack::operator()(const fles::Timeslice& ts) const { return DoUnpack(Subsystem::MUCH, 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
std::vector< uint16_t > GetEquipmentIds()
Equipment in the configuration.
size_t GetNumElinks(uint16_t equipmentId)
Number of elinks of a component.
std::vector< bool > MaskMap(uint16_t equipId, uint16_t elink)
API: Mapping from component and elink to channel mask flags.
std::vector< uint32_t > Map(uint16_t equipId, uint16_t elink)
API: Mapping from component and elink to addresses per channel.
detail::UnpackBase::Result_t Result_t
Definition much/Unpack.h:22
Unpack(const ReadoutConfig &readout)
Result_t operator()(const fles::Timeslice &) const
ReadoutConfig fReadout
Definition much/Unpack.h:29
std::int64_t i64
Definition Definitions.h:22
std::uint8_t u8
Definition Definitions.h:17
STS Unpacking parameters for one eLink / ASIC.
uint64_t fTimeOffset
Time calibration parameter.
std::vector< bool > fChanMask
Channel masking flags.
std::vector< uint32_t > fAddress
CbmMuchAddress for different channels.
Parameters required for the STS unpacking (specific to one component)