g2o
Loading...
Searching...
No Matches
g2o
core
jacobian_workspace.h
Go to the documentation of this file.
1
// g2o - General Graph Optimization
2
// Copyright (C) 2011 R. Kuemmerle, G. Grisetti, 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 JACOBIAN_WORKSPACE_H
28
#define JACOBIAN_WORKSPACE_H
29
30
#include <Eigen/Core>
31
#include <cassert>
32
#include <vector>
33
34
#include "
g2o/core/eigen_types.h
"
35
#include "
g2o_core_api.h
"
36
#include "
hyper_graph.h
"
37
38
namespace
g2o
{
39
40
struct
OptimizableGraph;
41
53
class
G2O_CORE_API
JacobianWorkspace
{
54
public
:
55
using
WorkspaceVector
= std::vector<VectorX>;
56
57
public
:
58
JacobianWorkspace
();
59
~JacobianWorkspace
();
60
64
bool
allocate();
65
70
void
updateSize(
const
HyperGraph::Edge
* e,
bool
reset);
75
void
updateSize(
const
HyperGraph::Edge
* e);
76
80
void
updateSize(
const
OptimizableGraph
& graph,
bool
reset =
false
);
81
85
void
updateSize(
int
numVertices,
int
dimension,
bool
reset =
false
);
86
90
void
setZero();
91
95
double
*
workspaceForVertex
(
int
vertexIndex) {
96
assert(vertexIndex >= 0 && (
size_t
)vertexIndex < _workspace.size() &&
97
"Index out of bounds"
);
98
return
_workspace[vertexIndex].data();
99
}
100
101
protected
:
102
WorkspaceVector
103
_workspace
;
104
int
_maxNumVertices
;
106
int
_maxDimension
;
108
};
109
110
}
// namespace g2o
111
112
#endif
g2o::HyperGraph::Edge
Definition
hyper_graph.h:172
g2o::JacobianWorkspace
provide memory workspace for computing the Jacobians
Definition
jacobian_workspace.h:53
g2o::JacobianWorkspace::workspaceForVertex
double * workspaceForVertex(int vertexIndex)
Definition
jacobian_workspace.h:95
g2o::JacobianWorkspace::_maxNumVertices
int _maxNumVertices
Definition
jacobian_workspace.h:104
g2o::JacobianWorkspace::WorkspaceVector
std::vector< VectorX > WorkspaceVector
Definition
jacobian_workspace.h:55
g2o::JacobianWorkspace::_maxDimension
int _maxDimension
Definition
jacobian_workspace.h:106
g2o::JacobianWorkspace::_workspace
WorkspaceVector _workspace
the memory pre-allocated for computing the Jacobians
Definition
jacobian_workspace.h:103
eigen_types.h
g2o_core_api.h
G2O_CORE_API
#define G2O_CORE_API
Definition
g2o_core_api.h:29
hyper_graph.h
g2o
Definition
dl_wrapper.cpp:55
g2o::OptimizableGraph
Definition
optimizable_graph.h:62
Generated on Tue Nov 11 2025 05:18:45 for g2o by
1.9.8