-
Notifications
You must be signed in to change notification settings - Fork 564
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
moveit_servo does not work until the joint position changes #3040
Comments
I tried adding a 1Hz forced update to the For now, I had to temporarily disable the I am unsure why the |
Curious about your use case? I think this was added intentionally so a user wouldn't start jogging the arm from an uninitialized/out of sync state. Where is your initial state coming from, if not this topic? |
I am testing the upper-level software developed for my robot, using a mock component for After adding forced update logic to |
This issue is being labeled as stale because it has been open 45 days with no activity. It will be automatically closed after another 45 days without follow-ups. |
Description
A moveit_servo node was added to the robot package, but after starting it, the message "Waiting to receive robot state update." is continuously displayed, and the jog function cannot be executed. It only starts working normally after the robot is moved through other means.
Upon investigation, it was found that in current_state_monitor.cpp line 357:
if (robot_state_.getJointPositions(jm)[0] != joint_state->position[i])
This logic requires that the robot’s joint position must change in order to send a new joint state.
Suggestion:
Consider adding a timeout mechanism to update the joint state.
ROS Distro
Humble
OS and version
ubuntu 22.04
Source or binary build?
Source
If binary, which release version?
No response
If source, which branch?
main
Which RMW are you using?
CycloneDDS
Steps to Reproduce
A moveit_servo node was added to the robot package, hardware is mock joints.
start package with
Expected behavior
moveit_servo should start and work correctly without requiring the robot's joint position to change. It should be able to receive and process jog commands immediately upon startup.
Actual behavior
Upon starting moveit_servo, the console displays the message "Waiting to receive robot state update," and the jog functionality does not work. The jog control only becomes functional after the robot is moved via other means, which triggers a joint state update.
Backtrace or Console output
[servo_node-2] [INFO] [1729777416.775937835] [slave_servo_node]: Waiting to receive robot state update.
[servo_node-3] [INFO] [1729777417.759779353] [master_servo_node]: Waiting to receive robot state update.
[servo_node-2] [INFO] [1729777417.776050432] [slave_servo_node]: Waiting to receive robot state update.
[servo_node-3] [INFO] [1729777418.759894841] [master_servo_node]: Waiting to receive robot state update.
[servo_node-2] [INFO] [1729777418.776130021] [slave_servo_node]: Waiting to receive robot state update.
The text was updated successfully, but these errors were encountered: