odom_constraint_generator.cpp
Go to the documentation of this file.
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 #include <graph_slam/constraints/odom.h>
00041 #include <pose_graph/transforms.h>
00042 #include <pose_graph/utils.h>
00043 
00044 namespace graph_slam
00045 {
00046 
00047 using graph_slam::GraphLocalization;
00048 using pg::contains;
00049 namespace pg=pose_graph;
00050 using Eigen3::Affine3d;
00051 
00052 void OdomConstraintGenerator::initializeFromGraph (const pg::PoseGraph& g, const std::vector<pg::NodeId>& node_sequence)
00053 {
00054   if (node_sequence.size() > 0)
00055     last_node_ = *(--node_sequence.end());
00056 }
00057 
00058 void OdomConstraintGenerator::updateLocalization (const GraphLocalization& loc)
00059 {
00060   ROS_ASSERT_MSG(false, "Not implemented!");
00061 }
00062 
00063 NodeConstraintVector OdomConstraintGenerator::getConstraints (const pg::PoseGraph& graph,
00064                                                               const pg::NodeId new_node,
00065                                                               const NodePoseMap& optimized_poses)
00066 {
00067   NodeConstraintVector constraints;
00068 
00069   if (last_node_) {
00070     if (!contains(graph.neighbors(new_node), *last_node_)) {
00071       const Affine3d rel_transform = pg::relativeTransform(graph.getInitialPoseEstimate(new_node),
00072                                                               graph.getInitialPoseEstimate(*last_node_));
00073       // We're assuming an identity precision matrix
00074       pg::PoseConstraint constraint = pg::makeConstraint(rel_transform, pg::makePrecisionMatrix(1, 1, 1));
00075       constraints.push_back(NodeConstraint(*last_node_, constraint));
00076       ROS_DEBUG_STREAM_NAMED ("odom_constraint_generator", "Adding constraint from " << *last_node_ 
00077                               << " to " << new_node << " : " << constraint);
00078     }
00079     else {
00080       ROS_DEBUG_STREAM_NAMED ("odom_constraint_generator", "Not adding odom constraint between " << new_node <<
00081                               " and " << *last_node_ << " as there's already a constraint");
00082     }
00083   }
00084   else {
00085     ROS_DEBUG_NAMED ("odom_constraint_generator", "Not adding odom constraint for %lu as it's the first node",
00086                      new_node.getId());
00087   }
00088   last_node_ = new_node;
00089   return constraints;
00090 }
00091 
00092 } // namespace graph_slam
00093 
00094 


graph_slam
Author(s): Bhaskara Marthi
autogenerated on Tue Jan 7 2014 11:17:21