Iguana LATEST
Implementation Guardian of Analysis Algorithms
Loading...
Searching...
No Matches
Algorithm.h
1#pragma once
2
3#include <mutex>
4#include <optional>
5#include <set>
6
7#include <hipo4/bank.h>
8
10#include "iguana/bankdefs/BankDefs.h"
11#include "iguana/services/Deprecated.h"
12#include "iguana/services/RCDBReader.h"
13#include "iguana/services/YAMLReader.h"
14#include <iguana/services/GlobalParam.h>
15
16namespace iguana {
17
19 // ALGORITHM TOOLS
21
23 namespace tools {
33 hipo::banklist::size_type GetBankIndex(
34 hipo::banklist& banks,
35 std::string const& bank_name,
36 unsigned int const& variant = 0) noexcept(false);
37 }
38
40 // BASE CLASS ALGORITHM
42
44 /* NOTE: if you modify this, you also must modify:
45 * - [ ] `PrintOptionValue`
46 * - [ ] Template specializations in this class
47 * - [ ] Template specializations in `YAMLReader` or `ConfigFileReader`, and `ConcurrentParam`
48 * - [ ] Add new tests, if you added new types
49 * - FIXME: adding `bool` type may be tricky, see https://github.com/JeffersonLab/iguana/issues/347
50 */
51 using option_t = std::variant<
52 int,
53 double,
54 std::string,
55 std::vector<int>,
56 std::vector<double>,
57 std::vector<std::string>>;
58
67 class Algorithm : public Object
68 {
69
70 public:
71
73 Algorithm(std::string_view name)
74 : Object(name)
75 , m_rows_only(false)
79 {}
80 virtual ~Algorithm() {}
81
90 virtual void Start(hipo::banklist& banks) final;
91
98 virtual void Start() final;
99
106 virtual bool Run(hipo::banklist& banks) const final;
107
111 virtual void Stop() final;
112
132 template <typename OPTION_TYPE>
133 OPTION_TYPE SetOption(std::string const& key, const OPTION_TYPE val)
134 {
135 // FIXME: this template is not specialized, to be friendlier to python `cppyy` bindings
136 if(key == "log") {
137 if constexpr(std::disjunction<
138 std::is_same<OPTION_TYPE, std::string>,
139 std::is_same<OPTION_TYPE, char const*>,
140 std::is_same<OPTION_TYPE, Logger::Level>>::value)
141 m_log->SetLevel(val);
142 else
143 m_log->Error("Option '{}' must be a string or a Logger::Level", key);
144 }
145 // make sure the key hasn't been renamed or deprecated
146 iguana::deprecated::CheckSetOptionKey(m_class_name, key);
147 // add it to the cache
148 m_option_cache[key] = val;
149 return val;
150 }
151
155 template <typename OPTION_TYPE>
156 OPTION_TYPE GetOptionScalar(YAMLReader::node_path_t node_path = {}) const;
157
161 template <typename OPTION_TYPE>
162 std::vector<OPTION_TYPE> GetOptionVector(YAMLReader::node_path_t node_path = {}) const;
163
167 template <typename OPTION_TYPE>
168 std::set<OPTION_TYPE> GetOptionSet(YAMLReader::node_path_t node_path = {}) const;
169
172 void SetName(std::string_view name);
173
176 std::unique_ptr<YAMLReader> const& GetConfig() const;
177
180 void SetConfig(std::unique_ptr<YAMLReader>&& yaml_config);
181
185 void SetConfigFile(std::string const& name);
186
190 void SetConfigDirectory(std::string const& name);
191
198 hipo::banklist::size_type GetBankIndex(hipo::banklist& banks, std::string const& bank_name) const noexcept(false);
199
205 hipo::banklist::size_type GetCreatedBankIndex(hipo::banklist& banks) const noexcept(false);
206
210 std::vector<std::string> GetCreatedBankNames() const noexcept(false);
211
215 std::string GetCreatedBankName() const noexcept(false);
216
222 hipo::bank GetCreatedBank(std::string const& bank_name = "") const noexcept(false);
223
228 hipo::schema GetCreatedBankSchema(std::string const& bank_name = "") const noexcept(false);
229
232 unsigned int GetCreatedBankVariant() const;
233
235 std::unique_ptr<RCDBReader>& GetRCDBReader();
236
237 protected: // methods
238
241
247 hipo::bank& GetBank(hipo::banklist& banks, hipo::banklist::size_type const idx, std::string const& expected_bank_name = "") const noexcept(false);
248
254 hipo::schema CreateBank(
255 hipo::banklist& banks,
256 hipo::banklist::size_type& bank_idx,
257 std::string const& bank_name) noexcept(false);
258
263 void ShowBanks(hipo::banklist const& banks, std::string_view message = "", Logger::Level const level = Logger::trace) const;
264
269 void ShowBank(hipo::bank const& bank, std::string_view message = "", Logger::Level const level = Logger::trace) const;
270
275 void ThrowSinceRenamed(std::string const& new_name, std::string const& version) const noexcept(false);
276
277 private: // methods
278
282 virtual void ConfigHook() {}
283
287 virtual void StartHook(hipo::banklist& banks) {}
288
291 virtual bool RunHook(hipo::banklist& banks) const { return true; }
292
295 virtual void StopHook() {}
296
298 void ParseYAMLConfig();
299
303 template <typename OPTION_TYPE>
304 std::optional<OPTION_TYPE> GetCachedOption(std::string const& key) const;
305
306 // PrintOptionValue: overloaded for different value types
307 void PrintOptionValue(std::string const& key, int const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
308 void PrintOptionValue(std::string const& key, double const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
309 void PrintOptionValue(std::string const& key, std::string const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
310 void PrintOptionValue(std::string const& key, std::vector<int> const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
311 void PrintOptionValue(std::string const& key, std::vector<double> const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
312 void PrintOptionValue(std::string const& key, std::vector<std::string> const& val, Logger::Level const level = Logger::debug, std::string_view prefix = "OPTION") const;
313
314 protected: // members
315
317 std::string m_class_name;
318
321
324
328
331 std::string o_user_config_dir;
332
334 mutable std::mutex m_mutex;
335
338 unsigned int m_created_bank_variant{0};
339
341 std::unique_ptr<RCDBReader> m_rcdb;
342
343 private: // members
344
346 std::unique_ptr<YAMLReader> m_yaml_config;
347
349 std::unordered_map<std::string, option_t> m_option_cache;
350 };
351
353 // ALGORITHM FACTORY
355
357 using algo_t = std::unique_ptr<Algorithm>;
358
360 class AlgorithmFactory
361 {
362
363 public:
364
366 using algo_creator_t = std::function<algo_t()>;
367
368 AlgorithmFactory() = delete;
369
375 static bool Register(std::string const& algo_name, algo_creator_t creator, std::vector<std::string> const new_banks = {}) noexcept;
376
380 static algo_t Create(std::string const& algo_name) noexcept(false);
381
385 static std::optional<std::vector<std::string>> GetCreatorAlgorithms(std::string const& bank_name) noexcept;
386
390 static std::optional<std::vector<std::string>> GetCreatedBanks(std::string const& algo_name) noexcept(false);
391
392 private:
393
395 static std::unordered_map<std::string, algo_creator_t> s_creators;
396
398 static std::unordered_map<std::string, std::vector<std::string>> s_bank_to_algos;
399
401 static std::unordered_map<std::string, std::vector<std::string>> s_algo_to_banks;
402 };
403}
Preprocessor macros to generate standardized algorithm boilerplate code.
static std::optional< std::vector< std::string > > GetCreatedBanks(std::string const &algo_name) noexcept(false)
std::function< algo_t()> algo_creator_t
Algorithm creator function type.
Definition Algorithm.h:366
static std::optional< std::vector< std::string > > GetCreatorAlgorithms(std::string const &bank_name) noexcept
static bool Register(std::string const &algo_name, algo_creator_t creator, std::vector< std::string > const new_banks={}) noexcept
static algo_t Create(std::string const &algo_name) noexcept(false)
Base class for all algorithms to inherit from.
Definition Algorithm.h:68
void SetName(std::string_view name)
std::string GetCreatedBankName() const noexcept(false)
void SetConfigDirectory(std::string const &name)
virtual bool Run(hipo::banklist &banks) const final
Run Function: Process an event's hipo::banklist
std::unique_ptr< YAMLReader > const & GetConfig() const
void SetConfig(std::unique_ptr< YAMLReader > &&yaml_config)
std::unique_ptr< RCDBReader > m_rcdb
RCDB reader.
Definition Algorithm.h:341
std::string m_class_name
Class name of this algorithm.
Definition Algorithm.h:317
virtual void Stop() final
Stop Function: Finalize this algorithm after all events are processed.
virtual void Start(hipo::banklist &banks) final
Start Function: Initialize this algorithm before any events are processed, with the intent to process...
std::vector< std::string > GetCreatedBankNames() const noexcept(false)
void ShowBanks(hipo::banklist const &banks, std::string_view message="", Logger::Level const level=Logger::trace) const
hipo::bank & GetBank(hipo::banklist &banks, hipo::banklist::size_type const idx, std::string const &expected_bank_name="") const noexcept(false)
unsigned int m_created_bank_variant
Definition Algorithm.h:338
std::mutex m_mutex
A mutex for this algorithm.
Definition Algorithm.h:334
hipo::schema GetCreatedBankSchema(std::string const &bank_name="") const noexcept(false)
void SetConfigFile(std::string const &name)
hipo::schema CreateBank(hipo::banklist &banks, hipo::banklist::size_type &bank_idx, std::string const &bank_name) noexcept(false)
std::string o_user_config_dir
Definition Algorithm.h:331
void ShowBank(hipo::bank const &bank, std::string_view message="", Logger::Level const level=Logger::trace) const
unsigned int GetCreatedBankVariant() const
OPTION_TYPE GetOptionScalar(YAMLReader::node_path_t node_path={}) const
void ThrowSinceRenamed(std::string const &new_name, std::string const &version) const noexcept(false)
OPTION_TYPE SetOption(std::string const &key, const OPTION_TYPE val)
Set an option specified by the user.
Definition Algorithm.h:133
std::vector< OPTION_TYPE > GetOptionVector(YAMLReader::node_path_t node_path={}) const
bool m_rows_only
If true, algorithm can only operate on bank rows; Algorithm::GetBank, and therefore Algorithm::Run,...
Definition Algorithm.h:320
hipo::banklist::size_type GetBankIndex(hipo::banklist &banks, std::string const &bank_name) const noexcept(false)
std::string o_user_config_file
Definition Algorithm.h:327
std::string m_default_config_file
Default configuration file name.
Definition Algorithm.h:323
std::set< OPTION_TYPE > GetOptionSet(YAMLReader::node_path_t node_path={}) const
hipo::banklist::size_type GetCreatedBankIndex(hipo::banklist &banks) const noexcept(false)
virtual void Start() final
Start Function: Initialize this algorithm before any events are processed, with the intent to process...
void StartRCDBReader()
Instantiate the RCDBReader instance for this algorithm.
hipo::bank GetCreatedBank(std::string const &bank_name="") const noexcept(false)
std::unique_ptr< RCDBReader > & GetRCDBReader()
Algorithm(std::string_view name)
Definition Algorithm.h:73
Simple logger service.
Definition Logger.h:18
std::unique_ptr< Logger > m_log
Logger instance for this object
Definition Object.h:52
Object(std::string_view name="", Logger::Level lev=Logger::DEFAULT_LEVEL)
RCDB reader.
Definition RCDBReader.h:32
std::deque< node_id_t > node_path_t
Representation of a path of YAML::Nodes in a YAML::Node tree, e.g., in a YAML file.
Definition YAMLReader.h:28
general algorithm tools
Definition Algorithm.h:23
hipo::banklist::size_type GetBankIndex(hipo::banklist &banks, std::string const &bank_name, unsigned int const &variant=0) noexcept(false)