g2o
Loading...
Searching...
No Matches
g2o
examples
g2o_hierarchical
edge_types_cost_function.h
Go to the documentation of this file.
1
// g2o - General Graph Optimization
2
// Copyright (C) 2011 R. Kuemmerle, G. Grisetti, H. Strasdat, W. Burgard
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without
6
// modification, are permitted provided that the following conditions are
7
// met:
8
//
9
// * Redistributions of source code must retain the above copyright notice,
10
// this list of conditions and the following disclaimer.
11
// * Redistributions in binary form must reproduce the above copyright
12
// notice, this list of conditions and the following disclaimer in the
13
// documentation and/or other materials provided with the distribution.
14
//
15
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
16
// IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17
// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
18
// PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19
// HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
21
// TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
23
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
27
#ifndef G2O_EDGE_TYPES_COST_FUNCTION_
28
#define G2O_EDGE_TYPES_COST_FUNCTION_
29
30
#include <string>
31
32
#include "
g2o/core/hyper_dijkstra.h
"
33
#include "
g2o/core/optimizable_graph.h
"
34
35
namespace
g2o
{
36
37
class
Factory;
38
44
struct
EdgeTypesCostFunction
:
public
HyperDijkstra::CostFunction
{
50
EdgeTypesCostFunction
(
const
std::string& edgeTag,
51
const
std::string& vertexTag,
int
level);
52
54
virtual
double
operator()
(
HyperGraph::Edge
* e_,
HyperGraph::Vertex
* from,
55
HyperGraph::Vertex
* to);
56
57
std::string
_edgeTag
;
58
std::string
_vertexTag
;
59
Factory
*
_factory
;
60
int
_level
;
61
};
62
63
}
// namespace g2o
64
#endif
g2o::Factory
create vertices and edges based on TAGs in, for example, a file
Definition
factory.h:48
g2o::HyperGraph::Edge
Definition
hyper_graph.h:172
g2o::HyperGraph::Vertex
abstract Vertex, your types must derive from that one
Definition
hyper_graph.h:148
hyper_dijkstra.h
g2o
Definition
dl_wrapper.cpp:55
optimizable_graph.h
g2o::EdgeTypesCostFunction
Definition
edge_types_cost_function.h:44
g2o::EdgeTypesCostFunction::_edgeTag
std::string _edgeTag
Definition
edge_types_cost_function.h:57
g2o::EdgeTypesCostFunction::_vertexTag
std::string _vertexTag
Definition
edge_types_cost_function.h:58
g2o::EdgeTypesCostFunction::operator()
virtual double operator()(HyperGraph::Edge *e_, HyperGraph::Vertex *from, HyperGraph::Vertex *to)
cost operator
Definition
edge_types_cost_function.cpp:43
g2o::EdgeTypesCostFunction::_level
int _level
Definition
edge_types_cost_function.h:60
g2o::EdgeTypesCostFunction::_factory
Factory * _factory
Definition
edge_types_cost_function.h:59
g2o::HyperDijkstra::CostFunction
Definition
hyper_dijkstra.h:39
Generated on Tue Nov 11 2025 05:18:45 for g2o by
1.9.8