Add optimization to flat systems trajectory generation#569
Merged
murrayrm merged 7 commits intopython-control:masterfrom Mar 19, 2021
Merged
Add optimization to flat systems trajectory generation#569murrayrm merged 7 commits intopython-control:masterfrom
murrayrm merged 7 commits intopython-control:masterfrom
Conversation
This commit allows a cost function and constraints to be passed to the flatsys point_to_point() function and when present will use sp.optimize to find a trajectory. Preliminary unit tests, benchmarks, docstrings and documentation 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 ordering elsewhere in the package. Make some small updates to optimal.py docstrings and argument names to make things consistent with flatsys.
This commit changes the way that cost functions and constraints are handled for flat system to carry out optimization only in the null space of the flat system basis coefficients, eliminating the use of an equality constraint for the terminal condition.
Contributor
|
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. |
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
Sign up for free
to 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.optimalmodule. In particular, you can now callflat.point_to_pointwithcostandconstraintskeywords. 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 is much faster than solving an optimal control problem with terminal constraints.I also found and fixed some docstring glitches and naming inconsistencies in
control.optimalalong the way (these are all minor and don't change behavior. Unit tests, examples, and updated documentation are included.