54 #include <visp3/core/vpConfig.h>
55 #include <visp3/core/vpDebug.h>
57 #ifdef VISP_HAVE_AFMA4
62 #include <visp3/io/vpParseArgv.h>
63 #include <visp3/robot/vpRobotAfma4.h>
66 #define GETOPTARGS "mh"
76 void usage(
const char *name,
const char *badparam)
79 Example of a positionning control followed by a velocity control \n\
80 of the Afma4 robot.\n \
89 Turn off the control of the robot. This option is\n\
90 essentially useful for security reasons during nightly\n\
94 Print the help.\n\n");
97 fprintf(stderr,
"ERROR: \n" );
98 fprintf(stderr,
"\nBad parameter [%s]\n", badparam);
114 bool getOptions(
int argc,
const char **argv,
bool &control)
121 case 'm': control =
false;
break;
122 case 'h': usage(argv[0], NULL);
return false;
break;
125 usage(argv[0], optarg);
return false;
break;
129 if ((c == 1) || (c == -1)) {
131 usage(argv[0], NULL);
132 std::cerr <<
"ERROR: " << std::endl;
133 std::cerr <<
" Bad argument " << optarg << std::endl << std::endl;
141 main(
int argc,
const char ** argv)
148 if (getOptions(argc, argv, control) ==
false) {
165 std::cout <<
"Position control: in articular..." << std::endl;
166 std::cout <<
" position to reach: " << qd.t() << std::endl;
174 std::cout <<
" measured position: " << q.t() ;
182 std::cout <<
"Velocity control: in articular..." << std::endl;
186 std::cout <<
" rotation arround vertical axis: " << q[0] << std::endl;
193 std::cout <<
" vertical translation: " << q[1] << std::endl;
200 std::cout <<
" vertical translation: " << q[1] << std::endl;
206 std::cout <<
" pan rotation: " << q[2] << std::endl;
213 std::cout <<
" tilt rotation: " << q[3] << std::endl;
222 std::cout <<
"Velocity control: in camera frame..." << std::endl;
226 std::cout <<
" rx rotation: " << q[0] << std::endl;
234 std::cout <<
" ry rotation: " << q[1] << std::endl;
239 std::cout <<
"The end" << std::endl;
243 std::cout <<
"Catch a ViSP exception: " << e << std::endl;
251 vpERROR_TRACE(
"You do not have an afma4 robot connected to your computer...");
void setVelocity(const vpRobot::vpControlFrameType frame, const vpColVector &velocity)
Initialize the position controller.
error that can be emited by ViSP classes.
static bool parse(int *argcPtr, const char **argv, vpArgvInfo *argTable, int flags)
void setPosition(const vpRobot::vpControlFrameType frame, const vpColVector &position)
Initialize the velocity controller.
void getPosition(const vpRobot::vpControlFrameType frame, vpColVector &position)
static const unsigned int njoint
Number of joint.
static double rad(double deg)
vpRobot::vpRobotStateType setRobotState(vpRobot::vpRobotStateType newState)
Implementation of column vector and the associated operations.
Control of Irisa's cylindrical robot named Afma4.