RobotAlgos.h

Go to the documentation of this file.
00001 /***************************************************************************
00002  *   Copyright (c) Jürgen Riegel          (juergen.riegel@web.de) 2009     *
00003  *                                                                         *
00004  *   This file is part of the FreeCAD CAx development system.              *
00005  *                                                                         *
00006  *   This library is free software; you can redistribute it and/or         *
00007  *   modify it under the terms of the GNU Library General Public           *
00008  *   License as published by the Free Software Foundation; either          *
00009  *   version 2 of the License, or (at your option) any later version.      *
00010  *                                                                         *
00011  *   This library  is distributed in the hope that it will be useful,      *
00012  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00013  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
00014  *   GNU Library General Public License for more details.                  *
00015  *                                                                         *
00016  *   You should have received a copy of the GNU Library General Public     *
00017  *   License along with this library; see the file COPYING.LIB. If not,    *
00018  *   write to the Free Software Foundation, Inc., 59 Temple Place,         *
00019  *   Suite 330, Boston, MA  02111-1307, USA                                *
00020  *                                                                         *
00021  ***************************************************************************/
00022 
00023  
00024 
00025 
00026 #ifndef _RobotAlgos_h_
00027 #define _RobotAlgos_h_
00028 
00029 #include <Base/Vector3D.h>
00030 #include <string>
00031 
00032 #include "kdl_cp/frames_io.hpp"
00033 #include <Base/Placement.h>
00034 
00035 namespace Robot
00036 {
00037 
00038 
00041 class RobotExport RobotAlgos
00042 {
00043 
00044 public:
00046         RobotAlgos(void);
00047         virtual ~RobotAlgos();
00048 
00049     void Test(void);
00050 };
00051 
00052 inline  KDL::Frame toFrame(const Base::Placement &To){
00053     return KDL::Frame(KDL::Rotation::Quaternion(To.getRotation()[0],To.getRotation()[1],To.getRotation()[2],To.getRotation()[3]),KDL::Vector(To.getPosition()[0],To.getPosition()[1],To.getPosition()[2]));
00054 }
00055 inline  Base::Placement toPlacement(const KDL::Frame &To){
00056         double x,y,z,w;
00057         To.M.GetQuaternion(x,y,z,w);
00058         return Base::Placement(Base::Vector3d(To.p[0],To.p[1],To.p[2]),Base::Rotation(x,y,z,w));
00059 }
00060 
00061 } //namespace Robot
00062 
00063 
00064 
00065 #endif

Generated on Wed Nov 23 19:00:36 2011 for FreeCAD by  doxygen 1.6.1