g2o
Loading...
Searching...
No Matches
g2o
types
sba
edge_project_stereo_xyz.h
Go to the documentation of this file.
1
// g2o - General Graph Optimization
2
// Copyright (C) 2011 H. Strasdat
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_SBA_EDGEPROJECTSTEREOXYZ_H
28
#define G2O_SBA_EDGEPROJECTSTEREOXYZ_H
29
30
#include "
g2o/core/base_binary_edge.h
"
31
#include "
g2o/types/slam3d/vertex_pointxyz.h
"
32
#include "
g2o_types_sba_api.h
"
33
#include "
vertex_se3_expmap.h
"
34
35
namespace
g2o
{
36
37
// Projection using focal_length in x and y directions stereo
38
class
G2O_TYPES_SBA_API
EdgeStereoSE3ProjectXYZ
39
:
public
BaseBinaryEdge
<3, Vector3, VertexPointXYZ, VertexSE3Expmap> {
40
public
:
41
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
42
43
EdgeStereoSE3ProjectXYZ
();
44
45
bool
read(std::istream& is);
46
47
bool
write(std::ostream& os)
const
;
48
49
void
computeError
() {
50
const
VertexSE3Expmap
* v1 =
51
static_cast<
const
VertexSE3Expmap
*
>
(_vertices[1]);
52
const
VertexPointXYZ
* v2 =
static_cast<
const
VertexPointXYZ
*
>
(_vertices[0]);
53
Vector3
obs(_measurement);
54
_error = obs - cam_project(v1->
estimate
().
map
(v2->
estimate
()), bf);
55
}
56
57
bool
isDepthPositive
() {
58
const
VertexSE3Expmap
* v1 =
59
static_cast<
const
VertexSE3Expmap
*
>
(_vertices[1]);
60
const
VertexPointXYZ
* v2 =
static_cast<
const
VertexPointXYZ
*
>
(_vertices[0]);
61
return
(v1->
estimate
().
map
(v2->
estimate
()))(2) > 0;
62
}
63
64
virtual
void
linearizeOplus();
65
66
Vector3
cam_project(
const
Vector3
& trans_xyz,
const
float
& bf)
const
;
67
68
double
fx = 1., fy = 1., cx = 0.5, cy = 0.5, bf = 0;
69
};
70
71
}
// namespace g2o
72
73
#endif
base_binary_edge.h
g2o::BaseBinaryEdge
Definition
base_binary_edge.h:37
g2o::BaseVertex::estimate
const EstimateType & estimate() const
return the current estimate of the vertex
Definition
base_vertex.h:127
g2o::EdgeStereoSE3ProjectXYZ
Definition
edge_project_stereo_xyz.h:39
g2o::EdgeStereoSE3ProjectXYZ::computeError
void computeError()
Definition
edge_project_stereo_xyz.h:49
g2o::EdgeStereoSE3ProjectXYZ::isDepthPositive
bool isDepthPositive()
Definition
edge_project_stereo_xyz.h:57
g2o::SE3Quat::map
Vector3 map(const Vector3 &xyz) const
Definition
se3quat.h:200
g2o::VertexPointXYZ
Vertex for a tracked point in space.
Definition
vertex_pointxyz.h:38
g2o::VertexSE3Expmap
SE3 Vertex parameterized internally with a transformation matrix and externally with its exponential ...
Definition
vertex_se3_expmap.h:40
g2o_types_sba_api.h
G2O_TYPES_SBA_API
#define G2O_TYPES_SBA_API
Definition
g2o_types_sba_api.h:55
g2o
Definition
dl_wrapper.cpp:55
g2o::Vector3
VectorN< 3 > Vector3
Definition
eigen_types.h:51
vertex_pointxyz.h
vertex_se3_expmap.h
Generated on Tue Nov 11 2025 05:18:45 for g2o by
1.9.8