<<PackageHeader(asr_cyberglove_lib)>> {{attachment:Logo-white-medium.jpg||width="333",height="200"}} <<TOC(4)>> ## AUTOGENERATED DON'T DELETE ## CategoryPackage == Description == The asr_cyberglove_lib package is used to start a server that provides the current joint state values received from the Cybergloves via ROS topics. == Usage == === Needed packages === This package depends on the following packages: * [[asr_msgs]] === Needed hardware === The following hardware components are needed: * Cybergloves {{attachment:cybergloves.jpg||width="430",height="241"}} === Start system === After ensuring that the Cybergloves are turned on, the asr_cyberglove_lib server can be started directly from the PC to which the hardware is connected: {{{ roslaunch asr_cyberglove_lib glove_lib.launch }}} Instead of using the preconfigured .launch-file, the server can also be started via ''rosrun'', e.g. with: {{{ rosrun asr_cyberglove_lib gloveServer_node -r --calibration-file-right $(find asr_cyberglove_lib)/cfg/GloveCalibrationRight.cal --tty-right /dev/ttyD2 -d 0 }}} Alternatively, the server can also be started from remote if the hardware is connected to another Lab-PC. The following command will also use a preconfigured .launch-file: {{{ rosrun asr_cyberglove_lib glove_lib_remote.sh }}} === Start system from remote using different ROS distributions === If the hardware is connected to a ROS Indigo Lab-PC and it is needed to start the asr_cyberglove_lib server from a remote ROS Kinetic Lab-PC, some workarounds / dirty hacks are needed. For the following, it is assumed that both ROS systems use the same file system and that the corresponding catkin workspaces are ''~/indigo_ws'' and ''~/kinetic_ws''. Open the terminal and source Kinetic (if not already sourced via ~/''.bashrc''): * ''source /opt/ros/kinetic/setup.bash'' * ''source ~/kinetic_ws/devel/setup.bash'' Additional ssh environment setups are needed (https://github.com/sigproc/qbo_sigproc/wiki/Detailed-environment-setup): * ''ssh-agent bash'' * ''ssh-add ~/.ssh/id_rsa'' A ssh connection can now be established, but the ~/''.bashrc'' needs to be modified to be able to start the server on ROS Indigo: * Add: ''source /opt/ros/indigo/setup.bash'' * Add: ''source ~/indigo_ws/devel/setup.bash'' * Comment out: ''source /opt/ros/kinetic/setup.bash'' * Comment out: ''source ~/kinetic_ws/devel/setup.bash'' The asr_cyberglove_lib server can now be started from remote: * ''rosrun asr_cyberglove_lib glove_lib_remote.sh'' To listen to the publishing ROS-Topic in a new terminal, ROS Kinetic has to be sourced again (or modify the ~/''.bashrc'' again before opening the new terminal): * ''source /opt/ros/kinetic/setup.bash'' * ''source ~/kinetic_ws/devel/setup.bash'' * ''rostopic echo /rightGloveData_radian'' Alternatively, the glove movements can also be visualized with the [[asr_cyberglove_visualization]] package (Kinetic needs to be sourced again): * ''source /opt/ros/kinetic/setup.bash'' * ''source ~/kinetic_ws/devel/setup.bash'' * ''roslaunch asr_cyberglove_visualization demo_glove.launch'' == ROS Nodes == === Published Topics === The sensor data of the Cybergloves are published as '''asr_msgs::!AsrGlove '''messages to the following topics: * '''''/rightGloveData''''' * '''''/leftGloveData''''' * '''''/rightGloveData_radian''''' * '''''/leftGloveData_radian''''' === Parameters === As mentioned in subsection 2.3, the asr_cyberglove_lib server can be started directly via ''rosrun'' without using the preconfigured .launch-file. For this case, it is needed to specify the ''rosrun'' arguments. The following arguments can be passed: * ''glove-right/r'': Indicates that the right glove should be used. * ''glove-left/l'': Indicates that the left glove should be used. * ''calibration-file-right'': If the right glove should be used, specify the path to its calibration file. Default: ''"$(find asr_cyberglove_lib)/cfg/GloveCalibrationRight.cal"'' * ''calibration-file-left'': If the left glove should be used, specify the path to its calibration file. Default: ''"$(find asr_cyberglove_lib)/cfg/GloveCalibrationLeft.cal"'' * ''tty-right'': If the right glove should be used, specify its device path. Default: ''"/dev/ttyD2"'' * ''tty-left'': If the left glove should be used, specify its device path. Default: ''"/dev/ttyD3"'' * ''debug-level/d'': Defines the debug level. The higher, the more debug infomation. Default: ''"0"''