49 #include <visp3/robot/vpReflexTakktile2.h> 51 int main(
int argc,
char *argv[])
53 std::string opt_network_interface =
"eth0";
54 std::string opt_finger_file_name =
"yaml/finger_calibrate.yaml";
55 std::string opt_tactile_file_name =
"yaml/tactile_calibrate.yaml";
56 std::string opt_motor_file_name =
"yaml/motor_constants.yaml";
58 for (
int i = 0; i < argc; i++) {
59 if (std::string(argv[i]) ==
"--network")
60 opt_network_interface = std::string(argv[i + 1]);
61 else if (std::string(argv[i]) ==
"--finger")
62 opt_finger_file_name = std::string(argv[i + 1]);
63 else if (std::string(argv[i]) ==
"--tactile")
64 opt_tactile_file_name = atoi(argv[i + 1]);
65 else if (std::string(argv[i]) ==
"--motor")
66 opt_motor_file_name = atoi(argv[i + 1]);
67 else if (std::string(argv[i]) ==
"--help" || std::string(argv[i]) ==
"-h") {
68 std::cout <<
"\nUsage: " << argv[0]
69 <<
" [--network <interface name>] " 70 " [--finger <calib file name>]" 71 " [--tactile <calib file name>]" 72 " [--motor <constants file name>]" 75 std::cout <<
"Options:" << std::endl;
76 std::cout <<
" --network <interface name>" << std::endl;
77 std::cout <<
"\tNetwork interface name. Default: " << opt_network_interface << std::endl << std::endl;
78 std::cout <<
" --finger <calib file name>" << std::endl;
79 std::cout <<
"\tFinger calibration file name. Default: " << opt_finger_file_name << std::endl << std::endl;
80 std::cout <<
" --tactile <calib file name>" << std::endl;
81 std::cout <<
"\tTactile calibration file name. Default: " << opt_tactile_file_name << std::endl << std::endl;
82 std::cout <<
" --motor <constants file name>" << std::endl;
83 std::cout <<
"\tMotor constants file name. Default: " << opt_motor_file_name << std::endl << std::endl;
84 std::cout <<
" --help, -h" << std::endl;
85 std::cout <<
"\tPrint this helper." << std::endl;
90 #ifdef VISP_HAVE_TAKKTILE2 103 std::cout <<
"Calibration complete" << std::endl;
109 std::cout <<
"Moving fingers..." << std::endl;
111 std::vector<vpColVector> finger_positions = {
112 {0.0, 0.0, 0.0, 0.0}, {0.5, 0.5, 0.5, 0.0}, {1.0, 1.0, 1.0, 0.0}, {0.5, 0.5, 0.5, 0.0}, {0.0, 0.0, 0.0, 0.0}};
114 for (
size_t i = 0; i < finger_positions.size(); i++) {
119 std::cout <<
"Finger movement complete" << std::endl;
125 std::cout <<
"Moving preshape joint..." << std::endl;
127 std::vector<vpColVector> preshape_positions = {
128 {0.0, 0.0, 0.0, 0.0}, {0.0, 0.0, 0.0, 0.5}, {0.0, 0.0, 0.0, 1.5}, {0.0, 0.0, 0.0, 0.5}, {0.0, 0.0, 0.0, 0.0}};
130 for (
size_t i = 0; i < preshape_positions.size(); i++) {
135 std::cout <<
"Preshape movement complete" << std::endl;
141 std::cout <<
"Changing to faster speed..." << std::endl;
142 vpColVector faster_velocities = {7.0, 7.0, 7.0, 7.0};
145 for (
size_t i = 0; i < finger_positions.size(); i++) {
150 std::cout <<
"Changing to slower speed..." << std::endl;
151 vpColVector slower_velocities = {0.5, 0.5, 0.5, 0.5};
154 for (
size_t i = 0; i < finger_positions.size(); i++) {
159 std::cout <<
"Done changing speeds" << std::endl;
165 std::cout <<
"Starting blended control..." << std::endl;
169 for (
int i = 0; i < 5; i++) {
176 std::cout <<
"Blended control complete" << std::endl;
182 std::cout <<
"Starting tactile feedback..." << std::endl
183 <<
"All fingers will stop moving when any one makes contact" << std::endl;
195 std::cout <<
"Now each finger will only stop moving once it makes contact" << std::endl;
197 std::vector<int> thresholds = {10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 20, 20, 20, 20, 20, 20, 20,
198 20, 20, 20, 20, 20, 20, 20, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30};
210 std::cout <<
"All torques disabled" << std::endl;
212 std::cout <<
"The end" << std::endl;
215 std::cout <<
"ViSP is not built to support Right Hand Reflex Takktile2 hand" << std::endl;
void setMotorConfigFile(const std::string &motor_file_name)
void setPositioningVelocity(const vpColVector &targets)
void setNetworkInterface(const std::string &network_interface="eth0")
void setVelocityUntilEachContact(const vpColVector &targets)
void wait(int milliseconds)
Implementation of column vector and the associated operations.
void setFingerConfigFile(const std::string &finger_file_name)
void setVelocityUntilAnyContact(const vpColVector &targets)
void setTactileConfigFile(const std::string &tactile_file_name)
void setPosition(const vpColVector &targets)
void setTactileThreshold(int threshold)