-
Notifications
You must be signed in to change notification settings - Fork 158
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
Deterministic task solutions #530
Comments
I cannot comment on Trac-IK. The Pilz planner should be deterministic, yes. ComputeIK randomly samples a new seed state, but only if the initial one didn't yield as solution. This is the exception and only occurs close to singularities. |
As it is currently implemented, if I need 8 IK samples, the first one is deterministic but all other calls are random. while (ik_solutions.size() < max_ik_solutions && remaining_time > 0) {
if (tried_current_state_as_seed) {
sandbox_state.setToRandomPositions(jmg);
sandbox_state.update();
}
tried_current_state_as_seed = true;
...
} Even if it would be implemented as you described, it would also occur every time the min distance is not respected or when in collision, not just singularities. I can configure those, so you are right ! I had the impression that we could get multiple IK solutions with just one call but it is not the case. By using the kinematic plugin, would I be able to request multiple IK solutions ? |
Yes, that's what I wrote too. Note that all but the first solution will induce strong joint motions, because you will switch between IK solution branches, e.g. from elbow up to elbow down. I always recommend to not do that. Surely, if you need those different solution branches, because different sub tasks operated on different branches, you need to go that route. |
I have some tasks, that needs to be deterministic.
Inverse Kinematic
I use
TRAC-IK
because we don't have a closed form solution when accounting for the robot kinematic calibration. Given the same seed and the same timeout, do you think that it is deterministic ? Not had a chance to benchmark this.Planners
I use the
Pilz industrial motion planner
to be deterministic. When using a cartesian goals, the IK solver is used to create the trajectory (or maybe just do some checks, not really sure). If the IK solver is not deterministic or the seed is random, then in fact this planner is not really deterministic for cartesian goals...MTC
Assuming I have a IK solver which is deterministic.
If I want to have the same task solutions, I would need first to change the
ComputeIK
stage to have the same sequence of seeds. I would need to always pass goals in joint space to Pilz and let MTC compute the IK's.Do you see anything else in the MTC framework that has non-deterministic behavior ? Or maybe you would have a different approach.
The text was updated successfully, but these errors were encountered: