-
Notifications
You must be signed in to change notification settings - Fork 113
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
Support numpy2 #411
base: main
Are you sure you want to change the base?
Support numpy2 #411
Conversation
Hmm so all the builds are failing due to the numpy lock file. Not sure how we should address this, since build-time dependency needs to be 2.0 but runtime version should be the one pinned. |
I think the fix for this would be to create a separate
I'm still familiarizing myself with the project, so I don't know why those three tests are failing, but I can push the commit on the changes I've made if you'd like @ewu63. |
Let me clarify - my comment above was regarding the Docker-based Linux tests. We use a pip constraint file in our toolchain and that's creating some issues. This is an issue with our toolchain and something for us maintainers (CC @eirikurj) to sort out. The step you mentioned is indeed necessary, and already done as part of this PR -- see here. The test is failing due to some regression errors that I have not had time to look into (which you can view by opening the test logs on GHA), and is unrelated to the build-time issues discussed above. Interestingly though, those errors are different from what you're seeing locally. |
Ah, I see. Thanks for that clarification. As another data point then, when I initially pulled the branch, and tried to run the tests I got the same thing that is in the |
Just a friendly ping to see if there are any updates on this PR. Looks like the assert in line 148 in |
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #411 +/- ##
=======================================
Coverage 74.98% 74.98%
=======================================
Files 22 22
Lines 3338 3338
=======================================
Hits 2503 2503
Misses 835 835 ☔ View full report in Codecov by Sentry. |
Okay, looks like I got past the pip-constraints file issue (which is frankly a bit hacky, CC @eirikurj). The Windows build (which is the only one testing numpy2 right now) is failing in a couple places, which probably requires further investigation. Hopefully no f2py shenanigans but we shall see. Suggested next steps for debugging:
In any case, I doubt I have time to work on this in the next few weeks, so I suggest someone in the lab take a look, maybe @marcomangano or @eirikurj? |
Ok I added numpy2 to the test matrix for windows but cannot get it to pass. In order to not hold up this PR any further I suggest that we push this through, and try to get the windows test coverage through conda-forge. Windows is technically not an official support platform anyhow so I think I'd rather get numpy2 to downstream users first. As for versions, I suggest that we release the current main branch as 2.12.1, and release this PR as 2.12.2 in order to isolate some of the recent changes. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So, just to be on the same page, right now numpy 2 is used at build time but the docker tests use their own matrix (which hopefully will include numpy 2 in the near future) and we will test numpy 2 on Win through CondaForge.
The failure looks due to a convergence issue wit IPOPT though, wouldn't that show up on conda as well?
@@ -26,7 +29,8 @@ jobs: | |||
shell: bash -l {0} | |||
run: | | |||
conda activate pyos-build | |||
mamba install libpgmath | |||
conda install libpgmath | |||
conda list -v |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this for debugging purposes?
"scipy>=1.7", | ||
"mdolab-baseclasses>=1.3.1", | ||
"setuptools", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I thought we got rid of setuptools
, where are currently we using it?
@@ -145,12 +145,11 @@ def test_ipopt(self): | |||
data_init = hist.read(0) | |||
self.assertEqual(0, data_init["iter"]) | |||
data_last = hist.read(hist.read("last")) | |||
self.assertEqual(11, data_last["iter"]) # took 12 function evaluations (see test_ipopt.out) | |||
self.assertGreater(data_last["iter"], 0) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why are we are not checking the total number of iterations anymore?
Purpose
Closes #408.
I removed the runtime requirement of numpy<2, and instead always build against numpy2 as suggested by numpy docs.
Changes
setuptools
as a runtime dependency (missing dependency; unrelated to numpy2 fixes).Expected time until merged
As long as it takes for CI to pass. While we don't test against numpy2 here (we could add CI for it for windows), we will be testing it on conda in the future.
Type of change
Testing
Checklist
flake8
andblack
to make sure the Python code adheres to PEP-8 and is consistently formattedfprettify
or C/C++ code withclang-format
as applicable