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

Python 3.13 #9413

Closed
sklam opened this issue Jan 31, 2024 · 8 comments · Fixed by #9682
Closed

Python 3.13 #9413

sklam opened this issue Jan 31, 2024 · 8 comments · Fixed by #9682

Comments

@sklam
Copy link
Member

sklam commented Jan 31, 2024

This issue is to track tasks and issues with Python 3.13.

Numba support status:

@sklam sklam pinned this issue Jan 31, 2024
@sklam sklam unpinned this issue Feb 19, 2024
@sklam sklam pinned this issue Feb 19, 2024
@aaronzo
Copy link

aaronzo commented Jun 28, 2024

Great to see some steps towards 3.13 taking place - will numba publish PEP 703 free threading wheels (-cp313t)?

@sklam
Copy link
Member Author

sklam commented Jul 23, 2024

RE: #9413 (comment)

will numba publish PEP 703 free threading wheels (-cp313t)?

We are talking about providing freethreading packages but the current priority is just to get through all the issues with bytecode changes.

As of a8ad12a, the testsuite is at 493 failures out of 10385.

@sklam
Copy link
Member Author

sklam commented Jul 31, 2024

As of 6cafffe, everything is working on py3.13 except for 3 failures that are unrelated to py3.13:

  • numba.tests.test_lists.TestLists.test_mul_error
    • Python3.13 is not raising MemoryError in the hatchery docker.
    • rosetta error: could not find free space for allocation size 1000000000001000
  • numba.tests.test_nrt.TestNrtMemInfo.test_allocate_invalid_size
    • rosetta error: could not find free space for allocation size 2000000000001000
  • numba.tests.test_function_type.TestFunctionTypeExtensions.test_wrapper_address_protocol_libm
    • Fail when running alone. Works when with other tests. Probably due to
      initialization problem.

@jmerkel11
Copy link

Basically the same as aaronzo said, but for PEP 738.
At first thanks for your awesome work, then the question: Will you support numba on Android starting with Python 3.13?
Otherwise, current Android support will likely die ( chaquo/chaquopy#834 ).

@mhsmith
Copy link

mhsmith commented Sep 12, 2024

Hi, I'm the maintainer of Chaquopy. Both myself and the Numba maintainers now work for Anaconda, so we'll hopefully be able to produce Numba builds for Python 3.13 on Android later in the year. But first we'll need to deal with more fundamental packages like NumPy.

@jakirkham
Copy link
Contributor

Think we need llvmlite supported on Python 3.13. Is that being tracked in an issue somewhere as well?

@stuartarchibald
Copy link
Contributor

@jakirkham thanks for the reminder, there is now numba/llvmlite#1084

@slayoo
Copy link

slayoo commented Oct 22, 2024

For the record, since last week's update, the macos-14-arm64 image on GitHub Actions ships with system Python 3.13, which makes Numba uninstallable there as of now

https://newreleases.io/project/github/actions/runner-images/release/macos-14-arm64%2F20241014.301

Shonas301 added a commit to Shonas301/whisper that referenced this issue Oct 26, 2024
*Changes made*

- Update `setup.py` to pass in a local dictionary to `exec` to capture
  the `locals()` in `_version.py` for package version reporting.

*Motivation*

- `Python3.13.0` enforces stricter safety standards on `locals()` with
  PEP 667 (see [here](python/cpython#118888 (comment)))

- This causes the following error upon attempting to install with
  `python3.13 -m pip install openai-whisper`:

```bash
Collecting openai-whisper
  Using cached openai-whisper-20240930.tar.gz (800 kB)
  Installing build dependencies ... done
  Getting requirements to build wheel ... error
  error: subprocess-exited-with-error

  × Getting requirements to build wheel did not run successfully.
  │ exit code: 1
  ╰─> [25 lines of output]
      <string>:5: DeprecationWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html
      Traceback (most recent call last):
        File "/Users/jasonshipp/.pyenv/versions/3.13.0/lib/python3.13/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 353, in <module>
          main()
          ~~~~^^
        File "/Users/jasonshipp/.pyenv/versions/3.13.0/lib/python3.13/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 335, in main
          json_out['return_val'] = hook(**hook_input['kwargs'])
                                   ~~~~^^^^^^^^^^^^^^^^^^^^^^^^
        File "/Users/jasonshipp/.pyenv/versions/3.13.0/lib/python3.13/site-packages/pip/_vendor/pyproject_hooks/_in_process/_in_process.py", line 118, in get_requires_for_build_wheel
          return hook(config_settings)
        File "/private/var/folders/hk/8xz63_l16zb9snz57jx9hqgr0000gn/T/pip-build-env-l_19mrvs/overlay/lib/python3.13/site-packages/setuptools/build_meta.py", line 332, in get_requires_for_build_wheel
          return self._get_build_requires(config_settings, requirements=[])
                 ~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
        File "/private/var/folders/hk/8xz63_l16zb9snz57jx9hqgr0000gn/T/pip-build-env-l_19mrvs/overlay/lib/python3.13/site-packages/setuptools/build_meta.py", line 302, in _get_build_requires
          self.run_setup()
          ~~~~~~~~~~~~~~^^
        File "/private/var/folders/hk/8xz63_l16zb9snz57jx9hqgr0000gn/T/pip-build-env-l_19mrvs/overlay/lib/python3.13/site-packages/setuptools/build_meta.py", line 516, in run_setup
          super().run_setup(setup_script=setup_script)
          ~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^
        File "/private/var/folders/hk/8xz63_l16zb9snz57jx9hqgr0000gn/T/pip-build-env-l_19mrvs/overlay/lib/python3.13/site-packages/setuptools/build_meta.py", line 318, in run_setup
          exec(code, locals())
          ~~~~^^^^^^^^^^^^^^^^
        File "<string>", line 21, in <module>
        File "<string>", line 11, in read_version
      KeyError: '__version__'
      [end of output]

  note: This error originates from a subprocess, and is likely not a problem with pip.
error: subprocess-exited-with-error

× Getting requirements to build wheel did not run successfully.
│ exit code: 1
╰─> See above for output.

note: This error originates from a subprocess, and is likely not a problem with pip
```

*EXTRA NOTES*

- This does not enable `openai-whisper` to be pip installed with
  `Python3.13`, due to a dependency on the `numba` library. This issue
  and missing dependency can be tracked [here](numba/numba#9413)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

7 participants