Visual Servoing Platform  version 3.6.1 under development (2024-11-15)
frankaSavePosition.cpp
1 /****************************************************************************
2  *
3  * ViSP, open source Visual Servoing Platform software.
4  * Copyright (C) 2005 - 2023 by Inria. All rights reserved.
5  *
6  * This software is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  * See the file LICENSE.txt at the root directory of this source
11  * distribution for additional information about the GNU GPL.
12  *
13  * For using ViSP with software that can not be combined with the GNU
14  * GPL, please contact Inria about acquiring a ViSP Professional
15  * Edition License.
16  *
17  * See https://visp.inria.fr for more information.
18  *
19  * This software was developed at:
20  * Inria Rennes - Bretagne Atlantique
21  * Campus Universitaire de Beaulieu
22  * 35042 Rennes Cedex
23  * France
24  *
25  * If you have questions regarding the use of this file, please contact
26  * Inria at visp@inria.fr
27  *
28  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30  *
31  * Description:
32  * Franka robot tool.
33  *
34 *****************************************************************************/
35 
41 #include <iostream>
42 
43 #include <visp3/core/vpConfig.h>
44 #include <visp3/robot/vpRobotFranka.h>
45 
46 #if defined(VISP_HAVE_FRANKA)
47 
48 int main(int argc, char **argv)
49 {
50 #ifdef ENABLE_VISP_NAMESPACE
51  using namespace VISP_NAMESPACE_NAME;
52 #endif
53  std::string opt_robot_ip = "192.168.1.1";
54  std::string opt_position_filename = "position.pos";
55 
56  for (int i = 1; i < argc; i++) {
57  if (std::string(argv[i]) == "--ip" && i + 1 < argc) {
58  opt_robot_ip = std::string(argv[i + 1]);
59  }
60  else if (std::string(argv[i]) == "--save" && i + 1 < argc) {
61  opt_position_filename = std::string(argv[i + 1]);
62  }
63  else if (std::string(argv[i]) == "--help" || std::string(argv[i]) == "-h") {
64  std::cout << "Save Panda robot position in a file." << std::endl;
65  std::cout << "Usage:\n" << std::endl;
66  std::cout << argv[0] << " [--ip <default " << opt_robot_ip << ">] [--save <position file name>] [--help] [-h]\n"
67  << std::endl;
68  std::cout << "Example:\n" << argv[0] << " --ip 192.168.100.1 --save position.pos\n" << std::endl;
69 
70  return EXIT_SUCCESS;
71  }
72  }
73 
74  vpRobotFranka robot;
75 
76  try {
77  robot.connect(opt_robot_ip);
78 
79  vpColVector q;
80  robot.getPosition(vpRobot::JOINT_STATE, q);
81  robot.savePosFile(opt_position_filename, q);
82 
83  std::cout << "Robot position saved in \"" << opt_position_filename << "\"" << std::endl;
84  }
85  catch (const vpException &e) {
86  std::cout << "ViSP exception: " << e.what() << std::endl;
87  std::cout << "Stop the robot " << std::endl;
89  return EXIT_FAILURE;
90  }
91  catch (const franka::NetworkException &e) {
92  std::cout << "Franka network exception: " << e.what() << std::endl;
93  std::cout << "Check if you are connected to the Franka robot"
94  << " or if you specified the right IP using --ip command line option set by default to 192.168.1.1. "
95  << std::endl;
96  return EXIT_FAILURE;
97  }
98  catch (const std::exception &e) {
99  std::cout << "Franka exception: " << e.what() << std::endl;
100  return EXIT_FAILURE;
101  }
102 
103  return EXIT_SUCCESS;
104 }
105 #else
106 int main()
107 {
108 #if !defined(VISP_HAVE_FRANKA)
109  std::cout << "Install libfranka." << std::endl;
110 #endif
111  return EXIT_SUCCESS;
112 }
113 #endif
Implementation of column vector and the associated operations.
Definition: vpColVector.h:191
error that can be emitted by ViSP classes.
Definition: vpException.h:60
const char * what() const
Definition: vpException.cpp:71
@ JOINT_STATE
Definition: vpRobot.h:82
@ STATE_STOP
Stops robot motion especially in velocity and acceleration control.
Definition: vpRobot.h:66
virtual vpRobotStateType setRobotState(const vpRobot::vpRobotStateType newState)
Definition: vpRobot.cpp:202