Visual Servoing Platform  version 3.6.1 under development (2024-07-27)
vpMomentDatabase.cpp
1 /****************************************************************************
2  *
3  * ViSP, open source Visual Servoing Platform software.
4  * Copyright (C) 2005 - 2023 by Inria. All rights reserved.
5  *
6  * This software is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  * See the file LICENSE.txt at the root directory of this source
11  * distribution for additional information about the GNU GPL.
12  *
13  * For using ViSP with software that can not be combined with the GNU
14  * GPL, please contact Inria about acquiring a ViSP Professional
15  * Edition License.
16  *
17  * See https://visp.inria.fr for more information.
18  *
19  * This software was developed at:
20  * Inria Rennes - Bretagne Atlantique
21  * Campus Universitaire de Beaulieu
22  * 35042 Rennes Cedex
23  * France
24  *
25  * If you have questions regarding the use of this file, please contact
26  * Inria at visp@inria.fr
27  *
28  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30  *
31  * Description:
32  * Pseudo-database used to handle dependencies between moments
33  *
34  * Authors:
35  * Filip Novotny
36  *
37 *****************************************************************************/
38 
39 #include <iostream>
40 #include <typeinfo>
41 #include <visp3/core/vpMoment.h>
42 #include <visp3/core/vpMomentDatabase.h>
43 #include <visp3/core/vpMomentObject.h>
44 
54 void vpMomentDatabase::add(vpMoment &moment, const std::string &name)
55 {
56  moments.insert(std::pair<const std::string, vpMoment *>(name, &moment));
57 }
58 
65 const vpMoment &vpMomentDatabase::get(const std::string &moment_name, bool &found) const
66 {
67  std::map<const std::string, vpMoment *, vpMomentDatabase::vpCmpStr_t>::const_iterator it = moments.find(moment_name);
68 
69  found = (it != moments.end());
70  return *(it->second);
71 }
72 
84 {
85  std::map<const std::string, vpMoment *, vpMomentDatabase::vpCmpStr_t>::const_iterator itr;
86  for (itr = moments.begin(); itr != moments.end(); ++itr) {
87  (*itr).second->update(object);
88  }
89 }
90 
94 VISP_EXPORT std::ostream &operator<<(std::ostream &os, const vpMomentDatabase &m)
95 {
96 #ifdef ENABLE_VISP_NAMESPACE
97  using namespace VISP_NAMESPACE_NAME;
98 #endif
99  std::map<const std::string, vpMoment *, vpMomentDatabase::vpCmpStr_t>::const_iterator itr;
100  os << "{";
101 
102  for (itr = m.moments.begin(); itr != m.moments.end(); ++itr) {
103  os << (*itr).first << ": [" << *((*itr).second) << "],";
104  }
105  os << "}";
106 
107  return os;
108 }
109 END_VISP_NAMESPACE
friend std::ostream & operator<<(std::ostream &s, const vpArray2D< Type > &A)
Definition: vpArray2D.h:611
This class allows to register all vpMoments so they can access each other according to their dependen...
const vpMoment & get(const std::string &moment_name, bool &found) const
virtual void updateAll(vpMomentObject &object)
Class for generic objects.
This class defines shared methods/attributes for 2D moments.
Definition: vpMoment.h:106