-
Notifications
You must be signed in to change notification settings - Fork 555
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
Require velocity and acceleration limits in TOTG #1794
Conversation
eb555a4
to
e75bb54
Compare
Codecov ReportBase: 50.33% // Head: 50.30% // Decreases project coverage by
Additional details and impacted files@@ Coverage Diff @@
## main #1794 +/- ##
==========================================
- Coverage 50.33% 50.30% -0.02%
==========================================
Files 374 374
Lines 31325 31329 +4
==========================================
- Hits 15763 15757 -6
- Misses 15562 15572 +10
Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. ☔ View full report at Codecov. |
49d6415
to
97d10c6
Compare
399484a
to
16bbc5f
Compare
16bbc5f
to
227a579
Compare
Things like this make me wonder if we should always enforce having velocity and acceleration limits set at runtime. There is really no actual use case of MoveIt that makes sense without them, imo. Opened up a discussion here: #1804 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think that change does make sense 👍 Here are a couple of comments
moveit_core/trajectory_processing/src/time_optimal_trajectory_generation.cpp
Outdated
Show resolved
Hide resolved
moveit_core/trajectory_processing/src/time_optimal_trajectory_generation.cpp
Outdated
Show resolved
Hide resolved
moveit_core/trajectory_processing/src/time_optimal_trajectory_generation.cpp
Outdated
Show resolved
Hide resolved
moveit_core/trajectory_processing/src/time_optimal_trajectory_generation.cpp
Show resolved
Hide resolved
moveit_core/trajectory_processing/src/time_optimal_trajectory_generation.cpp
Outdated
Show resolved
Hide resolved
moveit_core/trajectory_processing/test/test_time_optimal_trajectory_generation.cpp
Show resolved
Hide resolved
I think I'll just close this one because the discussion is tending toward requiring acceleration limits when the RobotModel is loaded. |
Reviving this PR since the discussion about requiring accel limits seems to be a dead end. |
Co-authored-by: Sebastian Jahr <[email protected]>
I'm surprised to see this change merged. Functionally the only thing it does is that you prohibit a use-case that did something intuitive but possibly sub-optimal before while printing an explicit warning. I don't see what the patch improves... The least you should do is document migration notes telling users to explicitly add the default 1.0 rad/s^2 limits for all joints if they want it to work the way it did so far. |
Good point, that we should recommend 1.0 rad/s^2 as default for beginners 👍 I don't think that this patch prohibits a use-case but rather helps users to avoid an unexpected behavior of the robot moving very slow. Yes, a warning was printed but it was easy to overlook in the huge terminal output that MoveIt produces. As a user, I'd assume the acceleration limits to be treated as unlimited (which would prob. be an unsafe default value 😅 ), if I don't explicitly set them and not a magic number. |
I don't think that this patch prohibits a use-case
Well, it clearly does not add any functionality and it exits an algorithm when the algorithm ran without error before. ;)
but rather helps users to avoid an unexpected behavior of the robot moving very slow.
They will still get that because of the independent default scaling parameters which make the robot slow unless overridden. :D
It's a valid question to ask which variables should have defaults and which should not.
MoveIt traditionally has defaults for everything to ease initial setup cost and the values are rarely great.
In my opinion, acceleration is far enough away from beginner use though to warrant a default (of 1.0/s^2).
Thinking along these lines, would it be a viable way around this whole discussion to add explicit defaults for velocity and acceleration to the joint_limits.yaml that apply whenever a joint does not define limits explicitly?
That way `has_velocity_limits`/`has_acceleration_limits` could be removed altogether. All RobotModel joints would alway come with valid (default) limits and the question of how to time trajectories for joints without acceleration limits does not arise.
But still, users would not have to think about each joint independently without having the chance to get official information from the manufacturer.
Yes, a warning was printed but it was easy to overlook in the huge terminal output that MoveIt produces.
[rqt_console](https://docs.ros.org/en/humble/Tutorials/Beginner-CLI-Tools/Using-Rqt-Console/Using-Rqt-Console.html)? :-)
And yes, MoveIt prints too much information/spam by default.
|
That seems like a good idea. The SRDF format doesn't even allow acceleration limits so we'd have to require a |
This reverts commit 937be8e.
This PR prints an error and returns false if vel/accel isn't defined for a robot joint, instead of assigning a default value and moving on.
Fixes #1793 and this UR issue: UniversalRobots/Universal_Robots_ROS2_Description#46