Optimizer.h
Go to the documentation of this file.
00001 /*
00002 Copyright (c) 2010-2016, Mathieu Labbe - IntRoLab - Universite de Sherbrooke
00003 All rights reserved.
00004 
00005 Redistribution and use in source and binary forms, with or without
00006 modification, are permitted provided that the following conditions are met:
00007     * Redistributions of source code must retain the above copyright
00008       notice, this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright
00010       notice, this list of conditions and the following disclaimer in the
00011       documentation and/or other materials provided with the distribution.
00012     * Neither the name of the Universite de Sherbrooke nor the
00013       names of its contributors may be used to endorse or promote products
00014       derived from this software without specific prior written permission.
00015 
00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00017 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00018 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY
00020 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00021 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00022 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00023 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00024 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00025 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026 */
00027 
00028 #ifndef OPTIMIZER_H_
00029 #define OPTIMIZER_H_
00030 
00031 #include "rtabmap/core/RtabmapExp.h" // DLL export/import defines
00032 
00033 #include <map>
00034 #include <list>
00035 #include <rtabmap/core/Link.h>
00036 #include <rtabmap/core/Parameters.h>
00037 #include <rtabmap/core/Signature.h>
00038 
00039 namespace rtabmap {
00040 
00042 // Graph optimizers
00044 class RTABMAP_EXP Optimizer
00045 {
00046 public:
00047         enum Type {
00048                 kTypeUndef = -1,
00049                 kTypeTORO = 0,
00050                 kTypeG2O = 1,
00051                 kTypeGTSAM = 2,
00052                 kTypeCVSBA = 3
00053         };
00054         static bool isAvailable(Optimizer::Type type);
00055         static Optimizer * create(const ParametersMap & parameters);
00056         static Optimizer * create(Optimizer::Type type, const ParametersMap & parameters = ParametersMap());
00057 
00058         // Get connected poses and constraints from a set of links
00059         static void getConnectedGraph(
00060                         int fromId,
00061                         const std::map<int, Transform> & posesIn,
00062                         const std::multimap<int, Link> & linksIn, // only one link between two poses
00063                         std::map<int, Transform> & posesOut,
00064                         std::multimap<int, Link> & linksOut,
00065                         int depth = 0);
00066 
00067 public:
00068         virtual ~Optimizer() {}
00069 
00070         virtual Type type() const = 0;
00071 
00072         // getters
00073         int iterations() const {return iterations_;}
00074         bool isSlam2d() const {return slam2d_;}
00075         bool isCovarianceIgnored() const {return covarianceIgnored_;}
00076         double epsilon() const {return epsilon_;}
00077         bool isRobust() const {return robust_;}
00078 
00079         // setters
00080         void setIterations(int iterations) {iterations_ = iterations;}
00081         void setSlam2d(bool enabled) {slam2d_ = enabled;}
00082         void setCovarianceIgnored(bool enabled) {covarianceIgnored_ = enabled;}
00083         void setEpsilon(double epsilon) {epsilon_ = epsilon;}
00084         void setRobust(bool enabled) {robust_ = enabled;}
00085 
00086         // inherited classes should implement one of these methods
00087         virtual std::map<int, Transform> optimize(
00088                         int rootId,
00089                         const std::map<int, Transform> & poses,
00090                         const std::multimap<int, Link> & constraints,
00091                         std::list<std::map<int, Transform> > * intermediateGraphes = 0,
00092                         double * finalError = 0,
00093                         int * iterationsDone = 0);
00094         virtual std::map<int, Transform> optimizeBA(
00095                         int rootId,
00096                         const std::map<int, Transform> & poses,
00097                         const std::multimap<int, Link> & links,
00098                         const std::map<int, Signature> & signatures);
00099 
00100         virtual void parseParameters(const ParametersMap & parameters);
00101 
00102         void computeBACorrespondences(
00103                         const std::map<int, Transform> & poses,
00104                         const std::multimap<int, Link> & links,
00105                         const std::map<int, Signature> & signatures,
00106                         std::map<int, cv::Point3f> & points3DMap,
00107                         std::map<int, std::map<int, cv::Point2f> > & wordReferences); // <ID words, IDs frames + keypoint>
00108 
00109 protected:
00110         Optimizer(
00111                         int iterations         = Parameters::defaultOptimizerIterations(),
00112                         bool slam2d            = Parameters::defaultOptimizerSlam2D(),
00113                         bool covarianceIgnored = Parameters::defaultOptimizerVarianceIgnored(),
00114                         double epsilon         = Parameters::defaultOptimizerEpsilon(),
00115                         bool robust            = Parameters::defaultOptimizerRobust());
00116         Optimizer(const ParametersMap & parameters);
00117 
00118 private:
00119         int iterations_;
00120         bool slam2d_;
00121         bool covarianceIgnored_;
00122         double epsilon_;
00123         bool robust_;
00124 };
00125 
00126 } /* namespace rtabmap */
00127 #endif /* OPTIMIZER_H_ */


rtabmap
Author(s): Mathieu Labbe
autogenerated on Sat Jul 23 2016 11:44:17