g2o
Loading...
Searching...
No Matches
parameter_camera.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 G2O_CAMERA_PARAMETERS_H_
28#define G2O_CAMERA_PARAMETERS_H_
29
33
34namespace g2o {
39 public:
42 void setKcam(double fx, double fy, double cx, double cy);
43 void setOffset(const Isometry3& offset_ = Isometry3::Identity());
44
45 virtual bool read(std::istream& is);
46 virtual bool write(std::ostream& os) const;
47
48 const Matrix3& Kcam() const { return _Kcam; }
49 const Matrix3& invKcam() const { return _invKcam; }
50 const Matrix3& Kcam_inverseOffsetR() const { return _Kcam_inverseOffsetR; }
51
52 protected:
56};
57
59 public:
62 const ParameterCamera* camParams() const { return params; }
64 const Affine3& w2i() const { return _w2i; }
65
66 protected:
67 virtual void updateImpl();
68 virtual bool resolveDependencies();
71};
72
73#ifdef G2O_HAVE_OPENGL
74class G2O_TYPES_SLAM3D_API CacheCameraDrawAction : public DrawAction {
75 public:
76 CacheCameraDrawAction();
77 virtual HyperGraphElementAction* operator()(
80
81 protected:
82 virtual bool refreshPropertyPtrs(
84 FloatProperty *_cameraZ, *_cameraSide;
85};
86#endif
87
88} // namespace g2o
89
90#endif
Affine3 _w2i
world to image transform
const ParameterCamera * camParams() const
parameters of the camera
const Affine3 & w2i() const
return the world to image transform
ParameterCamera * params
caching the offset related to a vertex
Abstract action that operates on a graph entity.
parameters for a camera
const Matrix3 & Kcam() const
const Matrix3 & invKcam() const
const Matrix3 & Kcam_inverseOffsetR() const
#define G2O_TYPES_SLAM3D_API
MatrixN< 3 > Matrix3
Definition eigen_types.h:72
Eigen::Transform< double, 3, Eigen::Isometry, Eigen::ColMajor > Isometry3
Definition eigen_types.h:77
Eigen::Transform< double, 3, Eigen::Affine, Eigen::ColMajor > Affine3
Definition eigen_types.h:79
Property< float > FloatProperty
Definition property.h:150