Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef OPTIMIZERTORO_H_
00029 #define OPTIMIZERTORO_H_
00030
00031 #include "rtabmap/core/RtabmapExp.h"
00032
00033 #include <rtabmap/core/Optimizer.h>
00034
00035 namespace rtabmap {
00036
00037 class RTABMAP_EXP OptimizerTORO : public Optimizer
00038 {
00039 public:
00040 static bool available();
00041
00042 public:
00043 static bool saveGraph(
00044 const std::string & fileName,
00045 const std::map<int, Transform> & poses,
00046 const std::multimap<int, Link> & edgeConstraints);
00047 static bool loadGraph(
00048 const std::string & fileName,
00049 std::map<int, Transform> & poses,
00050 std::multimap<int, Link> & edgeConstraints);
00051
00052 public:
00053 OptimizerTORO(
00054 int iterations = Parameters::defaultOptimizerIterations(),
00055 bool slam2d = Parameters::defaultOptimizerSlam2D(),
00056 bool covarianceIgnored = Parameters::defaultOptimizerVarianceIgnored(),
00057 double epsilon = Parameters::defaultOptimizerEpsilon()) :
00058 Optimizer(iterations, slam2d, covarianceIgnored, epsilon) {}
00059 OptimizerTORO(const ParametersMap & parameters) :
00060 Optimizer(parameters) {}
00061 virtual ~OptimizerTORO() {}
00062
00063 virtual Type type() const {return kTypeTORO;}
00064
00065 virtual std::map<int, Transform> optimize(
00066 int rootId,
00067 const std::map<int, Transform> & poses,
00068 const std::multimap<int, Link> & edgeConstraints,
00069 std::list<std::map<int, Transform> > * intermediateGraphes = 0,
00070 double * finalError = 0,
00071 int * iterationsDone = 0);
00072 };
00073
00074 }
00075 #endif