nao_footprint.hpp
Go to the documentation of this file.
00001 /*
00002  * Copyright 2015 Aldebaran
00003  *
00004  * Licensed under the Apache License, Version 2.0 (the "License");
00005  * you may not use this file except in compliance with the License.
00006  * You may obtain a copy of the License at
00007  *
00008  *     http://www.apache.org/licenses/LICENSE-2.0
00009  *
00010  * Unless required by applicable law or agreed to in writing, software
00011  * distributed under the License is distributed on an "AS IS" BASIS,
00012  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00013  * See the License for the specific language governing permissions and
00014  * limitations under the License.
00015  *
00016 */
00017 
00018 #ifndef NAO_FOOTPRINT_HPP
00019 #define NAO_FOOTPRINT_HPP
00020 
00021 /*
00022 * ROS includes
00023 */
00024 #include <tf2/LinearMath/Transform.h>
00025 #include <geometry_msgs/Transform.h>
00026 #include <tf2_geometry_msgs/tf2_geometry_msgs.h>
00027 
00028 /*
00029 * loca includes
00030 */
00031 #include "../helpers/transform_helpers.hpp"
00032 
00033 namespace naoqi
00034 {
00035 namespace converter
00036 {
00037 namespace nao
00038 {
00039 
00040 inline void addBaseFootprint( boost::shared_ptr<tf2_ros::Buffer> tf2_buffer, std::vector<geometry_msgs::TransformStamped>& tf_transforms, const ros::Time& time )
00041 {
00042   bool canTransform = tf2_buffer->canTransform("odom", "l_sole", time, ros::Duration(0.1) );
00043   if (!canTransform)
00044   {
00045     ROS_ERROR_STREAM("Do not calculate NAO Footprint, no transform possible " << time);
00046     return;
00047   }
00048 
00049   geometry_msgs::TransformStamped tf_odom_to_base, tf_odom_to_left_foot, tf_odom_to_right_foot;
00050   try {
00051     // TRANSFORM THEM DIRECTLY INTO TRANSFORM
00052     tf_odom_to_left_foot  = tf2_buffer->lookupTransform("odom", "l_sole",    time );
00053     tf_odom_to_right_foot = tf2_buffer->lookupTransform("odom", "r_sole",    time );
00054     tf_odom_to_base       = tf2_buffer->lookupTransform("odom", "base_link", time );
00055   } catch (const tf::TransformException& ex){
00056     ROS_ERROR("NAO Footprint error %s",ex.what());
00057     return ;
00058   }
00059   // middle of both feet
00060   // z = fix to the lowest foot
00061   tf2::Vector3 new_origin(
00062       float(tf_odom_to_right_foot.transform.translation.x + tf_odom_to_left_foot.transform.translation.x)/2.0,
00063       float(tf_odom_to_right_foot.transform.translation.y + tf_odom_to_left_foot.transform.translation.y)/2.0,
00064       std::min(tf_odom_to_left_foot.transform.translation.z, tf_odom_to_right_foot.transform.translation.z)
00065       );
00066 
00067   // adjust yaw according to torso orientation, all other angles 0 (= in z-plane)
00068   double yaw = helpers::transform::getYaw( tf_odom_to_base.transform ) ;
00069   tf2::Quaternion new_q;
00070   new_q.setRPY(0.0f, 0.0f, yaw);
00071   tf2::Transform tf_odom_to_footprint( new_q, new_origin);
00072 
00073   // way too complicated here, there should be proper conversions!
00074   tf2::Quaternion q( tf_odom_to_base.transform.rotation.x,
00075                      tf_odom_to_base.transform.rotation.y,
00076                      tf_odom_to_base.transform.rotation.z,
00077                      tf_odom_to_base.transform.rotation.w
00078       );
00079   tf2::Vector3 r( tf_odom_to_base.transform.translation.x,
00080                   tf_odom_to_base.transform.translation.y,
00081                   tf_odom_to_base.transform.translation.z
00082       );
00083   tf2::Transform tf_odom_to_base_conv( q,r);
00084   //tf2::Transform tf_odom_to_base_conv;
00085   //tf2::convert( tf_odom_to_base.transform, tf_odom_to_base_conv );
00086   tf2::Transform tf_base_to_footprint = tf_odom_to_base_conv.inverse() * tf_odom_to_footprint;
00087 
00088   // convert it back to geometry_msgs
00089   geometry_msgs::TransformStamped message;
00090   //message.transform = tf2::toMsg(tf_base_to_footprint);
00091   message.header.stamp = time;
00092   message.header.frame_id = "base_link";
00093   message.child_frame_id = "base_footprint";
00094 
00095   message.transform.rotation.x = tf_base_to_footprint.getRotation().x();
00096   message.transform.rotation.y = tf_base_to_footprint.getRotation().y();
00097   message.transform.rotation.z = tf_base_to_footprint.getRotation().z();
00098   message.transform.rotation.w = tf_base_to_footprint.getRotation().w();
00099   message.transform.translation.x = tf_base_to_footprint.getOrigin().x();
00100   message.transform.translation.y = tf_base_to_footprint.getOrigin().y();
00101   message.transform.translation.z = tf_base_to_footprint.getOrigin().z();
00102 
00103   //tf::transformTFToMsg( tf_base_to_footprint, message.transform);
00104   // publish transform with parent m_baseFrameId and new child m_baseFootPrintID
00105   // i.e. transform from m_baseFrameId to m_baseFootPrintID
00106   tf2_buffer->setTransform( message, "naoqiconverter", false );
00107   tf_transforms.push_back( message );
00108 }
00109 
00110 } // nao
00111 } // converter
00112 } // naoqi
00113 
00114 #endif


naoqi_driver
Author(s): Karsten Knese
autogenerated on Sun Sep 17 2017 02:57:14