DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
TAMakerDBSCANAlgorithm.hpp
Go to the documentation of this file.
1// *** this file is generated by oksdalgen, do not modify it ***
2
3#ifndef _TAMakerDBSCANAlgorithm_0_dunedaq__appmodel_0_appmodel_H_
4#define _TAMakerDBSCANAlgorithm_0_dunedaq__appmodel_0_appmodel_H_
5
6#include <stdint.h> // to define 64 bits types
7#include <iostream>
8#include <sstream>
9#include <string>
10#include <map>
11#include <vector>
12
14#include "conffwk/DalObject.hpp"
15
16 // include files for classes used in inheritance hierarchy
17
19
20namespace dunedaq {
21 namespace appmodel {
22
23 class TAMakerDBSCANAlgorithm : public dunedaq::appmodel::TAAlgorithm {
24
26 friend class conffwk::DalObject;
27 friend class conffwk::DalFactory;
29
30 protected:
31
33 virtual ~TAMakerDBSCANAlgorithm() noexcept;
34 virtual void init(bool init_children);
35
36 public:
37
40 static const std::string& s_class_name;
41
42
52 virtual void print(unsigned int offset, bool print_header, std::ostream& s) const;
53
54
64 virtual std::vector<const dunedaq::conffwk::DalObject *> get(const std::string& name, bool upcast_unregistered = true) const;
65
66
67 protected:
68
69 bool get(const std::string& name, std::vector<const dunedaq::conffwk::DalObject *>& vec, bool upcast_unregistered, bool first_call) const;
70
71
72 private:
73
74 uint32_t m_min_pts;
75 uint32_t m_eps;
76
77
78 public:
79
80 // attribute names
81
82 inline static const std::string s_min_pts = "min_pts";
83 inline static const std::string s_eps = "eps";
84
85 static const std::string& __get_min_pts_str() noexcept { return s_min_pts; }
86 static const std::string& __get_eps_str() noexcept { return s_eps; }
87
88
96 uint32_t
98 {
99 std::lock_guard scoped_lock(m_mutex);
100 check();
101 check_init();
102 return m_min_pts;
103 }
104
112 void
113 set_min_pts(uint32_t value)
114 {
115 std::lock_guard scoped_lock(m_mutex);
116 check();
117 clear();
118 p_obj.set_by_val(s_min_pts, value);
119 }
120
121
129 uint32_t
130 get_eps() const
131 {
132 std::lock_guard scoped_lock(m_mutex);
133 check();
134 check_init();
135 return m_eps;
136 }
137
145 void
146 set_eps(uint32_t value)
147 {
148 std::lock_guard scoped_lock(m_mutex);
149 check();
150 clear();
151 p_obj.set_by_val(s_eps, value);
152 }
153
154
155 };
156
157 // out stream operator
158
159 inline std::ostream& operator<<(std::ostream& s, const TAMakerDBSCANAlgorithm& obj)
160 {
161 return obj.print_object(s);
162 }
163
164 typedef std::vector<const TAMakerDBSCANAlgorithm*>::const_iterator TAMakerDBSCANAlgorithmIterator;
165
166 }
167}
168
169#endif
uint32_t get_eps() const
Get "eps" attribute value. Kernel size for the DBSCAN algorithm.
uint32_t get_min_pts() const
Get "min_pts" attribute value. Minimum number of points in a density unit.
static const std::string & __get_eps_str() noexcept
virtual std::vector< const dunedaq::conffwk::DalObject * > get(const std::string &name, bool upcast_unregistered=true) const
Get values of relationships and results of some algorithms as a vector of dunedaq::conffwk::DalObject...
void set_eps(uint32_t value)
Set "eps" attribute value. Kernel size for the DBSCAN algorithm.
static const std::string & __get_min_pts_str() noexcept
TAMakerDBSCANAlgorithm(conffwk::DalRegistry &db, const conffwk::ConfigObject &obj) noexcept
void set_min_pts(uint32_t value)
Set "min_pts" attribute value. Minimum number of points in a density unit.
void set_by_val(const std::string &name, T value)
Set attribute value.
The base class for any generated DAL object.
Definition DalObject.hpp:45
std::mutex m_mutex
Used to protect changes of DAL object.
ConfigObject p_obj
Config object used by given template object.
void check_init() const
Check and initialize object if necessary.
DalRegistry: A registry of DalObjects It provides a single interface to create, cache and manage DalO...
conffwk entry point
double offset
std::ostream & operator<<(std::ostream &s, const AVXAbsRunSumProcessor &obj)
std::vector< constTAMakerDBSCANAlgorithm * >::const_iterator TAMakerDBSCANAlgorithmIterator
Including Qt Headers.