This file is indexed.

/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