00001 /* 00002 * Copyright (c) 2008, Willow Garage, Inc. 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 * 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 Willow Garage, Inc. nor the names of its 00014 * contributors may be used to endorse or promote products derived from 00015 * this software without specific prior written permission. 00016 * 00017 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00018 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00019 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00020 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00021 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00022 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00023 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00024 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00025 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00026 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00027 * POSSIBILITY OF SUCH DAMAGE. 00028 * 00029 */ 00030 00031 00040 #ifndef POSE_GRAPH_SCAN_MATCH_LOCALIZATION_H 00041 #define POSE_GRAPH_SCAN_MATCH_LOCALIZATION_H 00042 00043 #include <graph_slam/scan_manager.h> 00044 #include <pose_graph/transforms.h> 00045 00046 namespace graph_slam 00047 { 00048 00049 struct LocalizationState 00050 { 00051 LocalizationState (const pose_graph::NodeId n, const Eigen3::Affine3d trans, const Pose& pose, 00052 const ros::Time& stamp) : 00053 ref_node(n), node_to_fixed_frame(trans), node_frame_pose(pose), stamp(stamp) {} 00054 00055 pose_graph::NodeId ref_node; 00056 Eigen3::Affine3d node_to_fixed_frame; 00057 Pose node_frame_pose; 00058 ros::Time stamp; 00059 }; 00060 00061 class ScanMatchLocalization : public ScanManager 00062 { 00063 public: 00064 00069 ScanMatchLocalization (const geometry_msgs::Pose2D& laser_offset, double neighborhood_size, 00070 const unsigned localizations_per_scan_match); 00071 00073 LocalizationState nextState (const LocalizationState& state, 00074 const Pose& fixed_frame_pose, const LaserPtr scan, 00075 const pose_graph::PoseGraph& graph, const NodePoseMap& optimized_poses) const; 00076 00077 00078 private: 00079 00080 const double max_link_length_; 00081 00082 // Mutable because it is initialized in nextState, which is logically const 00083 mutable KartoMatcherPtr matcher_; 00084 00085 const unsigned localizations_per_scan_match_; 00086 00087 }; 00088 00089 00090 00091 00092 00093 00094 00095 } // namespace graph_slam 00096 00097 #endif // include guard