g2o
Loading...
Searching...
No Matches
edge_sba_cam.h
Go to the documentation of this file.
1// g2o - General Graph Optimization
2// Copyright (C) 2011 Kurt Konolige
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_EDGESBACAM_H
28#define G2O_SBA_EDGESBACAM_H
29
31#include "g2o_types_sba_api.h"
32#include "vertex_cam.h"
33
34namespace g2o {
35
40 : public BaseBinaryEdge<6, SE3Quat, VertexCam, VertexCam> {
41 public:
43 EdgeSBACam();
44 virtual bool read(std::istream& is);
45 virtual bool write(std::ostream& os) const;
46 void computeError();
47
48 virtual void setMeasurement(const SE3Quat& meas);
49
52 return cst(1.);
53 }
54 virtual void initialEstimate(const OptimizableGraph::VertexSet& from,
56
57 virtual bool setMeasurementData(const double* d);
58
59 virtual bool getMeasurementData(double* d) const;
60
61 virtual int measurementDimension() const { return 7; }
62
63 virtual bool setMeasurementFromState();
64
65 protected:
67};
68
69} // namespace g2o
70
71#endif
3D edge between two SBAcam
virtual int measurementDimension() const
virtual double initialEstimatePossible(const OptimizableGraph::VertexSet &, OptimizableGraph::Vertex *)
SE3Quat _inverseMeasurement
std::set< Vertex * > VertexSet
A general case Vertex for optimization.
#define G2O_TYPES_SBA_API
constexpr double cst(long double v)
Definition misc.h:60