-
Notifications
You must be signed in to change notification settings - Fork 63
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
Invalid Trajectory: start point deviates from current robot state more than 0.01 #285
Comments
For some reason, I could not get the |
That fixed it. Thanks. |
The problem has returned whenever the arm gets bumped or deviated from its path, for example, by pushing down too hard when trying to pick up a part. Is there a way to reset the state or something so that it recognizes where the current joints actually are? Alternatively, is there a way to turn off this check and/or increase the tolerance? Here is an example: Invalid Trajectory: start point deviates from current robot state more than 0.01 |
Just to clarify you have this issue even when adding code like this before planning the trajectory? with self._planning_scene_monitor.read_write() as scene:
self._floor_robot.set_start_state(robot_state=scene.current_state) |
Yes. That fixed it before but when the arm has been jostled, it doesn't work. |
Here is a discussion about it, but no resolution: jacknlliu/development-issues#67 |
Along the same lines, when the arm is jostled, this error sometimes appears. Of course, the best thing is to not jostle the arm, but the problem is that, when you occasionally do, there seems to be no way to clear the error. How do you get the gripper back within limits if being out of limits makes it refuse to move? I cannot find a way to set the 'start_state_max_bounds_error' parameter at all, much less while the sim is running. Joint 'floor_gripper_joint' from the starting state is outside bounds by a significant margin: [0.222733 ] should be in the range [-0.001 ], [0.001 ] but the error above the 'start_state_max_bounds_error' parameter (currently set to 0.050000) |
Hi Dan, sorry for the delayed response. I was digging through the moveit_py documentation and saw there is a method for the with self._planning_scene_monitor.read_write() as scene:
scene.wait_for_current_robot_state()
self._floor_robot.set_start_state(robot_state=scene.current_state) Another possible suggestion I have is, if you are running your system similarly to ariac_tutorials, changing the executor to be of type |
That's a good find; I will try it. Yes, the ROS2 approach to threading is, simply put, poor. The issue with blocking causes all sorts of problems. |
@dan9thsense Any update on this? Does waiting for the current state fix the start point deviation error? |
Waiting blocks right now. I have to learn more about executors....... |
is self._planning_scene_monitor a class member that you initialize in the init? You can try to put it in a separate mutually exclusive callback group and see if see solves the issue. It seems this a synchronous execution which is blocking the current thread. |
OK, I'll try that, thanks. Or maybe put the wait in its own executor? |
Since the call is to Moveit, based on the original Moveit call (MoveItPy) where MoveIt creates a node, I don't see a way to put that in a callback group that I make. |
Dan, can you try changing the start state tolerance directly in the MoveIt config and see if that fixes the error? |
Actually it might be this part of the launch file that needs to be changed |
I think that will help. I'll try it. So far, I have not found another solution. |
I have been doing some work with MoveItPy myself recently and I found that it was difficult to not jostle the robot when doing full speed cartesian motions. Looking into it, the most recent version of MoveItPy has added the ability to scale trajectories with time-optimal trajectory generation (TOTG) which is a feature I used extensively for nist_competitor. It also has the TrajectoryExecutionManager which allows for async execution of trajectories which is very helpful for pick operations. I was able to build the current version of MoveIt from source on Iron. Would you be interested in using these features? I think it could help with not jostling the arm as much. If so we can look at how to properly integrate this with the automated evaluation. We may create a separate image that has MoveIt built from source and competitors can select that image in the evaluation configuration file. |
That's interesting. Now that it's April and quals are just a few weeks away, I'm focusing on testing and debugging rather than introducing new features or approaches. Those are good things for next year. Also, given the track record of both ROS2 and MoveItPy, I'd be concerned about some subtle bug rearing its head at the last minute. |
However, I will try changing the tolerance and see if that helps. I expect it will. |
In branch 2024_dev, I get the error in the title about 80% of the time that I try to move to specified joints using this method from the tutorials. The method generally works when used right at the start of the simulation. But once the floor robot arm is moved, then trying to use this method causes the error to occur.
For example, when the current elbow joint is at 1.57 and I try to move it to 1.0, the error indicates that it is taking the goal (1.0) as the current start point. I saw similar behavior with Cartesian goals and fixed it by using the current pose as the first waypoint. But I don't know how to fix it here.
Invalid Trajectory: start point deviates from current robot state more than 0.01
joint 'floor_elbow_joint': expected: 1.57, current: 0.99786
The text was updated successfully, but these errors were encountered: