-
Notifications
You must be signed in to change notification settings - Fork 134
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
[ros2] Support for dynamic joint limits in MotionRequests + other features #144
base: ros2
Are you sure you want to change the base?
Conversation
# Motion planning request to the global planner | ||
string planning_group | ||
trajectory_msgs/JointTrajectory trajectory |
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 don't really follow why this should be needed, but why not add a reference trajectory here? https://github.com/ros-planning/moveit_msgs/blob/master/msg/MotionPlanRequest.msg#L25
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.
So, the moveit_msgs/MotionSequenceRequest contains a JointTrajectory if you dig deep enough.
MotionSequenceRequest-> MotionSequenceItem[] -> MotionPlanRequest-> GenericTrajectory[]-> JointTrajectory[]
I guess this new field is probably not needed :(
What do you think @henningkayser? Is it too hard to dig all the way down to JointTrajectory in the current message type?
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'm cool with either approach. I guess using what currently exists (even if you do need to dig down somewhat deep) makes the most sense so I can make that change
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'm reconsidering this. I think having a dedicated "trajectory" field is more intuitive to the user to assign than having to dig deep in the motionplanrequest. This is for three reasons:
- The way the HP will check to see if it should process the already planned trajectory (as opposed to planning one) is by specifically looking in this "trajectory" field to see if has a multi-point trajectory. This makes this field pretty important to this action. Having it buried down within the MotionSequenceRequest could therefore be less intuitive to the user.
- Having this trajectory field outside the MotionSequenceRequest highlights that this action isn't so much a request to plan as it is to just bypass planning and execute via the local planner.
- The action already conains a field for the
planning_group
so wouldn't be a big stretch to add the accompanying trajectory on the same level if applicable.
All this said, if you think using the reference-trajectory field is best, I can run with that and make the necessary changes.
|
||
# If true, smoothing will be skipped when applying a smoothing adapter during | ||
# trajectory processing (if it is defined as a request adapter). | ||
bool skip_smoothing |
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.
This makes me thing that a separate post processing config would make sense by now, there are already so many related fields.
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.
Hmm, say TOTG and Ruckig are configured to do smoothing by default in ompl_planning.yaml
. I'm trying to think of how the motion planning pipeline would know to skip both of those smoothers but not the other OMPL planning request adapters.
Maybe it should be a vector of strings containing the plugins to skip, like this:
string[] ompl_adapters_to_skip
So to skip those two plugins, you would have:
["default_planner_request_adapters/AddTimeOptimalParameterization"
"default_planner_request_adapters/AddRuckigTrajectorySmoothing"]
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'm not sure we'd want to skip a time-parameterization adapter like TOTG. I think this is only relevant for smoothing (which occurs after the time-parameterization step) in which case I think ruckig is the only one currently. In any case though, if multiple smoothing adapters do exist down the road, then it's not too hard to use the "skip_smoothing" field when the adapter is called like I have done on my fork here for Ruckig https://github.com/mechwiz/moveit2/blob/mwiz/hp_fixes/moveit_ros/planning/planning_request_adapter_plugins/src/add_ruckig_traj_smoothing.cpp#L68
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.
bumping this again.
I feel like defining a vector of strings for this is maybe a little overkill. I can think of usecases where even though a smoothing adapter (like Ruckig) is applied after TOTG in the list of ompl adapters, there may be exceptions/times where we don't want to smooth the resulting trajectory (whether to save on time or because its a very simple motion like closing/opening a gripper, etc..). Are there other usecases where we'd want to skip an adapter that is not smoothing?
|
||
# If true, smoothing will be skipped when applying a smoothing adapter during | ||
# trajectory processing (if it is defined as a request adapter). | ||
bool skip_smoothing |
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.
Hmm, say TOTG and Ruckig are configured to do smoothing by default in ompl_planning.yaml
. I'm trying to think of how the motion planning pipeline would know to skip both of those smoothers but not the other OMPL planning request adapters.
Maybe it should be a vector of strings containing the plugins to skip, like this:
string[] ompl_adapters_to_skip
So to skip those two plugins, you would have:
["default_planner_request_adapters/AddTimeOptimalParameterization"
"default_planner_request_adapters/AddRuckigTrajectorySmoothing"]
# Motion planning request to the global planner | ||
string planning_group | ||
trajectory_msgs/JointTrajectory trajectory |
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.
So, the moveit_msgs/MotionSequenceRequest contains a JointTrajectory if you dig deep enough.
MotionSequenceRequest-> MotionSequenceItem[] -> MotionPlanRequest-> GenericTrajectory[]-> JointTrajectory[]
I guess this new field is probably not needed :(
What do you think @henningkayser? Is it too hard to dig all the way down to JointTrajectory in the current message type?
trajectory_msgs/JointTrajectory trajectory | ||
moveit_msgs/MotionSequenceRequest motion_sequence |
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.
Same comment about MotionSequenceRequest containing a JointTrajectory already, if you dig deep enough.
2a0169f
to
f0ecd18
Compare
d7e3169
to
2de907d
Compare
2de907d
to
81735e6
Compare
I created this PR in anticipation of a few PRs I have in the works for MoveIt and MTC so that they can support:
@AndyZe, @JafarAbdi