g2o_slam_interface.h
Go to the documentation of this file.
00001 // g2o - General Graph Optimization
00002 // Copyright (C) 2011 R. Kuemmerle, G. Grisetti, W. Burgard
00003 // 
00004 // g2o is free software: you can redistribute it and/or modify
00005 // it under the terms of the GNU Lesser General Public License as published
00006 // by the Free Software Foundation, either version 3 of the License, or
00007 // (at your option) any later version.
00008 // 
00009 // g2o is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012 // GNU Lesser General Public License for more details.
00013 // 
00014 // You should have received a copy of the GNU Lesser General Public License
00015 // along with this program.  If not, see <http://www.gnu.org/licenses/>.
00016 
00017 #ifndef G2O_SLAM_INTERFACE_H
00018 #define G2O_SLAM_INTERFACE_H
00019 
00020 #include "g2o/core/optimizable_graph.h"
00021 #include "slam_parser/interface/abstract_slam_interface.h"
00022 
00023 #include <map>
00024 #include <vector>
00025 
00026 namespace g2o {
00027 
00028   class SparseOptimizerOnline;
00029 
00030   class G2oSlamInterface : public SlamParser::AbstractSlamInterface
00031   {
00032     public:
00033       G2oSlamInterface(SparseOptimizerOnline* optimizer);
00034 
00035       bool addNode(const std::string& tag, int id, int dimension, const std::vector<double>& values);
00036 
00037       bool addEdge(const std::string& tag, int id, int dimension, int v1, int v2, const std::vector<double>& measurement, const std::vector<double>& information);
00038 
00039       bool fixNode(const std::vector<int>& nodes);
00040 
00041       bool queryState(const std::vector<int>& nodes);
00042 
00043       bool solveState();
00044 
00045       int updatedGraphEachN() const { return _updateGraphEachN;}
00046       void setUpdateGraphEachN(int n);
00047 
00048     protected:
00049       SparseOptimizerOnline* _optimizer;
00050       bool _firstOptimization;
00051       int _nodesAdded;
00052       int _incIterations;
00053       int _updateGraphEachN;
00054       int _batchEveryN;
00055       int _lastBatchStep;
00056       bool _initSolverDone;
00057 
00058       HyperGraph::VertexSet _verticesAdded;
00059       HyperGraph::EdgeSet _edgesAdded;
00060 
00061       OptimizableGraph::Vertex* addVertex(int dimension, int id);
00062       bool printVertex(OptimizableGraph::Vertex* v);
00063   };
00064 
00065 } // end namespace
00066 
00067 #endif


re_vision
Author(s): Dorian Galvez-Lopez
autogenerated on Sun Jan 5 2014 11:31:13