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

Use numpy>=2 #613

Merged
merged 10 commits into from
Nov 26, 2024
Merged

Use numpy>=2 #613

merged 10 commits into from
Nov 26, 2024

Conversation

krzywon
Copy link
Collaborator

@krzywon krzywon commented Oct 28, 2024

This allows sasmodels to use numpy>=2. This also fixes two sphinx warnings that were happening during the build.

Fixes #604
Fixes #598
Refs #609

@bobleesj
Copy link
Contributor

@krzywon Thanks for this PR, just wondering, will this PR be reviewed or merged?

@krzywon
Copy link
Collaborator Author

krzywon commented Nov 19, 2024

@bobleesj, a review is required before a merge can be made into sasmodels, but that review can come from anyone who wasn't the original PR creator. Would you feel comfortable, and have the time to review it?

@bobleesj
Copy link
Contributor

@krzywon yes happy to review. Will do later in the afternoon.

Copy link
Contributor

Choose a reason for hiding this comment

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

I am wondering reasons preventing sasmodels from testing against Python 3.12 in the test.yml workflow?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Great question! I don't think there is anything holding us back. I'm going to add 3.12 and see what happens.

@@ -29,7 +29,7 @@ def find_version(package):
return version[1:-1]
raise RuntimeError("Could not read version from %s/__init__.py"%package)

install_requires = ['numpy==1.*', 'scipy']
install_requires = ['numpy', 'scipy']
Copy link
Contributor

Choose a reason for hiding this comment

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

great

@@ -36,8 +36,7 @@ jobs:
python -m pip install --upgrade pip
python -m pip install wheel setuptools
python -m pip install mako
python -m pip install numpy==1.*
Copy link
Contributor

Choose a reason for hiding this comment

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

great

@@ -70,8 +70,8 @@ def find_version(package):
},
install_requires=install_requires,
extras_require={
'full': ['docutils', 'bumps', 'matplotlib', 'columnize'],
'server': ['bumps'],
'full': ['docutils', 'bumps==0.*', 'matplotlib', 'columnize', 'siphash24'],
Copy link
Contributor

Choose a reason for hiding this comment

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

since I am new here, just wondering why bumps and siphash24 were modified

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

siphash24 was optionally required for a set of dependencies, but these changes move to a point where it is now required, which is why I've added it here. Without it, our tests were failing.

bumps is our optimizing package (https://github.com/bumps/bumps). v1.0 of bumps has made significant, breaking, changes that will create issues with packages that depend on sasmodels. This is a temporary fix to maintain compatibility.

Copy link
Contributor

Choose a reason for hiding this comment

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

Got it, thanks for the explanation!

Copy link
Contributor

@bobleesj bobleesj left a comment

Choose a reason for hiding this comment

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

@krzywon reviewed. Could you please check my comments?

Copy link

@sbillinge sbillinge left a comment

Choose a reason for hiding this comment

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

Thanks for the review @bobleesj . This also looks good to me.

@bobleesj
Copy link
Contributor

@krzywon Great! 3.12 is working here. For our group's package, we also plan to support Python 3.13. If it's not too much trouble, could you please check if 3.13 works as well?

@sbillinge
Copy link

btw, I am not sure who has write access and can provide a review. Are either of the Pauls (@pkienzle @butlerpd ) or Matthieu (@mdoucet ) still actively maintaining this? conda-forge is already shipping python 3.13 as latest so we are migrating all our diffpy codes over. I just am wondering who is leading the maintenance on here these days?

@krzywon
Copy link
Collaborator Author

krzywon commented Nov 19, 2024

@bobleesj, I've added the py3.13 test, as requested. Let's see what happens!

@sbillinge, I spoke to @pkienzle, and he says he will take a look when he has a chance.

@krzywon
Copy link
Collaborator Author

krzywon commented Nov 19, 2024

I rolled back from py3.13. The build is failing to find a compatible pyopencl wheel. I could probably build from source, but that is beyond the scope of this PR.

@bobleesj
Copy link
Contributor

I rolled back from py3.13. The build is failing to find a compatible pyopencl wheel. I could probably build from source, but that is beyond the scope of this PR.

Yes. Thanks a ton!

@andyfaff
Copy link
Contributor

Copy link
Contributor

@pkienzle pkienzle left a comment

Choose a reason for hiding this comment

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

Oops... thought I approved this already. Sorry!

@pkienzle pkienzle merged commit 049de31 into master Nov 26, 2024
18 checks passed
@pkienzle pkienzle deleted the numpy-update branch November 26, 2024 18:54
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.

scipy 1.14 introduces breaking changes NumPy 2.0.0 Breaking Changes
5 participants