Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpMomentDatabase.h
1/*
2 * ViSP, open source Visual Servoing Platform software.
3 * Copyright (C) 2005 - 2025 by Inria. All rights reserved.
4 *
5 * This software is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 * See the file LICENSE.txt at the root directory of this source
10 * distribution for additional information about the GNU GPL.
11 *
12 * For using ViSP with software that can not be combined with the GNU
13 * GPL, please contact Inria about acquiring a ViSP Professional
14 * Edition License.
15 *
16 * See https://visp.inria.fr for more information.
17 *
18 * This software was developed at:
19 * Inria Rennes - Bretagne Atlantique
20 * Campus Universitaire de Beaulieu
21 * 35042 Rennes Cedex
22 * France
23 *
24 * If you have questions regarding the use of this file, please contact
25 * Inria at visp@inria.fr
26 *
27 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29 *
30 * Description:
31 * Pseudo-database used to handle dependencies between moments
32 */
33
38#ifndef VP_MOMENT_DATABASE_H
39#define VP_MOMENT_DATABASE_H
40
41#include <visp3/core/vpImage.h>
42
43#include <cstring>
44#include <iostream>
45#include <map>
46
48class vpMoment;
49class vpMomentObject;
50
132class VISP_EXPORT vpMomentDatabase
133{
134private:
135#ifndef DOXYGEN_SHOULD_SKIP_THIS
136 struct vpCmpStr_t
137 {
138 bool operator()(const std::string &a, const std::string &b) const { return std::strcmp(a.c_str(), b.c_str()) < 0; }
139 };
140#endif
141 std::map<const std::string, vpMoment *, vpCmpStr_t> moments;
142 void add(vpMoment &moment, const std::string &name);
143
144public:
145 vpMomentDatabase() : moments() { }
146#if (VISP_CXX_STANDARD > VISP_CXX_STANDARD_98)
148#endif
149 virtual ~vpMomentDatabase() { }
150
151#if (VISP_CXX_STANDARD > VISP_CXX_STANDARD_98)
153#endif
154
157 const vpMoment &get(const std::string &moment_name, bool &found) const;
165 vpMoment &get_first() { return *(moments.begin()->second); }
166
167 virtual void updateAll(vpMomentObject &object);
169
170 friend class vpMoment;
171 friend VISP_EXPORT std::ostream &operator<<(std::ostream &os, const vpMomentDatabase &v);
172};
173END_VISP_NAMESPACE
174#endif
const vpMoment & get(const std::string &moment_name, bool &found) const
vpMomentDatabase & operator=(const vpMomentDatabase &)=default
vpMomentDatabase(const vpMomentDatabase &)=default
virtual ~vpMomentDatabase()
vpMoment & get_first()
friend class vpMoment
friend VISP_EXPORT std::ostream & operator<<(std::ostream &os, const vpMomentDatabase &v)
Class for generic objects.
This class defines shared methods/attributes for 2D moments.
Definition vpMoment.h:106