/usr/include/visp/vpRobot.h is in libvisp-dev 2.9.0-3+b2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 | /****************************************************************************
*
* $Id: vpRobot.h 4632 2014-02-03 17:06:40Z fspindle $
*
* This file is part of the ViSP software.
* Copyright (C) 2005 - 2014 by INRIA. All rights reserved.
*
* This software is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* ("GPL") version 2 as published by the Free Software Foundation.
* See the file LICENSE.txt at the root directory of this source
* distribution for additional information about the GNU GPL.
*
* For using ViSP with software that can not be combined with the GNU
* GPL, please contact INRIA about acquiring a ViSP Professional
* Edition License.
*
* See http://www.irisa.fr/lagadic/visp/visp.html for more information.
*
* This software was developed at:
* INRIA Rennes - Bretagne Atlantique
* Campus Universitaire de Beaulieu
* 35042 Rennes Cedex
* France
* http://www.irisa.fr/lagadic
*
* If you have questions regarding the use of this file, please contact
* INRIA at visp@inria.fr
*
* This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
* WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*
*
* Description:
* Generic virtual robot.
*
* Authors:
* Eric Marchand
*
*****************************************************************************/
#ifndef vpRobot_H
#define vpRobot_H
/*!
\file vpRobot.h
\brief class that defines a generic virtual robot
*/
#include <visp/vpHomogeneousMatrix.h>
#include <visp/vpMatrix.h>
#include <visp/vpColVector.h>
#include <visp/vpPoseVector.h>
/*!
\class vpRobot
\brief class that defines a generic virtual robot
*/
class VISP_EXPORT vpRobot
{
public:
/*!
Robot control states.
*/
typedef enum
{
STATE_STOP, /*!< Stops robot motion especially in velocity and
acceleration control. */
STATE_VELOCITY_CONTROL, //!< Initialize the velocity controller.
STATE_POSITION_CONTROL, //!< Initialize the position controller.
STATE_ACCELERATION_CONTROL //!< Initialize the acceleration controller.
} vpRobotStateType ;
/*!
Robot control frames.
*/
typedef enum
{
REFERENCE_FRAME, /*!< Corresponds to a fixed reference frame
attached to the robot structure. */
ARTICULAR_FRAME, /*!< Corresponds to the joint space. */
CAMERA_FRAME, /*!< Corresponds to a frame attached to the
camera mounted on the robot end-effector. */
MIXT_FRAME /*!< Corresponds to a "virtual" frame where
translations are expressed in the reference frame, and
rotations in the camera frame.*/
} vpControlFrameType ;
private: /* Membres privees */
vpRobot::vpRobotStateType stateRobot;
vpRobot::vpControlFrameType frameRobot;
protected:
double maxTranslationVelocity;
static const double maxTranslationVelocityDefault;// = 0.2;
double maxRotationVelocity;
static const double maxRotationVelocityDefault;// = 0.7;
//! number of degrees of freedom
int nDof ;
//! robot Jacobian expressed in the end-effector frame
vpMatrix eJe ;
//! is the robot Jacobian expressed in the end-effector frame available
int eJeAvailable ;
//! robot Jacobian expressed in the robot reference frame available
vpMatrix fJe ;
//! is the robot Jacobian expressed in the robot reference frame available
int fJeAvailable ;
int areJointLimitsAvailable ;
double *qmin;
double *qmax ;
bool verbose_;
public:
vpRobot (void);
vpRobot (const vpRobot &robot);
virtual ~vpRobot() { ; }
//---------- Jacobian -----------------------------
//! Get the robot Jacobian expressed in the end-effector frame
virtual void get_eJe(vpMatrix &_eJe) = 0 ;
//! Get the robot Jacobian expressed in the robot reference (or world) frame.
virtual void get_fJe(vpMatrix &_fJe) = 0 ;
//! Get a displacement (frame as to ve specified) between two successive position control.
virtual void getDisplacement(const vpRobot::vpControlFrameType frame,
vpColVector &q) = 0 ;
double getMaxTranslationVelocity (void) const ;
double getMaxRotationVelocity (void) const;
//! Get the robot position (frame has to be specified).
virtual void getPosition(const vpRobot::vpControlFrameType frame,
vpColVector &q) = 0 ;
// Return the robot position (frame has to be specified).
vpColVector getPosition (const vpRobot::vpControlFrameType frame);
virtual vpRobotStateType getRobotState (void) const { return stateRobot ; }
virtual void init() = 0 ;
vpRobot & operator=(const vpRobot &robot);
static vpColVector saturateVelocities(const vpColVector &v_in, const vpColVector &v_max, bool verbose=false);
void setMaxRotationVelocity (const double maxVr);
void setMaxTranslationVelocity (const double maxVt);
//! Set a displacement (frame has to be specified) in position control.
virtual void setPosition(const vpRobot::vpControlFrameType frame,
const vpColVector &q) = 0 ;
virtual vpRobotStateType setRobotState (const vpRobot::vpRobotStateType newState);
//! Set the velocity (frame has to be specified) that will be applied to the velocity controller.
virtual void setVelocity(const vpRobot::vpControlFrameType frame,
const vpColVector &vel) = 0 ;
inline void setVerbose(bool verbose) { verbose_ = verbose; };
protected:
vpControlFrameType setRobotFrame (vpRobot::vpControlFrameType newFrame);
vpControlFrameType getRobotFrame (void) const { return frameRobot ; }
} ;
#endif
|