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

Upgrade MadNLPHSL.jl #376

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Conversation

amontoison
Copy link
Member

@amontoison amontoison commented Nov 13, 2024

Require the new release of HSL_jll.jl and this PR of HSL.jl:
JuliaSmoothOptimizers/HSL.jl#215

@frapac You will be able to easily try it.

@amontoison amontoison marked this pull request as draft November 13, 2024 03:54
@sshin23
Copy link
Member

sshin23 commented Nov 13, 2024

This is great! @amontoison, does only ma27 support quad precision? I guess it might be tricky once they rely on BLAS

@amontoison
Copy link
Member Author

amontoison commented Nov 13, 2024

Quadruple precision will only be supported in MA27 for the upcoming release of HSL_jll.jl.
However, the next release will bring other useful features, such as support of Int64 for the HSL solvers interfaced in MadNLP.

For supporting quadruple precision in other HSL linear solvers, we have a few challenges.
The first is the convention for BLAS/LAPACK symbols, which isn't standardized in quadruple precision:

Next, I need to add these symbols to LBT, as some of them are missing:

Finally, we need a BLAS/LAPACK library compiled in quadruple precision with the relevant symbols.

@nimgould plans to port the subset of routines needed in quadruple precision:

We might be able to include this in HSL_jll.jl, but all of this is speculative and will take some time before it becomes available.

@amontoison amontoison changed the title Interface MA27 in quadruple precision Uograde MadNLPHSL.jl Dec 27, 2024
@amontoison amontoison requested review from sshin23 and frapac December 27, 2024 08:42
@amontoison amontoison marked this pull request as ready for review December 27, 2024 08:42
@sshin23
Copy link
Member

sshin23 commented Dec 27, 2024

Looks good @amontoison! Now I think it is a good time to get rid of Int32 from MadNLP and make Int64 the default (but in a separate PR)

@amontoison
Copy link
Member Author

amontoison commented Dec 27, 2024

MA27 can also be used with quadruple precision with the PR.

I tested with the future version of HSL_jll.jl 2025.x.x that support Float128 for all solvers and it works too.
I did the modifications in HSL.jl such that we don't need to update MadNLPHSL.jl again.

The function HSL.is_supported will automatically return true with Float128 for ma57, ma77, etc...

@amontoison amontoison changed the title Uograde MadNLPHSL.jl Upgrade MadNLPHSL.jl Dec 27, 2024
@amontoison
Copy link
Member Author

@frapac Can I merge this PR?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants