33 : mOrigin(orig), mCTFCoder(
o2::ctf::CTFCoderBase::OpType::Decoder, orig ==
o2::header::gDataOriginITS ?
o2::detectors::
DetID::ITS :
o2::detectors::
DetID::MFT), mGetDigits(getDigits)
46 mMaskNoise = ic.
options().
get<
bool>(
"mask-noise");
47 mUseClusterDictionary = !ic.
options().
get<
bool>(
"ignore-cluster-dictionary");
55 auto cput = mTimer.CpuTime();
58 updateTimeDependentParams(pc);
59 auto buff = pc.
inputs().
get<gsl::span<o2::ctf::BufferType>>(std::string(
"ctf") + mDetPrefix);
73 LOG(info) <<
"Decoded " <<
digits.size() <<
" digits in " << rofs.size() <<
" RO frames, (" << iosize.
asString() <<
") in " << mTimer.CpuTime() - cput <<
" s";
75 auto& compcl = pc.
outputs().
make<std::vector<o2::itsmft::CompClusterExt>>(
OutputRef{
"compClusters"});
81 LOG(info) <<
"Decoded " << compcl.size() <<
" clusters in " << rofs.size() <<
" RO frames, (" << iosize.
asString() <<
") in " << mTimer.CpuTime() - cput <<
" s";
88 LOGF(info,
"%s Entropy Decoding total timing: Cpu: %.3e Real: %.3e s in %d slots",
89 mOrigin.
as<std::string>(), mTimer.CpuTime(), mTimer.RealTime(), mTimer.Counter() - 1);
98 if (mGetDigits || mMaskNoise) {
109 LOG(info) << mOrigin.
as<std::string>() <<
" noise map updated";
113 LOG(info) << mOrigin.
as<std::string>() <<
" cluster dictionary updated" << (!mUseClusterDictionary ?
" but its using is disabled" :
"");
124 std::vector<OutputSpec> outputs;
131 outputs.emplace_back(
OutputSpec{{
"Digits"}, orig,
"DIGITS", 0, Lifetime::Timeframe});
132 outputs.emplace_back(
OutputSpec{{
"ROframes"}, orig,
"DIGITSROF", 0, Lifetime::Timeframe});
134 outputs.emplace_back(
OutputSpec{{
"compClusters"}, orig,
"COMPCLUSTERS", 0, Lifetime::Timeframe});
135 outputs.emplace_back(
OutputSpec{{
"ROframes"}, orig,
"CLUSTERSROF", 0, Lifetime::Timeframe});
136 outputs.emplace_back(
OutputSpec{{
"patterns"}, orig,
"PATTERNS", 0, Lifetime::Timeframe});
138 outputs.emplace_back(
OutputSpec{{
"ctfrep"}, orig,
"CTFDECREP", 0, Lifetime::Timeframe});
140 std::vector<InputSpec> inputs;
141 inputs.emplace_back(std::string(
"ctf") + nm, orig,
"CTFDATA", sspec, Lifetime::Timeframe);
142 inputs.emplace_back(std::string(
"noise") + nm, orig,
"NOISEMAP", 0, Lifetime::Condition,
ccdbParamSpec(fmt::format(
"{}/Calib/NoiseMap", orig.
as<std::string>())));
143 inputs.emplace_back(std::string(
"cldict") + nm, orig,
"CLUSDICT", 0, Lifetime::Condition,
ccdbParamSpec(fmt::format(
"{}/Calib/ClusterDictionary", orig.
as<std::string>())));
144 inputs.emplace_back(std::string(
"ctfdict") + nm, orig,
"CTFDICT", 0, Lifetime::Condition,
ccdbParamSpec(fmt::format(
"{}/Calib/CTFDictionaryTree", orig.
as<std::string>())));
145 inputs.emplace_back(std::string(
"trigoffset"),
"CTP",
"Trig_Offset", 0, Lifetime::Condition,
ccdbParamSpec(
"CTP/Config/TriggerOffsets"));
153 {
"ctf-dict", VariantType::String,
"ccdb", {
"CTF dictionary: empty or ccdb=CCDB, none=no external dictionary otherwise: local filename"}},
154 {
"mask-noise", VariantType::Bool,
false, {
"apply noise mask to digits or clusters (involves reclusterization)"}},
155 {
"ignore-cluster-dictionary", VariantType::Bool,
false, {
"do not use cluster dictionary, always store explicit patterns"}},
156 {
"ans-version", VariantType::String, {
"version of ans entropy coder implementation to use"}}}};
Definition of the ITS/MFT clusterer settings.
Definition of the ITSMFT compact cluster.
Definition of the Names Generator class.
Convert CTF (EncodedBlocks) to clusters streams.
Definition Physics trigger record extracted from the ITS/MFT stream.
void updateTimeDependentParams(o2::framework::ProcessingContext &pc, bool askTree=false)
void setDictBinding(const std::string &s)
void init(o2::framework::InitContext &ic)
bool finaliseCCDB(o2::framework::ConcreteDataMatcher &matcher, void *obj)
static auto getImage(const void *newHead)
get const image of the container wrapper, with pointers in the image relocated to new head
Static class with identifiers, bitmasks and names for ALICE detectors.
T get(const char *key) const
void snapshot(const Output &spec, T const &object)
decltype(auto) make(const Output &spec, Args... args)
ConfigParamRegistry const & options()
DataAllocator & outputs()
The data allocator is used to allocate memory for the output data.
InputRecord & inputs()
The inputs associated with this processing context.
ServiceRegistryRef services()
The services registry associated with this processing context.
o2::ctf::CTFIOSize decode(const CTF::base &ec, VROF &rofRecVec, VCLUS &cclusVec, VPAT &pattVec, const NoiseMap *noiseMap, const LookUp &clPattLookup)
entropy decode clusters from buffer with CTF
void finaliseCCDB(o2::framework::ConcreteDataMatcher &matcher, void *obj) final
void endOfStream(o2::framework::EndOfStreamContext &ec) final
This is invoked whenever we have an EndOfStream event.
static auto getName(o2::header::DataOrigin orig)
void run(o2::framework::ProcessingContext &pc) final
void init(o2::framework::InitContext &ic) final
EntropyDecoderSpec(o2::header::DataOrigin orig, int verbosity, bool getDigits=false)
void setDictionary(const TopologyDictionary *dict)
NoiseMap class for the ITS and MFT.
constexpr o2::header::DataOrigin gDataOriginMFT
constexpr o2::header::DataOrigin gDataOriginITS
Defining PrimaryVertex explicitly as messageable.
std::vector< ConfigParamSpec > ccdbParamSpec(std::string const &path, int runDependent, std::vector< CCDBMetadata > metadata={}, int qrate=0)
std::vector< ConfigParamSpec > Options
framework::DataProcessorSpec getEntropyDecoderSpec(o2::header::DataOrigin orig, int verbosity, bool getDigits, unsigned int sspec)
create a processor spec
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
std::string asString() const
bool globalRunNumberChanged
wrapper for the Entropy-encoded clusters of the TF
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"
std::vector< Digit > digits