Skip to content
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

The Riemannian Interior Point Newton Method #399

Merged
merged 267 commits into from
Aug 2, 2024

Conversation

kellertuer
Copy link
Member

@kellertuer kellertuer commented Jun 28, 2024

This is my (third) summer project: This is initial code for a Riemannian Interior Point Newton method based on the master thesis of @mstokkenes, where of course documentation and testing are not part of master theses, but exploring how this algorithms works and illustrating that is works.
A Matlab code for the same idea this is based on (and from the authors of the original paper) is https://github.com/GALVINLAI/RIPM, though here the notation is already much closer to that of Manopt.jl

🛣️ Roadmap

  • 🛠️ refactor code to VectorialHessianFunctions, which are newer than the original code base
  • 🛠️ Refactor is_feasible to work in a more general sense than just for RIPM and (re-)introduce DebugFeasibility()
  • 🛠️ rework KKT vector field, Jacobian and the merit function (incl. documentation)
  • 🛠️ store the merit function and its gradient as the stepsize_objective and for the additional check use centrality_condition
  • 🛠️ debug and refactor Conjugate residual
  • 🔎 carefully check the condensed KKT system
  • 🔎 carefully debug the parameters ρ and σ (Section 8.1 YL) and their update
  • ⚠️ for now the IPNewton performs one or two steps very well, then the gradient seems not be a descent direction (but I am also not yet 100% through with documentation and testing)
  • 📚extend all new documentation strings
  • fix Refine storage of subsolver states #403 on all solvers that have a subsolver.
  • 📈 ensure proper test coverage

mstokkenes and others added 30 commits April 20, 2024 18:56
Now more similar to rest of Manopt
step_solver! for interior point Newton now employs conjugate_gradient!, and interior_point_Newton! converges unless first iterate is not feasible
Also changed AbstractManoptProblem inputs to AbstractManoptProblem{<:TangentSpace}
Also added possibility for plotting results for visualization purposes. Added  comments throughout code.
…irarchical maybe (at least seen from the main solver).
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
kellertuer and others added 7 commits August 1, 2024 20:01
its a bit like knitting – one can nearly do that while watching a documentation.
…iaManifolds/Manopt.jl into kellertuer/riemannian-interior-point

# Conflicts:
#	src/solvers/difference_of_convex_algorithm.jl
@kellertuer
Copy link
Member Author

Oh TR looks a bit more involved, the code is quite old and might also benefit from a bit of improvements anyways. Do you want to do that or shall I?

@mateuszbaran
Copy link
Member

I can adapt TR.

@kellertuer
Copy link
Member Author

We have all others and proper code cov.

@kellertuer
Copy link
Member Author

Oh, I introduced an ambiguity? Why did that not happen for the other solvers? I do not directly se how to resolve that.

@mateuszbaran
Copy link
Member

I've adapted TR and resolved the ambiguity.

@kellertuer
Copy link
Member Author

I am not so sure where we lost the 2 lines on TR, but the rest seems to be fine.

@kellertuer
Copy link
Member Author

Yay! I'd call this finished, but would be happy if you could approve it as well.
We can also wait until tomorrow with merging.

@mateuszbaran
Copy link
Member

I would like to take one more look at this PR tomorrow, mostly to check if there are any major performance issues or some small documentation improvements.

@kellertuer
Copy link
Member Author

Sure, If you find something and do a commit, you can also adapt the date in the changelog.
I can check back here tomorrow afternoon then, since I will be on a hike tomorrow (one we can also do when you are here).

Copy link
Member

@mateuszbaran mateuszbaran left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Performance is not great but to improve that I need to extend PowerManifold a bit first. I think this would be better suited for a separate PR.

Changelog.md Outdated Show resolved Hide resolved
@kellertuer
Copy link
Member Author

Performance is not great but to improve that I need to extend PowerManifold a bit first. I think this would be better suited for a separate PR.

I think s well, this took quite a while to get done, so working is my first goal here, performance a next one.
I did work through most of the access functions used for constraints and used the single access ones for performance for example.

…iaManifolds/Manopt.jl into kellertuer/riemannian-interior-point
@kellertuer kellertuer merged commit 0b05c8c into master Aug 2, 2024
15 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Ready-for-Review A label for pull requests that are feature-ready
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Refine storage of subsolver states
3 participants