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 CMultiMetricMapPDF_H
00029 #define CMultiMetricMapPDF_H
00030
00031 #include <mrpt/slam/CMultiMetricMap.h>
00032 #include <mrpt/slam/CSimpleMap.h>
00033 #include <mrpt/poses/CPosePDFParticles.h>
00034 #include <mrpt/poses/CPose3DPDFParticles.h>
00035
00036 #include <mrpt/poses/CPoseRandomSampler.h>
00037
00038 #include <mrpt/bayes/CParticleFilterCapable.h>
00039 #include <mrpt/utils/CLoadableOptions.h>
00040 #include <mrpt/slam/CICP.h>
00041
00042 #include <mrpt/slam/PF_implementations_data.h>
00043
00044 #include <mrpt/slam/link_pragmas.h>
00045
00046 namespace mrpt
00047 {
00048 namespace slam
00049 {
00050 DEFINE_SERIALIZABLE_PRE_CUSTOM_BASE_LINKAGE( CRBPFParticleData, mrpt::utils::CSerializable, SLAM_IMPEXP )
00051
00052
00053
00054 class SLAM_IMPEXP CRBPFParticleData : public mrpt::utils::CSerializable
00055 {
00056
00057 DEFINE_SERIALIZABLE( CRBPFParticleData )
00058 public:
00059 CRBPFParticleData( const TSetOfMetricMapInitializers *mapsInitializers = NULL ) :
00060 mapTillNow( mapsInitializers ),
00061 robotPath()
00062 {
00063 }
00064
00065 CMultiMetricMap mapTillNow;
00066 std::deque<TPose3D> robotPath;
00067 };
00068
00069
00070 DEFINE_SERIALIZABLE_PRE_CUSTOM_BASE_LINKAGE( CMultiMetricMapPDF, mrpt::utils::CSerializable, SLAM_IMPEXP )
00071
00072
00073
00074
00075
00076
00077 class SLAM_IMPEXP CMultiMetricMapPDF :
00078 public mrpt::utils::CSerializable,
00079 public mrpt::bayes::CParticleFilterData<CRBPFParticleData>,
00080 public mrpt::bayes::CParticleFilterCapable,
00081 public mrpt::slam::PF_implementation<CRBPFParticleData>
00082 {
00083 friend class CMetricMapBuilderRBPF;
00084
00085
00086 DEFINE_SERIALIZABLE( CMultiMetricMapPDF )
00087
00088
00089 IMPLEMENT_PARTICLE_FILTER_CAPABLE(CRBPFParticleData);
00090
00091 protected:
00092
00093
00094 void prediction_and_update_pfStandardProposal(
00095 const mrpt::slam::CActionCollection * action,
00096 const mrpt::slam::CSensoryFrame * observation,
00097 const bayes::CParticleFilter::TParticleFilterOptions &PF_options );
00098
00099
00100
00101 void prediction_and_update_pfOptimalProposal(
00102 const mrpt::slam::CActionCollection * action,
00103 const mrpt::slam::CSensoryFrame * observation,
00104 const bayes::CParticleFilter::TParticleFilterOptions &PF_options );
00105
00106
00107
00108 void prediction_and_update_pfAuxiliaryPFOptimal(
00109 const mrpt::slam::CActionCollection * action,
00110 const mrpt::slam::CSensoryFrame * observation,
00111 const bayes::CParticleFilter::TParticleFilterOptions &PF_options );
00112
00113
00114 private:
00115
00116
00117 CMultiMetricMap averageMap;
00118 bool averageMapIsUpdated;
00119
00120
00121
00122 CSimpleMap SFs;
00123
00124
00125
00126 std::vector<uint32_t> SF2robotPath;
00127
00128
00129
00130
00131 float H(float p);
00132
00133 public:
00134
00135
00136
00137
00138
00139 struct SLAM_IMPEXP TPredictionParams : public utils::CLoadableOptions
00140 {
00141
00142
00143 TPredictionParams();
00144
00145
00146
00147 void loadFromConfigFile(
00148 const mrpt::utils::CConfigFileBase &source,
00149 const std::string §ion);
00150
00151
00152
00153 void dumpToTextStream(CStream &out) const;
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164 int pfOptimalProposal_mapSelection;
00165
00166
00167
00168
00169 float ICPGlobalAlign_MinQuality;
00170
00171
00172
00173 COccupancyGridMap2D::TLikelihoodOptions update_gridMapLikelihoodOptions;
00174
00175 TKLDParams KLD_params;
00176
00177 CICP::TConfigParams icp_params;
00178
00179 } options;
00180
00181
00182
00183 CMultiMetricMapPDF(
00184 const bayes::CParticleFilter::TParticleFilterOptions &opts = bayes::CParticleFilter::TParticleFilterOptions(),
00185 const mrpt::slam::TSetOfMetricMapInitializers *mapsInitializers = NULL,
00186 const TPredictionParams *predictionOptions = NULL );
00187
00188
00189
00190 virtual ~CMultiMetricMapPDF();
00191
00192
00193 void clear( const CPose2D &initialPose );
00194
00195
00196 void clear( const CPose3D &initialPose );
00197
00198
00199
00200
00201 void getEstimatedPosePDFAtTime(
00202 size_t timeStep,
00203 CPose3DPDFParticles &out_estimation ) const;
00204
00205
00206
00207
00208 void getEstimatedPosePDF( CPose3DPDFParticles &out_estimation ) const;
00209
00210
00211
00212 CMultiMetricMap * getCurrentMetricMapEstimation( );
00213
00214
00215
00216 CMultiMetricMap * getCurrentMostLikelyMetricMap( );
00217
00218
00219 size_t getNumberOfObservationsInSimplemap() const { return SFs.size(); }
00220
00221
00222
00223
00224 void insertObservation(CSensoryFrame &sf);
00225
00226
00227
00228
00229 void getPath(size_t i, std::deque<math::TPose3D> &out_path) const;
00230
00231
00232
00233 double getCurrentEntropyOfPaths();
00234
00235
00236
00237 double getCurrentJointEntropy();
00238
00239
00240
00241 void updateSensoryFrameSequence();
00242
00243
00244
00245 void saveCurrentPathEstimationToTextFile( const std::string &fil );
00246
00247
00248
00249 float newInfoIndex;
00250
00251 private:
00252
00253
00254 void rebuildAverageMap();
00255
00256 protected:
00257
00258
00259
00260 const TPose3D * getLastPose(const size_t i) const;
00261
00262 void PF_SLAM_implementation_custom_update_particle_with_new_pose(
00263 CParticleDataContent *particleData,
00264 const TPose3D &newPose) const;
00265
00266
00267
00268
00269 bool PF_SLAM_implementation_doWeHaveValidObservations(
00270 const CParticleList &particles,
00271 const CSensoryFrame *sf) const;
00272
00273 bool PF_SLAM_implementation_skipRobotMovement() const;
00274
00275
00276 double PF_SLAM_computeObservationLikelihoodForParticle(
00277 const CParticleFilter::TParticleFilterOptions &PF_options,
00278 const size_t particleIndexForMap,
00279 const CSensoryFrame &observation,
00280 const CPose3D &x ) const;
00281
00282
00283
00284 };
00285
00286 }
00287 }
00288
00289 #endif