- Notifications
You must be signed in to change notification settings - Fork441
Add optimization to flat systems trajectory generation#569
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 ourterms of service andprivacy statement. We’ll occasionally send you account related emails.
Already on GitHub?Sign in to your account
Merged
Uh oh!
There was an error while loading.Please reload this page.
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.Learn more about bidirectional Unicode characters
This commit allows a cost function and constraints to be passed to theflatsys point_to_point() function and when present will use sp.optimize tofind a trajectory. Preliminary unit tests, benchmarks, docstrings anddocumentation also in place.Switched the order of arguments in point_to_point() so that Tf (or timepts)now comes before the initial and final states, consistent with orderingelsewhere in the package.Make some small updates to optimal.py docstrings and argument names to makethings consistent with flatsys.
This commit changes the way that cost functions and constraints are handledfor flat system to carry out optimization only in the null space of the flatsystem basis coefficients, eliminating the use of an equality constraint forthe terminal condition.
coveralls commentedMar 13, 2021
I am not in a position to evaluate this at the moment, but my inclination would be to merge and include with 0.9 so people can play with it/find rough edges sooner rather than later. |
Sign up for freeto join this conversation on GitHub. Already have an account?Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR adds the ability to generate trajectories for differential flat systems taking into account cost functions and constraints, in a manner that is consistent with the
control.optimal
module. In particular, you can now callflat.point_to_point
withcost
andconstraints
keywords. The code then uses any extra degrees of freedom in the flat trajectory to minimize cost and satisfy constraints at a list of time points. For differentially flat systems, this method ismuch faster than solving an optimal control problem with terminal constraints.I also found and fixed some docstring glitches and naming inconsistencies in
control.optimal
along the way (these are all minor and don't change behavior. Unit tests, examples, and updated documentation are included.