mrpt_localization_core.h
Go to the documentation of this file.
00001 /***********************************************************************************
00002  * Revised BSD License                                                             *
00003  * Copyright (c) 2014, Markus Bader <markus.bader@tuwien.ac.at>                    *
00004  * All rights reserved.                                                            *
00005  *                                                                                 *
00006  * Redistribution and use in source and binary forms, with or without              *
00007  * modification, are permitted provided that the following conditions are met:     *
00008  *     * Redistributions of source code must retain the above copyright            *
00009  *       notice, this list of conditions and the following disclaimer.             *
00010  *     * Redistributions in binary form must reproduce the above copyright         *
00011  *       notice, this list of conditions and the following disclaimer in the       *
00012  *       documentation and/or other materials provided with the distribution.      *
00013  *     * Neither the name of the Vienna University of Technology nor the           *
00014  *       names of its contributors may be used to endorse or promote products      *
00015  *       derived from this software without specific prior written permission.     *
00016  *                                                                                 *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND *
00018  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED   *
00019  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE          *
00020  * DISCLAIMED. IN NO EVENT SHALL Markus Bader BE LIABLE FOR ANY                    *
00021  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES      *
00022  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;    *
00023  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND     *
00024  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT      *
00025  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS   *
00026  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.                    *                       *
00027  ***********************************************************************************/
00028 
00029 #include <iostream>
00030 #include <stdint.h>
00031 #include <mrpt/base.h>
00032 #include <mrpt/slam.h>
00033 #include <mrpt_bridge/mrpt_log_macros.h>
00034 
00035 #ifndef MRPT_LOCALIZATION_CORE_H
00036 #define MRPT_LOCALIZATION_CORE_H
00037 
00038 
00039 class PFLocalizationCore {
00040   MRPT_VIRTUAL_LOG_MACROS;
00041 public:
00042     enum PFStates {NA, INIT, RUN} ;
00043     PFLocalizationCore ();
00044     ~PFLocalizationCore();
00045     void init();
00046 protected:
00047     mrpt::slam::CActionRobotMovement2D::TMotionModelOptions odom_params_dummy_;
00048     mrpt::slam::CActionRobotMovement2D::TMotionModelOptions odom_params_;
00049     mrpt::slam::CMultiMetricMap metric_map_;
00050     mrpt::slam::CMonteCarloLocalization2D  pdf_;
00051     mrpt::bayes::CParticleFilter pf_;
00052     mrpt::bayes::CParticleFilter::TParticleFilterStats   pf_stats_;
00053     mrpt::utils::CPosePDFGaussian initialPose_;
00054     mrpt::system::TTimeStamp timeLastUpdate_;
00055     mrpt::utils::CTicTac tictac_;
00056     size_t update_counter_;
00057     PFStates state_;
00058     mrpt::poses::CPose2D odomLastObservation_;
00059 
00060     int initialParticleCount_;
00061     void initializeFilter(mrpt::utils::CPosePDFGaussian &p);
00062     void observation(mrpt::slam::CSensoryFramePtr _sf, mrpt::slam::CObservationOdometryPtr _odometry);
00063     void updateFilter(mrpt::slam::CActionCollectionPtr _action, mrpt::slam::CSensoryFramePtr _sf);
00064 };
00065 
00066 #endif // MRPT_LOCALIZATION_CORE_H
00067 


mrpt_localization
Author(s):
autogenerated on Tue Aug 5 2014 10:58:12