quat_to_euler.cpp
Go to the documentation of this file.
00001 /*********************************************************************
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2010, LABUST, UNIZG-FER
00005  *  All rights reserved.
00006  *
00007  *  Redistribution and use in source and binary forms, with or without
00008  *  modification, are permitted provided that the following conditions
00009  *  are met:
00010  *
00011  *   * Redistributions of source code must retain the above copyright
00012  *     notice, this list of conditions and the following disclaimer.
00013  *   * Redistributions in binary form must reproduce the above
00014  *     copyright notice, this list of conditions and the following
00015  *     disclaimer in the documentation and/or other materials provided
00016  *     with the distribution.
00017  *   * Neither the name of the LABUST nor the names of its
00018  *     contributors may be used to endorse or promote products derived
00019  *     from this software without specific prior written permission.
00020  *
00021  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029  *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030  *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031  *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032  *  POSSIBILITY OF SUCH DAMAGE.
00033  *
00034  *  Author : Dula Nad
00035  *  Created: 26.03.2013.
00036  *********************************************************************/
00037 #include <labust/tools/conversions.hpp>
00038 
00039 #include <auv_msgs/RPY.h>
00040 #include <sensor_msgs/Imu.h>
00041 
00042 #include <ros/ros.h>
00043 
00044 void handleImu(ros::Publisher& rpy, const sensor_msgs::Imu::ConstPtr& data)
00045 {
00046         double roll,pitch,yaw;
00047         labust::tools::eulerZYXFromQuaternion(data->orientation, roll, pitch, yaw);
00048         geometry_msgs::Quaternion q = data->orientation;
00049         //roll = atan2(2*(q.y*q.z - q.x*q.w),1-2*(q.x*q.x + q.y*q.y));
00050         //pitch = -asin(2*(q.x*q.z + q.y*q.w));
00051         //yaw = atan2(2*(q.x*q.y-q.w*q.z),1-2*(q.y*q.y+q.z*q.z));
00052         auv_msgs::RPY out;
00053         out.roll = roll/M_PI*180;
00054         out.pitch = pitch/M_PI*180;
00055         out.yaw = yaw/M_PI*180;
00056         rpy.publish(out);
00057 
00058         ROS_INFO("R=%f,P=%f,Y=%f",roll, pitch, yaw);
00059 };
00060 
00061 
00062 
00063 int main(int argc, char* argv[])
00064 {
00065         ros::init(argc,argv,"quat_to_euler");
00066 
00067         ros::NodeHandle nh;
00068 
00069         //Publishers
00070         ros::Publisher rpy = nh.advertise<auv_msgs::RPY>("rpy",1);
00071         ros::Subscriber imu = nh.subscribe<sensor_msgs::Imu>("imu", 1, boost::bind(&handleImu,boost::ref(rpy),_1));
00072 
00073         ros::spin();
00074 
00075         return 0;
00076 }
00077 


labust_navigation
Author(s): Gyula Nagy
autogenerated on Fri Aug 28 2015 11:23:33