scipy 1.15.3__cp312-cp312-macosx_14_0_arm64.whl → 1.16.0rc2__cp312-cp312-macosx_14_0_arm64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- scipy/__config__.py +4 -4
- scipy/__init__.py +3 -6
- scipy/_cyutility.cpython-312-darwin.so +0 -0
- scipy/_lib/_array_api.py +486 -161
- scipy/_lib/_array_api_compat_vendor.py +9 -0
- scipy/_lib/_bunch.py +4 -0
- scipy/_lib/_ccallback_c.cpython-312-darwin.so +0 -0
- scipy/_lib/_docscrape.py +1 -1
- scipy/_lib/_elementwise_iterative_method.py +15 -26
- scipy/_lib/_sparse.py +41 -0
- scipy/_lib/_test_deprecation_call.cpython-312-darwin.so +0 -0
- scipy/_lib/_test_deprecation_def.cpython-312-darwin.so +0 -0
- scipy/_lib/_testutils.py +6 -2
- scipy/_lib/_util.py +222 -125
- scipy/_lib/array_api_compat/__init__.py +4 -4
- scipy/_lib/array_api_compat/_internal.py +19 -6
- scipy/_lib/array_api_compat/common/__init__.py +1 -1
- scipy/_lib/array_api_compat/common/_aliases.py +365 -193
- scipy/_lib/array_api_compat/common/_fft.py +94 -64
- scipy/_lib/array_api_compat/common/_helpers.py +413 -180
- scipy/_lib/array_api_compat/common/_linalg.py +116 -40
- scipy/_lib/array_api_compat/common/_typing.py +179 -10
- scipy/_lib/array_api_compat/cupy/__init__.py +1 -4
- scipy/_lib/array_api_compat/cupy/_aliases.py +61 -41
- scipy/_lib/array_api_compat/cupy/_info.py +16 -6
- scipy/_lib/array_api_compat/cupy/_typing.py +24 -39
- scipy/_lib/array_api_compat/dask/array/__init__.py +6 -3
- scipy/_lib/array_api_compat/dask/array/_aliases.py +267 -108
- scipy/_lib/array_api_compat/dask/array/_info.py +105 -34
- scipy/_lib/array_api_compat/dask/array/fft.py +5 -8
- scipy/_lib/array_api_compat/dask/array/linalg.py +21 -22
- scipy/_lib/array_api_compat/numpy/__init__.py +13 -15
- scipy/_lib/array_api_compat/numpy/_aliases.py +98 -49
- scipy/_lib/array_api_compat/numpy/_info.py +36 -16
- scipy/_lib/array_api_compat/numpy/_typing.py +27 -43
- scipy/_lib/array_api_compat/numpy/fft.py +11 -5
- scipy/_lib/array_api_compat/numpy/linalg.py +75 -22
- scipy/_lib/array_api_compat/torch/__init__.py +3 -5
- scipy/_lib/array_api_compat/torch/_aliases.py +262 -159
- scipy/_lib/array_api_compat/torch/_info.py +27 -16
- scipy/_lib/array_api_compat/torch/_typing.py +3 -0
- scipy/_lib/array_api_compat/torch/fft.py +17 -18
- scipy/_lib/array_api_compat/torch/linalg.py +16 -16
- scipy/_lib/array_api_extra/__init__.py +26 -3
- scipy/_lib/array_api_extra/_delegation.py +171 -0
- scipy/_lib/array_api_extra/_lib/__init__.py +1 -0
- scipy/_lib/array_api_extra/_lib/_at.py +463 -0
- scipy/_lib/array_api_extra/_lib/_backends.py +46 -0
- scipy/_lib/array_api_extra/_lib/_funcs.py +937 -0
- scipy/_lib/array_api_extra/_lib/_lazy.py +357 -0
- scipy/_lib/array_api_extra/_lib/_testing.py +278 -0
- scipy/_lib/array_api_extra/_lib/_utils/__init__.py +1 -0
- scipy/_lib/array_api_extra/_lib/_utils/_compat.py +74 -0
- scipy/_lib/array_api_extra/_lib/_utils/_compat.pyi +45 -0
- scipy/_lib/array_api_extra/_lib/_utils/_helpers.py +559 -0
- scipy/_lib/array_api_extra/_lib/_utils/_typing.py +10 -0
- scipy/_lib/array_api_extra/_lib/_utils/_typing.pyi +105 -0
- scipy/_lib/array_api_extra/testing.py +359 -0
- scipy/_lib/decorator.py +2 -2
- scipy/_lib/doccer.py +1 -7
- scipy/_lib/messagestream.cpython-312-darwin.so +0 -0
- scipy/_lib/pyprima/__init__.py +212 -0
- scipy/_lib/pyprima/cobyla/__init__.py +0 -0
- scipy/_lib/pyprima/cobyla/cobyla.py +559 -0
- scipy/_lib/pyprima/cobyla/cobylb.py +714 -0
- scipy/_lib/pyprima/cobyla/geometry.py +226 -0
- scipy/_lib/pyprima/cobyla/initialize.py +215 -0
- scipy/_lib/pyprima/cobyla/trustregion.py +492 -0
- scipy/_lib/pyprima/cobyla/update.py +289 -0
- scipy/_lib/pyprima/common/__init__.py +0 -0
- scipy/_lib/pyprima/common/_bounds.py +34 -0
- scipy/_lib/pyprima/common/_linear_constraints.py +46 -0
- scipy/_lib/pyprima/common/_nonlinear_constraints.py +54 -0
- scipy/_lib/pyprima/common/_project.py +173 -0
- scipy/_lib/pyprima/common/checkbreak.py +93 -0
- scipy/_lib/pyprima/common/consts.py +47 -0
- scipy/_lib/pyprima/common/evaluate.py +99 -0
- scipy/_lib/pyprima/common/history.py +38 -0
- scipy/_lib/pyprima/common/infos.py +30 -0
- scipy/_lib/pyprima/common/linalg.py +435 -0
- scipy/_lib/pyprima/common/message.py +290 -0
- scipy/_lib/pyprima/common/powalg.py +131 -0
- scipy/_lib/pyprima/common/preproc.py +277 -0
- scipy/_lib/pyprima/common/present.py +5 -0
- scipy/_lib/pyprima/common/ratio.py +54 -0
- scipy/_lib/pyprima/common/redrho.py +47 -0
- scipy/_lib/pyprima/common/selectx.py +296 -0
- scipy/_lib/tests/test__util.py +105 -121
- scipy/_lib/tests/test_array_api.py +166 -35
- scipy/_lib/tests/test_bunch.py +7 -0
- scipy/_lib/tests/test_ccallback.py +2 -10
- scipy/_lib/tests/test_public_api.py +13 -0
- scipy/cluster/_hierarchy.cpython-312-darwin.so +0 -0
- scipy/cluster/_optimal_leaf_ordering.cpython-312-darwin.so +0 -0
- scipy/cluster/_vq.cpython-312-darwin.so +0 -0
- scipy/cluster/hierarchy.py +393 -223
- scipy/cluster/tests/test_hierarchy.py +273 -335
- scipy/cluster/tests/test_vq.py +45 -61
- scipy/cluster/vq.py +39 -35
- scipy/conftest.py +263 -157
- scipy/constants/_constants.py +4 -1
- scipy/constants/tests/test_codata.py +2 -2
- scipy/constants/tests/test_constants.py +11 -18
- scipy/datasets/_download_all.py +15 -1
- scipy/datasets/_fetchers.py +7 -1
- scipy/datasets/_utils.py +1 -1
- scipy/differentiate/_differentiate.py +25 -25
- scipy/differentiate/tests/test_differentiate.py +24 -25
- scipy/fft/_basic.py +20 -0
- scipy/fft/_helper.py +3 -34
- scipy/fft/_pocketfft/helper.py +29 -1
- scipy/fft/_pocketfft/tests/test_basic.py +2 -4
- scipy/fft/_pocketfft/tests/test_real_transforms.py +4 -4
- scipy/fft/_realtransforms.py +13 -0
- scipy/fft/tests/test_basic.py +27 -25
- scipy/fft/tests/test_fftlog.py +16 -7
- scipy/fft/tests/test_helper.py +18 -34
- scipy/fft/tests/test_real_transforms.py +8 -10
- scipy/fftpack/convolve.cpython-312-darwin.so +0 -0
- scipy/fftpack/tests/test_basic.py +2 -4
- scipy/fftpack/tests/test_real_transforms.py +8 -9
- scipy/integrate/_bvp.py +9 -3
- scipy/integrate/_cubature.py +3 -2
- scipy/integrate/_dop.cpython-312-darwin.so +0 -0
- scipy/integrate/_lsoda.cpython-312-darwin.so +0 -0
- scipy/integrate/_ode.py +9 -2
- scipy/integrate/_odepack.cpython-312-darwin.so +0 -0
- scipy/integrate/_quad_vec.py +21 -29
- scipy/integrate/_quadpack.cpython-312-darwin.so +0 -0
- scipy/integrate/_quadpack_py.py +11 -7
- scipy/integrate/_quadrature.py +3 -3
- scipy/integrate/_rules/_base.py +2 -2
- scipy/integrate/_tanhsinh.py +48 -47
- scipy/integrate/_test_odeint_banded.cpython-312-darwin.so +0 -0
- scipy/integrate/_vode.cpython-312-darwin.so +0 -0
- scipy/integrate/tests/test__quad_vec.py +0 -6
- scipy/integrate/tests/test_banded_ode_solvers.py +85 -0
- scipy/integrate/tests/test_cubature.py +21 -35
- scipy/integrate/tests/test_quadrature.py +6 -8
- scipy/integrate/tests/test_tanhsinh.py +56 -48
- scipy/interpolate/__init__.py +70 -58
- scipy/interpolate/_bary_rational.py +22 -22
- scipy/interpolate/_bsplines.py +119 -66
- scipy/interpolate/_cubic.py +65 -50
- scipy/interpolate/_dfitpack.cpython-312-darwin.so +0 -0
- scipy/interpolate/_dierckx.cpython-312-darwin.so +0 -0
- scipy/interpolate/_fitpack.cpython-312-darwin.so +0 -0
- scipy/interpolate/_fitpack2.py +9 -6
- scipy/interpolate/_fitpack_impl.py +32 -26
- scipy/interpolate/_fitpack_repro.py +23 -19
- scipy/interpolate/_interpnd.cpython-312-darwin.so +0 -0
- scipy/interpolate/_interpolate.py +30 -12
- scipy/interpolate/_ndbspline.py +13 -18
- scipy/interpolate/_ndgriddata.py +5 -8
- scipy/interpolate/_polyint.py +95 -31
- scipy/interpolate/_ppoly.cpython-312-darwin.so +0 -0
- scipy/interpolate/_rbf.py +2 -2
- scipy/interpolate/_rbfinterp.py +1 -1
- scipy/interpolate/_rbfinterp_pythran.cpython-312-darwin.so +0 -0
- scipy/interpolate/_rgi.py +31 -26
- scipy/interpolate/_rgi_cython.cpython-312-darwin.so +0 -0
- scipy/interpolate/dfitpack.py +0 -20
- scipy/interpolate/interpnd.py +1 -2
- scipy/interpolate/tests/test_bary_rational.py +2 -2
- scipy/interpolate/tests/test_bsplines.py +97 -1
- scipy/interpolate/tests/test_fitpack2.py +39 -1
- scipy/interpolate/tests/test_interpnd.py +32 -20
- scipy/interpolate/tests/test_interpolate.py +48 -4
- scipy/interpolate/tests/test_rgi.py +2 -1
- scipy/io/_fast_matrix_market/__init__.py +2 -0
- scipy/io/_harwell_boeing/_fortran_format_parser.py +19 -16
- scipy/io/_harwell_boeing/hb.py +7 -11
- scipy/io/_idl.py +5 -7
- scipy/io/_netcdf.py +15 -5
- scipy/io/_test_fortran.cpython-312-darwin.so +0 -0
- scipy/io/arff/tests/test_arffread.py +3 -3
- scipy/io/matlab/__init__.py +5 -3
- scipy/io/matlab/_mio.py +4 -1
- scipy/io/matlab/_mio5.py +19 -13
- scipy/io/matlab/_mio5_utils.cpython-312-darwin.so +0 -0
- scipy/io/matlab/_mio_utils.cpython-312-darwin.so +0 -0
- scipy/io/matlab/_miobase.py +4 -1
- scipy/io/matlab/_streams.cpython-312-darwin.so +0 -0
- scipy/io/matlab/tests/test_mio.py +46 -18
- scipy/io/matlab/tests/test_mio_funcs.py +1 -1
- scipy/io/tests/test_mmio.py +7 -1
- scipy/io/tests/test_wavfile.py +41 -0
- scipy/io/wavfile.py +57 -10
- scipy/linalg/_basic.py +113 -86
- scipy/linalg/_cythonized_array_utils.cpython-312-darwin.so +0 -0
- scipy/linalg/_decomp.py +22 -9
- scipy/linalg/_decomp_cholesky.py +28 -13
- scipy/linalg/_decomp_cossin.py +45 -30
- scipy/linalg/_decomp_interpolative.cpython-312-darwin.so +0 -0
- scipy/linalg/_decomp_ldl.py +4 -1
- scipy/linalg/_decomp_lu.py +18 -6
- scipy/linalg/_decomp_lu_cython.cpython-312-darwin.so +0 -0
- scipy/linalg/_decomp_polar.py +2 -0
- scipy/linalg/_decomp_qr.py +6 -2
- scipy/linalg/_decomp_qz.py +3 -0
- scipy/linalg/_decomp_schur.py +3 -1
- scipy/linalg/_decomp_svd.py +13 -2
- scipy/linalg/_decomp_update.cpython-312-darwin.so +0 -0
- scipy/linalg/_expm_frechet.py +4 -0
- scipy/linalg/_fblas.cpython-312-darwin.so +0 -0
- scipy/linalg/_flapack.cpython-312-darwin.so +0 -0
- scipy/linalg/_linalg_pythran.cpython-312-darwin.so +0 -0
- scipy/linalg/_matfuncs.py +187 -4
- scipy/linalg/_matfuncs_expm.cpython-312-darwin.so +0 -0
- scipy/linalg/_matfuncs_schur_sqrtm.cpython-312-darwin.so +0 -0
- scipy/linalg/_matfuncs_sqrtm.py +1 -99
- scipy/linalg/_matfuncs_sqrtm_triu.cpython-312-darwin.so +0 -0
- scipy/linalg/_procrustes.py +2 -0
- scipy/linalg/_sketches.py +17 -6
- scipy/linalg/_solve_toeplitz.cpython-312-darwin.so +0 -0
- scipy/linalg/_solvers.py +7 -2
- scipy/linalg/_special_matrices.py +26 -36
- scipy/linalg/cython_blas.cpython-312-darwin.so +0 -0
- scipy/linalg/cython_lapack.cpython-312-darwin.so +0 -0
- scipy/linalg/lapack.py +22 -2
- scipy/linalg/tests/_cython_examples/meson.build +7 -0
- scipy/linalg/tests/test_basic.py +31 -16
- scipy/linalg/tests/test_batch.py +588 -0
- scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
- scipy/linalg/tests/test_decomp.py +40 -3
- scipy/linalg/tests/test_decomp_cossin.py +14 -0
- scipy/linalg/tests/test_decomp_ldl.py +1 -1
- scipy/linalg/tests/test_lapack.py +115 -7
- scipy/linalg/tests/test_matfuncs.py +157 -102
- scipy/linalg/tests/test_procrustes.py +0 -7
- scipy/linalg/tests/test_solve_toeplitz.py +1 -1
- scipy/linalg/tests/test_special_matrices.py +1 -5
- scipy/ndimage/__init__.py +1 -0
- scipy/ndimage/_cytest.cpython-312-darwin.so +0 -0
- scipy/ndimage/_delegators.py +8 -2
- scipy/ndimage/_filters.py +453 -5
- scipy/ndimage/_interpolation.py +36 -6
- scipy/ndimage/_measurements.py +4 -2
- scipy/ndimage/_morphology.py +5 -0
- scipy/ndimage/_nd_image.cpython-312-darwin.so +0 -0
- scipy/ndimage/_ni_docstrings.py +5 -1
- scipy/ndimage/_ni_label.cpython-312-darwin.so +0 -0
- scipy/ndimage/_ni_support.py +1 -5
- scipy/ndimage/_rank_filter_1d.cpython-312-darwin.so +0 -0
- scipy/ndimage/_support_alternative_backends.py +18 -6
- scipy/ndimage/tests/test_filters.py +370 -259
- scipy/ndimage/tests/test_fourier.py +7 -9
- scipy/ndimage/tests/test_interpolation.py +68 -61
- scipy/ndimage/tests/test_measurements.py +18 -35
- scipy/ndimage/tests/test_morphology.py +143 -131
- scipy/ndimage/tests/test_splines.py +1 -3
- scipy/odr/__odrpack.cpython-312-darwin.so +0 -0
- scipy/optimize/_basinhopping.py +13 -7
- scipy/optimize/_bglu_dense.cpython-312-darwin.so +0 -0
- scipy/optimize/_bracket.py +17 -24
- scipy/optimize/_chandrupatla.py +9 -10
- scipy/optimize/_cobyla_py.py +104 -123
- scipy/optimize/_constraints.py +14 -10
- scipy/optimize/_differentiable_functions.py +371 -230
- scipy/optimize/_differentialevolution.py +4 -3
- scipy/optimize/_direct.cpython-312-darwin.so +0 -0
- scipy/optimize/_dual_annealing.py +1 -1
- scipy/optimize/_elementwise.py +1 -4
- scipy/optimize/_group_columns.cpython-312-darwin.so +0 -0
- scipy/optimize/_lbfgsb.cpython-312-darwin.so +0 -0
- scipy/optimize/_lbfgsb_py.py +57 -16
- scipy/optimize/_linprog_doc.py +2 -2
- scipy/optimize/_linprog_highs.py +2 -2
- scipy/optimize/_linprog_ip.py +25 -10
- scipy/optimize/_linprog_util.py +14 -16
- scipy/optimize/_lsap.cpython-312-darwin.so +0 -0
- scipy/optimize/_lsq/common.py +3 -3
- scipy/optimize/_lsq/dogbox.py +16 -2
- scipy/optimize/_lsq/givens_elimination.cpython-312-darwin.so +0 -0
- scipy/optimize/_lsq/least_squares.py +198 -126
- scipy/optimize/_lsq/lsq_linear.py +6 -6
- scipy/optimize/_lsq/trf.py +35 -8
- scipy/optimize/_milp.py +3 -1
- scipy/optimize/_minimize.py +105 -36
- scipy/optimize/_minpack.cpython-312-darwin.so +0 -0
- scipy/optimize/_minpack_py.py +21 -14
- scipy/optimize/_moduleTNC.cpython-312-darwin.so +0 -0
- scipy/optimize/_nnls.py +20 -21
- scipy/optimize/_nonlin.py +34 -3
- scipy/optimize/_numdiff.py +288 -110
- scipy/optimize/_optimize.py +86 -48
- scipy/optimize/_pava_pybind.cpython-312-darwin.so +0 -0
- scipy/optimize/_remove_redundancy.py +5 -5
- scipy/optimize/_root_scalar.py +1 -1
- scipy/optimize/_shgo.py +6 -0
- scipy/optimize/_shgo_lib/_complex.py +1 -1
- scipy/optimize/_slsqp_py.py +216 -124
- scipy/optimize/_slsqplib.cpython-312-darwin.so +0 -0
- scipy/optimize/_spectral.py +1 -1
- scipy/optimize/_tnc.py +8 -1
- scipy/optimize/_trlib/_trlib.cpython-312-darwin.so +0 -0
- scipy/optimize/_trustregion.py +20 -6
- scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
- scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
- scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
- scipy/optimize/_trustregion_constr/projections.py +12 -8
- scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
- scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
- scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
- scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
- scipy/optimize/_trustregion_exact.py +0 -1
- scipy/optimize/_zeros.cpython-312-darwin.so +0 -0
- scipy/optimize/_zeros_py.py +97 -17
- scipy/optimize/cython_optimize/_zeros.cpython-312-darwin.so +0 -0
- scipy/optimize/slsqp.py +0 -1
- scipy/optimize/tests/test__basinhopping.py +1 -1
- scipy/optimize/tests/test__differential_evolution.py +4 -4
- scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
- scipy/optimize/tests/test__numdiff.py +66 -22
- scipy/optimize/tests/test__remove_redundancy.py +2 -2
- scipy/optimize/tests/test__shgo.py +9 -1
- scipy/optimize/tests/test_bracket.py +36 -46
- scipy/optimize/tests/test_chandrupatla.py +133 -135
- scipy/optimize/tests/test_cobyla.py +74 -45
- scipy/optimize/tests/test_constraints.py +1 -1
- scipy/optimize/tests/test_differentiable_functions.py +226 -6
- scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
- scipy/optimize/tests/test_least_squares.py +125 -13
- scipy/optimize/tests/test_linear_assignment.py +3 -3
- scipy/optimize/tests/test_linprog.py +3 -3
- scipy/optimize/tests/test_lsq_linear.py +6 -6
- scipy/optimize/tests/test_minimize_constrained.py +2 -2
- scipy/optimize/tests/test_minpack.py +4 -4
- scipy/optimize/tests/test_nnls.py +43 -3
- scipy/optimize/tests/test_nonlin.py +36 -0
- scipy/optimize/tests/test_optimize.py +95 -17
- scipy/optimize/tests/test_slsqp.py +36 -4
- scipy/optimize/tests/test_zeros.py +34 -1
- scipy/signal/__init__.py +12 -23
- scipy/signal/_delegators.py +568 -0
- scipy/signal/_filter_design.py +459 -241
- scipy/signal/_fir_filter_design.py +262 -90
- scipy/signal/_lti_conversion.py +3 -2
- scipy/signal/_ltisys.py +118 -91
- scipy/signal/_max_len_seq_inner.cpython-312-darwin.so +0 -0
- scipy/signal/_peak_finding_utils.cpython-312-darwin.so +0 -0
- scipy/signal/_polyutils.py +172 -0
- scipy/signal/_short_time_fft.py +519 -70
- scipy/signal/_signal_api.py +30 -0
- scipy/signal/_signaltools.py +719 -399
- scipy/signal/_sigtools.cpython-312-darwin.so +0 -0
- scipy/signal/_sosfilt.cpython-312-darwin.so +0 -0
- scipy/signal/_spectral_py.py +230 -50
- scipy/signal/_spline.cpython-312-darwin.so +0 -0
- scipy/signal/_spline_filters.py +108 -68
- scipy/signal/_support_alternative_backends.py +73 -0
- scipy/signal/_upfirdn.py +4 -1
- scipy/signal/_upfirdn_apply.cpython-312-darwin.so +0 -0
- scipy/signal/_waveforms.py +2 -11
- scipy/signal/_wavelets.py +1 -1
- scipy/signal/fir_filter_design.py +1 -0
- scipy/signal/spline.py +4 -11
- scipy/signal/tests/_scipy_spectral_test_shim.py +2 -171
- scipy/signal/tests/test_bsplines.py +114 -79
- scipy/signal/tests/test_cont2discrete.py +9 -2
- scipy/signal/tests/test_filter_design.py +721 -481
- scipy/signal/tests/test_fir_filter_design.py +332 -140
- scipy/signal/tests/test_savitzky_golay.py +4 -3
- scipy/signal/tests/test_short_time_fft.py +221 -3
- scipy/signal/tests/test_signaltools.py +2144 -1348
- scipy/signal/tests/test_spectral.py +50 -6
- scipy/signal/tests/test_splines.py +161 -96
- scipy/signal/tests/test_upfirdn.py +84 -50
- scipy/signal/tests/test_waveforms.py +20 -0
- scipy/signal/tests/test_windows.py +607 -466
- scipy/signal/windows/_windows.py +287 -148
- scipy/sparse/__init__.py +23 -4
- scipy/sparse/_base.py +270 -108
- scipy/sparse/_bsr.py +7 -4
- scipy/sparse/_compressed.py +59 -231
- scipy/sparse/_construct.py +90 -38
- scipy/sparse/_coo.py +115 -181
- scipy/sparse/_csc.py +4 -4
- scipy/sparse/_csparsetools.cpython-312-darwin.so +0 -0
- scipy/sparse/_csr.py +2 -2
- scipy/sparse/_data.py +48 -48
- scipy/sparse/_dia.py +105 -18
- scipy/sparse/_dok.py +0 -23
- scipy/sparse/_index.py +4 -4
- scipy/sparse/_matrix.py +23 -0
- scipy/sparse/_sparsetools.cpython-312-darwin.so +0 -0
- scipy/sparse/_sputils.py +37 -22
- scipy/sparse/base.py +0 -9
- scipy/sparse/bsr.py +0 -14
- scipy/sparse/compressed.py +0 -23
- scipy/sparse/construct.py +0 -6
- scipy/sparse/coo.py +0 -14
- scipy/sparse/csc.py +0 -3
- scipy/sparse/csgraph/_flow.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_matching.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_min_spanning_tree.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_reordering.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_shortest_path.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_tools.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/_traversal.cpython-312-darwin.so +0 -0
- scipy/sparse/csgraph/tests/test_matching.py +14 -2
- scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
- scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
- scipy/sparse/csr.py +0 -5
- scipy/sparse/data.py +1 -6
- scipy/sparse/dia.py +0 -7
- scipy/sparse/dok.py +0 -10
- scipy/sparse/linalg/_dsolve/_superlu.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
- scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
- scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_eigen/arpack/arpack.py +23 -17
- scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
- scipy/sparse/linalg/_interface.py +17 -18
- scipy/sparse/linalg/_isolve/_gcrotmk.py +4 -4
- scipy/sparse/linalg/_isolve/iterative.py +51 -45
- scipy/sparse/linalg/_isolve/lgmres.py +6 -6
- scipy/sparse/linalg/_isolve/minres.py +5 -5
- scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
- scipy/sparse/linalg/_isolve/utils.py +2 -8
- scipy/sparse/linalg/_matfuncs.py +1 -1
- scipy/sparse/linalg/_norm.py +1 -1
- scipy/sparse/linalg/_propack/_cpropack.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_propack/_dpropack.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_propack/_spropack.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_propack/_zpropack.cpython-312-darwin.so +0 -0
- scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
- scipy/sparse/linalg/tests/test_pydata_sparse.py +14 -0
- scipy/sparse/tests/test_arithmetic1d.py +5 -2
- scipy/sparse/tests/test_base.py +214 -42
- scipy/sparse/tests/test_common1d.py +7 -7
- scipy/sparse/tests/test_construct.py +1 -1
- scipy/sparse/tests/test_coo.py +272 -4
- scipy/sparse/tests/test_sparsetools.py +5 -0
- scipy/sparse/tests/test_sputils.py +36 -7
- scipy/spatial/_ckdtree.cpython-312-darwin.so +0 -0
- scipy/spatial/_distance_pybind.cpython-312-darwin.so +0 -0
- scipy/spatial/_distance_wrap.cpython-312-darwin.so +0 -0
- scipy/spatial/_hausdorff.cpython-312-darwin.so +0 -0
- scipy/spatial/_qhull.cpython-312-darwin.so +0 -0
- scipy/spatial/_voronoi.cpython-312-darwin.so +0 -0
- scipy/spatial/distance.py +49 -42
- scipy/spatial/tests/test_distance.py +15 -1
- scipy/spatial/tests/test_kdtree.py +1 -0
- scipy/spatial/tests/test_qhull.py +7 -2
- scipy/spatial/transform/__init__.py +5 -3
- scipy/spatial/transform/_rigid_transform.cpython-312-darwin.so +0 -0
- scipy/spatial/transform/_rotation.cpython-312-darwin.so +0 -0
- scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
- scipy/spatial/transform/tests/test_rotation.py +1213 -832
- scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
- scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
- scipy/special/__init__.py +1 -47
- scipy/special/_add_newdocs.py +34 -772
- scipy/special/_basic.py +22 -25
- scipy/special/_comb.cpython-312-darwin.so +0 -0
- scipy/special/_ellip_harm_2.cpython-312-darwin.so +0 -0
- scipy/special/_gufuncs.cpython-312-darwin.so +0 -0
- scipy/special/_logsumexp.py +67 -58
- scipy/special/_orthogonal.pyi +1 -1
- scipy/special/_specfun.cpython-312-darwin.so +0 -0
- scipy/special/_special_ufuncs.cpython-312-darwin.so +0 -0
- scipy/special/_spherical_bessel.py +4 -4
- scipy/special/_support_alternative_backends.py +212 -119
- scipy/special/_test_internal.cpython-312-darwin.so +0 -0
- scipy/special/_testutils.py +4 -4
- scipy/special/_ufuncs.cpython-312-darwin.so +0 -0
- scipy/special/_ufuncs.pyi +1 -0
- scipy/special/_ufuncs.pyx +215 -1400
- scipy/special/_ufuncs_cxx.cpython-312-darwin.so +0 -0
- scipy/special/_ufuncs_cxx.pxd +2 -15
- scipy/special/_ufuncs_cxx.pyx +5 -44
- scipy/special/_ufuncs_cxx_defs.h +2 -16
- scipy/special/_ufuncs_defs.h +0 -8
- scipy/special/cython_special.cpython-312-darwin.so +0 -0
- scipy/special/cython_special.pxd +1 -1
- scipy/special/tests/_cython_examples/meson.build +10 -1
- scipy/special/tests/test_basic.py +153 -20
- scipy/special/tests/test_boost_ufuncs.py +3 -0
- scipy/special/tests/test_cdflib.py +35 -11
- scipy/special/tests/test_gammainc.py +16 -0
- scipy/special/tests/test_hyp2f1.py +2 -2
- scipy/special/tests/test_log1mexp.py +85 -0
- scipy/special/tests/test_logsumexp.py +206 -64
- scipy/special/tests/test_mpmath.py +1 -0
- scipy/special/tests/test_nan_inputs.py +1 -1
- scipy/special/tests/test_orthogonal.py +17 -18
- scipy/special/tests/test_sf_error.py +3 -2
- scipy/special/tests/test_sph_harm.py +6 -7
- scipy/special/tests/test_support_alternative_backends.py +211 -76
- scipy/stats/__init__.py +4 -1
- scipy/stats/_ansari_swilk_statistics.cpython-312-darwin.so +0 -0
- scipy/stats/_axis_nan_policy.py +5 -12
- scipy/stats/_biasedurn.cpython-312-darwin.so +0 -0
- scipy/stats/_continued_fraction.py +387 -0
- scipy/stats/_continuous_distns.py +277 -310
- scipy/stats/_correlation.py +1 -1
- scipy/stats/_covariance.py +6 -3
- scipy/stats/_discrete_distns.py +39 -32
- scipy/stats/_distn_infrastructure.py +39 -12
- scipy/stats/_distribution_infrastructure.py +900 -238
- scipy/stats/_entropy.py +9 -10
- scipy/{_lib → stats}/_finite_differences.py +1 -1
- scipy/stats/_hypotests.py +83 -50
- scipy/stats/_kde.py +53 -49
- scipy/stats/_ksstats.py +1 -1
- scipy/stats/_levy_stable/__init__.py +7 -15
- scipy/stats/_levy_stable/levyst.cpython-312-darwin.so +0 -0
- scipy/stats/_morestats.py +118 -73
- scipy/stats/_mstats_basic.py +13 -17
- scipy/stats/_mstats_extras.py +8 -8
- scipy/stats/_multivariate.py +89 -113
- scipy/stats/_new_distributions.py +97 -20
- scipy/stats/_page_trend_test.py +12 -5
- scipy/stats/_probability_distribution.py +265 -43
- scipy/stats/_qmc.py +14 -9
- scipy/stats/_qmc_cy.cpython-312-darwin.so +0 -0
- scipy/stats/_qmvnt.py +16 -95
- scipy/stats/_qmvnt_cy.cpython-312-darwin.so +0 -0
- scipy/stats/_quantile.py +335 -0
- scipy/stats/_rcont/rcont.cpython-312-darwin.so +0 -0
- scipy/stats/_resampling.py +4 -29
- scipy/stats/_sampling.py +1 -1
- scipy/stats/_sobol.cpython-312-darwin.so +0 -0
- scipy/stats/_stats.cpython-312-darwin.so +0 -0
- scipy/stats/_stats_mstats_common.py +21 -2
- scipy/stats/_stats_py.py +550 -476
- scipy/stats/_stats_pythran.cpython-312-darwin.so +0 -0
- scipy/stats/_unuran/unuran_wrapper.cpython-312-darwin.so +0 -0
- scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
- scipy/stats/_variation.py +6 -8
- scipy/stats/_wilcoxon.py +13 -7
- scipy/stats/tests/common_tests.py +6 -4
- scipy/stats/tests/test_axis_nan_policy.py +62 -24
- scipy/stats/tests/test_continued_fraction.py +173 -0
- scipy/stats/tests/test_continuous.py +379 -60
- scipy/stats/tests/test_continuous_basic.py +18 -12
- scipy/stats/tests/test_discrete_basic.py +14 -8
- scipy/stats/tests/test_discrete_distns.py +16 -16
- scipy/stats/tests/test_distributions.py +95 -75
- scipy/stats/tests/test_entropy.py +40 -48
- scipy/stats/tests/test_fit.py +4 -3
- scipy/stats/tests/test_hypotests.py +153 -24
- scipy/stats/tests/test_kdeoth.py +109 -41
- scipy/stats/tests/test_marray.py +289 -0
- scipy/stats/tests/test_morestats.py +79 -47
- scipy/stats/tests/test_mstats_basic.py +3 -3
- scipy/stats/tests/test_multivariate.py +434 -83
- scipy/stats/tests/test_qmc.py +13 -10
- scipy/stats/tests/test_quantile.py +199 -0
- scipy/stats/tests/test_rank.py +119 -112
- scipy/stats/tests/test_resampling.py +47 -56
- scipy/stats/tests/test_sampling.py +9 -4
- scipy/stats/tests/test_stats.py +799 -939
- scipy/stats/tests/test_variation.py +8 -6
- scipy/version.py +2 -2
- {scipy-1.15.3.dist-info → scipy-1.16.0rc2.dist-info}/LICENSE.txt +4 -4
- {scipy-1.15.3.dist-info → scipy-1.16.0rc2.dist-info}/METADATA +11 -11
- {scipy-1.15.3.dist-info → scipy-1.16.0rc2.dist-info}/RECORD +560 -567
- scipy-1.16.0rc2.dist-info/WHEEL +6 -0
- scipy/_lib/array_api_extra/_funcs.py +0 -484
- scipy/_lib/array_api_extra/_typing.py +0 -8
- scipy/interpolate/_bspl.cpython-312-darwin.so +0 -0
- scipy/optimize/_cobyla.cpython-312-darwin.so +0 -0
- scipy/optimize/_cython_nnls.cpython-312-darwin.so +0 -0
- scipy/optimize/_slsqp.cpython-312-darwin.so +0 -0
- scipy/spatial/qhull_src/COPYING.txt +0 -38
- scipy/special/libsf_error_state.dylib +0 -0
- scipy/special/tests/test_log_softmax.py +0 -109
- scipy/special/tests/test_xsf_cuda.py +0 -114
- scipy/special/xsf/binom.h +0 -89
- scipy/special/xsf/cdflib.h +0 -100
- scipy/special/xsf/cephes/airy.h +0 -307
- scipy/special/xsf/cephes/besselpoly.h +0 -51
- scipy/special/xsf/cephes/beta.h +0 -257
- scipy/special/xsf/cephes/cbrt.h +0 -131
- scipy/special/xsf/cephes/chbevl.h +0 -85
- scipy/special/xsf/cephes/chdtr.h +0 -193
- scipy/special/xsf/cephes/const.h +0 -87
- scipy/special/xsf/cephes/ellie.h +0 -293
- scipy/special/xsf/cephes/ellik.h +0 -251
- scipy/special/xsf/cephes/ellpe.h +0 -107
- scipy/special/xsf/cephes/ellpk.h +0 -117
- scipy/special/xsf/cephes/expn.h +0 -260
- scipy/special/xsf/cephes/gamma.h +0 -398
- scipy/special/xsf/cephes/hyp2f1.h +0 -596
- scipy/special/xsf/cephes/hyperg.h +0 -361
- scipy/special/xsf/cephes/i0.h +0 -149
- scipy/special/xsf/cephes/i1.h +0 -158
- scipy/special/xsf/cephes/igam.h +0 -421
- scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
- scipy/special/xsf/cephes/igami.h +0 -313
- scipy/special/xsf/cephes/j0.h +0 -225
- scipy/special/xsf/cephes/j1.h +0 -198
- scipy/special/xsf/cephes/jv.h +0 -715
- scipy/special/xsf/cephes/k0.h +0 -164
- scipy/special/xsf/cephes/k1.h +0 -163
- scipy/special/xsf/cephes/kn.h +0 -243
- scipy/special/xsf/cephes/lanczos.h +0 -112
- scipy/special/xsf/cephes/ndtr.h +0 -275
- scipy/special/xsf/cephes/poch.h +0 -85
- scipy/special/xsf/cephes/polevl.h +0 -167
- scipy/special/xsf/cephes/psi.h +0 -194
- scipy/special/xsf/cephes/rgamma.h +0 -111
- scipy/special/xsf/cephes/scipy_iv.h +0 -811
- scipy/special/xsf/cephes/shichi.h +0 -248
- scipy/special/xsf/cephes/sici.h +0 -224
- scipy/special/xsf/cephes/sindg.h +0 -221
- scipy/special/xsf/cephes/tandg.h +0 -139
- scipy/special/xsf/cephes/trig.h +0 -58
- scipy/special/xsf/cephes/unity.h +0 -186
- scipy/special/xsf/cephes/zeta.h +0 -172
- scipy/special/xsf/config.h +0 -304
- scipy/special/xsf/digamma.h +0 -205
- scipy/special/xsf/error.h +0 -57
- scipy/special/xsf/evalpoly.h +0 -47
- scipy/special/xsf/expint.h +0 -266
- scipy/special/xsf/hyp2f1.h +0 -694
- scipy/special/xsf/iv_ratio.h +0 -173
- scipy/special/xsf/lambertw.h +0 -150
- scipy/special/xsf/loggamma.h +0 -163
- scipy/special/xsf/sici.h +0 -200
- scipy/special/xsf/tools.h +0 -427
- scipy/special/xsf/trig.h +0 -164
- scipy/special/xsf/wright_bessel.h +0 -843
- scipy/special/xsf/zlog1.h +0 -35
- scipy/stats/_mvn.cpython-312-darwin.so +0 -0
- scipy-1.15.3.dist-info/WHEEL +0 -4
@@ -0,0 +1,74 @@
|
|
1
|
+
"""Acquire helpers from array-api-compat."""
|
2
|
+
# Allow packages that vendor both `array-api-extra` and
|
3
|
+
# `array-api-compat` to override the import location
|
4
|
+
|
5
|
+
# pylint: disable=duplicate-code
|
6
|
+
try:
|
7
|
+
from ...._array_api_compat_vendor import (
|
8
|
+
array_namespace,
|
9
|
+
device,
|
10
|
+
is_array_api_obj,
|
11
|
+
is_array_api_strict_namespace,
|
12
|
+
is_cupy_array,
|
13
|
+
is_cupy_namespace,
|
14
|
+
is_dask_array,
|
15
|
+
is_dask_namespace,
|
16
|
+
is_jax_array,
|
17
|
+
is_jax_namespace,
|
18
|
+
is_lazy_array,
|
19
|
+
is_numpy_array,
|
20
|
+
is_numpy_namespace,
|
21
|
+
is_pydata_sparse_array,
|
22
|
+
is_pydata_sparse_namespace,
|
23
|
+
is_torch_array,
|
24
|
+
is_torch_namespace,
|
25
|
+
is_writeable_array,
|
26
|
+
size,
|
27
|
+
to_device,
|
28
|
+
)
|
29
|
+
except ImportError:
|
30
|
+
from array_api_compat import (
|
31
|
+
array_namespace,
|
32
|
+
device,
|
33
|
+
is_array_api_obj,
|
34
|
+
is_array_api_strict_namespace,
|
35
|
+
is_cupy_array,
|
36
|
+
is_cupy_namespace,
|
37
|
+
is_dask_array,
|
38
|
+
is_dask_namespace,
|
39
|
+
is_jax_array,
|
40
|
+
is_jax_namespace,
|
41
|
+
is_lazy_array,
|
42
|
+
is_numpy_array,
|
43
|
+
is_numpy_namespace,
|
44
|
+
is_pydata_sparse_array,
|
45
|
+
is_pydata_sparse_namespace,
|
46
|
+
is_torch_array,
|
47
|
+
is_torch_namespace,
|
48
|
+
is_writeable_array,
|
49
|
+
size,
|
50
|
+
to_device,
|
51
|
+
)
|
52
|
+
|
53
|
+
__all__ = [
|
54
|
+
"array_namespace",
|
55
|
+
"device",
|
56
|
+
"is_array_api_obj",
|
57
|
+
"is_array_api_strict_namespace",
|
58
|
+
"is_cupy_array",
|
59
|
+
"is_cupy_namespace",
|
60
|
+
"is_dask_array",
|
61
|
+
"is_dask_namespace",
|
62
|
+
"is_jax_array",
|
63
|
+
"is_jax_namespace",
|
64
|
+
"is_lazy_array",
|
65
|
+
"is_numpy_array",
|
66
|
+
"is_numpy_namespace",
|
67
|
+
"is_pydata_sparse_array",
|
68
|
+
"is_pydata_sparse_namespace",
|
69
|
+
"is_torch_array",
|
70
|
+
"is_torch_namespace",
|
71
|
+
"is_writeable_array",
|
72
|
+
"size",
|
73
|
+
"to_device",
|
74
|
+
]
|
@@ -0,0 +1,45 @@
|
|
1
|
+
"""Static type stubs for `_compat.py`."""
|
2
|
+
|
3
|
+
# https://github.com/scikit-learn/scikit-learn/pull/27910#issuecomment-2568023972
|
4
|
+
from __future__ import annotations
|
5
|
+
|
6
|
+
from types import ModuleType
|
7
|
+
from typing import Any, TypeGuard
|
8
|
+
|
9
|
+
# TODO import from typing (requires Python >=3.13)
|
10
|
+
from typing_extensions import TypeIs
|
11
|
+
|
12
|
+
from ._typing import Array, Device
|
13
|
+
|
14
|
+
# pylint: disable=missing-class-docstring,unused-argument
|
15
|
+
|
16
|
+
def array_namespace(
|
17
|
+
*xs: Array | complex | None,
|
18
|
+
api_version: str | None = None,
|
19
|
+
use_compat: bool | None = None,
|
20
|
+
) -> ModuleType: ...
|
21
|
+
def device(x: Array, /) -> Device: ...
|
22
|
+
def is_array_api_obj(x: object, /) -> TypeIs[Array]: ...
|
23
|
+
def is_array_api_strict_namespace(xp: ModuleType, /) -> bool: ...
|
24
|
+
def is_cupy_namespace(xp: ModuleType, /) -> bool: ...
|
25
|
+
def is_dask_namespace(xp: ModuleType, /) -> bool: ...
|
26
|
+
def is_jax_namespace(xp: ModuleType, /) -> bool: ...
|
27
|
+
def is_numpy_namespace(xp: ModuleType, /) -> bool: ...
|
28
|
+
def is_pydata_sparse_namespace(xp: ModuleType, /) -> bool: ...
|
29
|
+
def is_torch_namespace(xp: ModuleType, /) -> bool: ...
|
30
|
+
def is_cupy_array(x: object, /) -> TypeGuard[Array]: ...
|
31
|
+
def is_dask_array(x: object, /) -> TypeGuard[Array]: ...
|
32
|
+
def is_jax_array(x: object, /) -> TypeGuard[Array]: ...
|
33
|
+
def is_numpy_array(x: object, /) -> TypeGuard[Array]: ...
|
34
|
+
def is_pydata_sparse_array(x: object, /) -> TypeGuard[Array]: ...
|
35
|
+
def is_torch_array(x: object, /) -> TypeGuard[Array]: ...
|
36
|
+
def is_lazy_array(x: object, /) -> TypeGuard[Array]: ...
|
37
|
+
def is_writeable_array(x: object, /) -> TypeGuard[Array]: ...
|
38
|
+
def size(x: Array, /) -> int | None: ...
|
39
|
+
def to_device( # type: ignore[explicit-any]
|
40
|
+
x: Array,
|
41
|
+
device: Device, # pylint: disable=redefined-outer-name
|
42
|
+
/,
|
43
|
+
*,
|
44
|
+
stream: int | Any | None = None,
|
45
|
+
) -> Array: ...
|
@@ -0,0 +1,559 @@
|
|
1
|
+
"""Helper functions used by `array_api_extra/_funcs.py`."""
|
2
|
+
|
3
|
+
from __future__ import annotations
|
4
|
+
|
5
|
+
import io
|
6
|
+
import math
|
7
|
+
import pickle
|
8
|
+
import types
|
9
|
+
from collections.abc import Callable, Generator, Iterable
|
10
|
+
from functools import wraps
|
11
|
+
from types import ModuleType
|
12
|
+
from typing import (
|
13
|
+
TYPE_CHECKING,
|
14
|
+
Any,
|
15
|
+
ClassVar,
|
16
|
+
Generic,
|
17
|
+
Literal,
|
18
|
+
ParamSpec,
|
19
|
+
TypeAlias,
|
20
|
+
TypeVar,
|
21
|
+
cast,
|
22
|
+
)
|
23
|
+
|
24
|
+
from . import _compat
|
25
|
+
from ._compat import (
|
26
|
+
array_namespace,
|
27
|
+
is_array_api_obj,
|
28
|
+
is_dask_namespace,
|
29
|
+
is_jax_namespace,
|
30
|
+
is_numpy_array,
|
31
|
+
is_pydata_sparse_namespace,
|
32
|
+
)
|
33
|
+
from ._typing import Array
|
34
|
+
|
35
|
+
if TYPE_CHECKING: # pragma: no cover
|
36
|
+
# TODO import from typing (requires Python >=3.12 and >=3.13)
|
37
|
+
from typing_extensions import TypeIs, override
|
38
|
+
else:
|
39
|
+
|
40
|
+
def override(func):
|
41
|
+
return func
|
42
|
+
|
43
|
+
|
44
|
+
P = ParamSpec("P")
|
45
|
+
T = TypeVar("T")
|
46
|
+
|
47
|
+
|
48
|
+
__all__ = [
|
49
|
+
"asarrays",
|
50
|
+
"capabilities",
|
51
|
+
"eager_shape",
|
52
|
+
"in1d",
|
53
|
+
"is_python_scalar",
|
54
|
+
"jax_autojit",
|
55
|
+
"mean",
|
56
|
+
"meta_namespace",
|
57
|
+
"pickle_flatten",
|
58
|
+
"pickle_unflatten",
|
59
|
+
]
|
60
|
+
|
61
|
+
|
62
|
+
def in1d(
|
63
|
+
x1: Array,
|
64
|
+
x2: Array,
|
65
|
+
/,
|
66
|
+
*,
|
67
|
+
assume_unique: bool = False,
|
68
|
+
invert: bool = False,
|
69
|
+
xp: ModuleType | None = None,
|
70
|
+
) -> Array: # numpydoc ignore=PR01,RT01
|
71
|
+
"""
|
72
|
+
Check whether each element of an array is also present in a second array.
|
73
|
+
|
74
|
+
Returns a boolean array the same length as `x1` that is True
|
75
|
+
where an element of `x1` is in `x2` and False otherwise.
|
76
|
+
|
77
|
+
This function has been adapted using the original implementation
|
78
|
+
present in numpy:
|
79
|
+
https://github.com/numpy/numpy/blob/v1.26.0/numpy/lib/arraysetops.py#L524-L758
|
80
|
+
"""
|
81
|
+
if xp is None:
|
82
|
+
xp = array_namespace(x1, x2)
|
83
|
+
|
84
|
+
x1_shape = eager_shape(x1)
|
85
|
+
x2_shape = eager_shape(x2)
|
86
|
+
|
87
|
+
# This code is run to make the code significantly faster
|
88
|
+
if x2_shape[0] < 10 * x1_shape[0] ** 0.145 and isinstance(x2, Iterable):
|
89
|
+
if invert:
|
90
|
+
mask = xp.ones(x1_shape[0], dtype=xp.bool, device=_compat.device(x1))
|
91
|
+
for a in x2:
|
92
|
+
mask &= x1 != a
|
93
|
+
else:
|
94
|
+
mask = xp.zeros(x1_shape[0], dtype=xp.bool, device=_compat.device(x1))
|
95
|
+
for a in x2:
|
96
|
+
mask |= x1 == a
|
97
|
+
return mask
|
98
|
+
|
99
|
+
rev_idx = xp.empty(0) # placeholder
|
100
|
+
if not assume_unique:
|
101
|
+
x1, rev_idx = xp.unique_inverse(x1)
|
102
|
+
x2 = xp.unique_values(x2)
|
103
|
+
|
104
|
+
ar = xp.concat((x1, x2))
|
105
|
+
device_ = _compat.device(ar)
|
106
|
+
# We need this to be a stable sort.
|
107
|
+
order = xp.argsort(ar, stable=True)
|
108
|
+
reverse_order = xp.argsort(order, stable=True)
|
109
|
+
sar = xp.take(ar, order, axis=0)
|
110
|
+
ar_size = _compat.size(sar)
|
111
|
+
assert ar_size is not None, "xp.unique*() on lazy backends raises"
|
112
|
+
if ar_size >= 1:
|
113
|
+
bool_ar = sar[1:] != sar[:-1] if invert else sar[1:] == sar[:-1]
|
114
|
+
else:
|
115
|
+
bool_ar = xp.asarray([False]) if invert else xp.asarray([True])
|
116
|
+
flag = xp.concat((bool_ar, xp.asarray([invert], device=device_)))
|
117
|
+
ret = xp.take(flag, reverse_order, axis=0)
|
118
|
+
|
119
|
+
if assume_unique:
|
120
|
+
return ret[: x1.shape[0]]
|
121
|
+
return xp.take(ret, rev_idx, axis=0)
|
122
|
+
|
123
|
+
|
124
|
+
def mean(
|
125
|
+
x: Array,
|
126
|
+
/,
|
127
|
+
*,
|
128
|
+
axis: int | tuple[int, ...] | None = None,
|
129
|
+
keepdims: bool = False,
|
130
|
+
xp: ModuleType | None = None,
|
131
|
+
) -> Array: # numpydoc ignore=PR01,RT01
|
132
|
+
"""
|
133
|
+
Complex mean, https://github.com/data-apis/array-api/issues/846.
|
134
|
+
"""
|
135
|
+
if xp is None:
|
136
|
+
xp = array_namespace(x)
|
137
|
+
|
138
|
+
if xp.isdtype(x.dtype, "complex floating"):
|
139
|
+
x_real = xp.real(x)
|
140
|
+
x_imag = xp.imag(x)
|
141
|
+
mean_real = xp.mean(x_real, axis=axis, keepdims=keepdims)
|
142
|
+
mean_imag = xp.mean(x_imag, axis=axis, keepdims=keepdims)
|
143
|
+
return mean_real + (mean_imag * xp.asarray(1j))
|
144
|
+
return xp.mean(x, axis=axis, keepdims=keepdims)
|
145
|
+
|
146
|
+
|
147
|
+
def is_python_scalar(x: object) -> TypeIs[complex]: # numpydoc ignore=PR01,RT01
|
148
|
+
"""Return True if `x` is a Python scalar, False otherwise."""
|
149
|
+
# isinstance(x, float) returns True for np.float64
|
150
|
+
# isinstance(x, complex) returns True for np.complex128
|
151
|
+
# bool is a subclass of int
|
152
|
+
return isinstance(x, int | float | complex) and not is_numpy_array(x)
|
153
|
+
|
154
|
+
|
155
|
+
def asarrays(
|
156
|
+
a: Array | complex,
|
157
|
+
b: Array | complex,
|
158
|
+
xp: ModuleType,
|
159
|
+
) -> tuple[Array, Array]:
|
160
|
+
"""
|
161
|
+
Ensure both `a` and `b` are arrays.
|
162
|
+
|
163
|
+
If `b` is a python scalar, it is converted to the same dtype as `a`, and vice versa.
|
164
|
+
|
165
|
+
Behavior is not specified when mixing a Python ``float`` and an array with an
|
166
|
+
integer data type; this may give ``float32``, ``float64``, or raise an exception.
|
167
|
+
Behavior is implementation-specific.
|
168
|
+
|
169
|
+
Similarly, behavior is not specified when mixing a Python ``complex`` and an array
|
170
|
+
with a real-valued data type; this may give ``complex64``, ``complex128``, or raise
|
171
|
+
an exception. Behavior is implementation-specific.
|
172
|
+
|
173
|
+
Parameters
|
174
|
+
----------
|
175
|
+
a, b : Array | int | float | complex | bool
|
176
|
+
Input arrays or scalars. At least one must be an array.
|
177
|
+
xp : array_namespace, optional
|
178
|
+
The standard-compatible namespace for `x`. Default: infer.
|
179
|
+
|
180
|
+
Returns
|
181
|
+
-------
|
182
|
+
Array, Array
|
183
|
+
The input arrays, possibly converted to arrays if they were scalars.
|
184
|
+
|
185
|
+
See Also
|
186
|
+
--------
|
187
|
+
mixing-arrays-with-python-scalars : Array API specification for the behavior.
|
188
|
+
"""
|
189
|
+
a_scalar = is_python_scalar(a)
|
190
|
+
b_scalar = is_python_scalar(b)
|
191
|
+
if not a_scalar and not b_scalar:
|
192
|
+
# This includes misc. malformed input e.g. str
|
193
|
+
return a, b # type: ignore[return-value]
|
194
|
+
|
195
|
+
swap = False
|
196
|
+
if a_scalar:
|
197
|
+
swap = True
|
198
|
+
b, a = a, b
|
199
|
+
|
200
|
+
if is_array_api_obj(a):
|
201
|
+
# a is an Array API object
|
202
|
+
# b is a int | float | complex | bool
|
203
|
+
xa = a
|
204
|
+
|
205
|
+
# https://data-apis.org/array-api/draft/API_specification/type_promotion.html#mixing-arrays-with-python-scalars
|
206
|
+
same_dtype = {
|
207
|
+
bool: "bool",
|
208
|
+
int: ("integral", "real floating", "complex floating"),
|
209
|
+
float: ("real floating", "complex floating"),
|
210
|
+
complex: "complex floating",
|
211
|
+
}
|
212
|
+
kind = same_dtype[type(cast(complex, b))] # type: ignore[index]
|
213
|
+
if xp.isdtype(a.dtype, kind):
|
214
|
+
xb = xp.asarray(b, dtype=a.dtype)
|
215
|
+
else:
|
216
|
+
# Undefined behaviour. Let the function deal with it, if it can.
|
217
|
+
xb = xp.asarray(b)
|
218
|
+
|
219
|
+
else:
|
220
|
+
# Neither a nor b are Array API objects.
|
221
|
+
# Note: we can only reach this point when one explicitly passes
|
222
|
+
# xp=xp to the calling function; otherwise we fail earlier on
|
223
|
+
# array_namespace(a, b).
|
224
|
+
xa, xb = xp.asarray(a), xp.asarray(b)
|
225
|
+
|
226
|
+
return (xb, xa) if swap else (xa, xb)
|
227
|
+
|
228
|
+
|
229
|
+
def ndindex(*x: int) -> Generator[tuple[int, ...]]:
|
230
|
+
"""
|
231
|
+
Generate all N-dimensional indices for a given array shape.
|
232
|
+
|
233
|
+
Given the shape of an array, an ndindex instance iterates over the N-dimensional
|
234
|
+
index of the array. At each iteration a tuple of indices is returned, the last
|
235
|
+
dimension is iterated over first.
|
236
|
+
|
237
|
+
This has an identical API to numpy.ndindex.
|
238
|
+
|
239
|
+
Parameters
|
240
|
+
----------
|
241
|
+
*x : int
|
242
|
+
The shape of the array.
|
243
|
+
"""
|
244
|
+
if not x:
|
245
|
+
yield ()
|
246
|
+
return
|
247
|
+
for i in ndindex(*x[:-1]):
|
248
|
+
for j in range(x[-1]):
|
249
|
+
yield *i, j
|
250
|
+
|
251
|
+
|
252
|
+
def eager_shape(x: Array, /) -> tuple[int, ...]:
|
253
|
+
"""
|
254
|
+
Return shape of an array. Raise if shape is not fully defined.
|
255
|
+
|
256
|
+
Parameters
|
257
|
+
----------
|
258
|
+
x : Array
|
259
|
+
Input array.
|
260
|
+
|
261
|
+
Returns
|
262
|
+
-------
|
263
|
+
tuple[int, ...]
|
264
|
+
Shape of the array.
|
265
|
+
"""
|
266
|
+
shape = x.shape
|
267
|
+
# Dask arrays uses non-standard NaN instead of None
|
268
|
+
if any(s is None or math.isnan(s) for s in shape):
|
269
|
+
msg = "Unsupported lazy shape"
|
270
|
+
raise TypeError(msg)
|
271
|
+
return cast(tuple[int, ...], shape)
|
272
|
+
|
273
|
+
|
274
|
+
def meta_namespace(
|
275
|
+
*arrays: Array | complex | None, xp: ModuleType | None = None
|
276
|
+
) -> ModuleType:
|
277
|
+
"""
|
278
|
+
Get the namespace of Dask chunks.
|
279
|
+
|
280
|
+
On all other backends, just return the namespace of the arrays.
|
281
|
+
|
282
|
+
Parameters
|
283
|
+
----------
|
284
|
+
*arrays : Array | int | float | complex | bool | None
|
285
|
+
Input arrays.
|
286
|
+
xp : array_namespace, optional
|
287
|
+
The standard-compatible namespace for the input arrays. Default: infer.
|
288
|
+
|
289
|
+
Returns
|
290
|
+
-------
|
291
|
+
array_namespace
|
292
|
+
If xp is Dask, the namespace of the Dask chunks;
|
293
|
+
otherwise, the namespace of the arrays.
|
294
|
+
"""
|
295
|
+
xp = array_namespace(*arrays) if xp is None else xp
|
296
|
+
if not is_dask_namespace(xp):
|
297
|
+
return xp
|
298
|
+
# Quietly skip scalars and None's
|
299
|
+
metas = [cast(Array | None, getattr(a, "_meta", None)) for a in arrays]
|
300
|
+
return array_namespace(*metas)
|
301
|
+
|
302
|
+
|
303
|
+
def capabilities(xp: ModuleType) -> dict[str, int]:
|
304
|
+
"""
|
305
|
+
Return patched ``xp.__array_namespace_info__().capabilities()``.
|
306
|
+
|
307
|
+
TODO this helper should be eventually removed once all the special cases
|
308
|
+
it handles are fixed in the respective backends.
|
309
|
+
|
310
|
+
Parameters
|
311
|
+
----------
|
312
|
+
xp : array_namespace
|
313
|
+
The standard-compatible namespace.
|
314
|
+
|
315
|
+
Returns
|
316
|
+
-------
|
317
|
+
dict
|
318
|
+
Capabilities of the namespace.
|
319
|
+
"""
|
320
|
+
if is_pydata_sparse_namespace(xp):
|
321
|
+
# No __array_namespace_info__(); no indexing by sparse arrays
|
322
|
+
return {"boolean indexing": False, "data-dependent shapes": True}
|
323
|
+
out = xp.__array_namespace_info__().capabilities()
|
324
|
+
if is_jax_namespace(xp) and out["boolean indexing"]:
|
325
|
+
# FIXME https://github.com/jax-ml/jax/issues/27418
|
326
|
+
# Fixed in jax >=0.6.0
|
327
|
+
out = out.copy()
|
328
|
+
out["boolean indexing"] = False
|
329
|
+
return out
|
330
|
+
|
331
|
+
|
332
|
+
_BASIC_PICKLED_TYPES = frozenset((
|
333
|
+
bool, int, float, complex, str, bytes, bytearray,
|
334
|
+
list, tuple, dict, set, frozenset, range, slice,
|
335
|
+
types.NoneType, types.EllipsisType,
|
336
|
+
)) # fmt: skip
|
337
|
+
_BASIC_REST_TYPES = frozenset((
|
338
|
+
type, types.BuiltinFunctionType, types.FunctionType, types.ModuleType
|
339
|
+
)) # fmt: skip
|
340
|
+
|
341
|
+
FlattenRest: TypeAlias = tuple[object, ...]
|
342
|
+
|
343
|
+
|
344
|
+
def pickle_flatten(
|
345
|
+
obj: object, cls: type[T] | tuple[type[T], ...]
|
346
|
+
) -> tuple[list[T], FlattenRest]:
|
347
|
+
"""
|
348
|
+
Use the pickle machinery to extract objects out of an arbitrary container.
|
349
|
+
|
350
|
+
Unlike regular ``pickle.dumps``, this function always succeeds.
|
351
|
+
|
352
|
+
Parameters
|
353
|
+
----------
|
354
|
+
obj : object
|
355
|
+
The object to pickle.
|
356
|
+
cls : type | tuple[type, ...]
|
357
|
+
One or multiple classes to extract from the object.
|
358
|
+
The instances of these classes inside ``obj`` will not be pickled.
|
359
|
+
|
360
|
+
Returns
|
361
|
+
-------
|
362
|
+
instances : list[cls]
|
363
|
+
All instances of ``cls`` found inside ``obj`` (not pickled).
|
364
|
+
rest
|
365
|
+
Opaque object containing the pickled bytes plus all other objects where
|
366
|
+
``__reduce__`` / ``__reduce_ex__`` is either not implemented or raised.
|
367
|
+
These are unpickleable objects, types, modules, and functions.
|
368
|
+
|
369
|
+
This object is *typically* hashable save for fairly exotic objects
|
370
|
+
that are neither pickleable nor hashable.
|
371
|
+
|
372
|
+
This object is pickleable if everything except ``instances`` was pickleable
|
373
|
+
in the input object.
|
374
|
+
|
375
|
+
See Also
|
376
|
+
--------
|
377
|
+
pickle_unflatten : Reverse function.
|
378
|
+
|
379
|
+
Examples
|
380
|
+
--------
|
381
|
+
>>> class A:
|
382
|
+
... def __repr__(self):
|
383
|
+
... return "<A>"
|
384
|
+
>>> class NS:
|
385
|
+
... def __repr__(self):
|
386
|
+
... return "<NS>"
|
387
|
+
... def __reduce__(self):
|
388
|
+
... assert False, "not serializable"
|
389
|
+
>>> obj = {1: A(), 2: [A(), NS(), A()]}
|
390
|
+
>>> instances, rest = pickle_flatten(obj, A)
|
391
|
+
>>> instances
|
392
|
+
[<A>, <A>, <A>]
|
393
|
+
>>> pickle_unflatten(instances, rest)
|
394
|
+
{1: <A>, 2: [<A>, <NS>, <A>]}
|
395
|
+
|
396
|
+
This can be also used to swap inner objects; the only constraint is that
|
397
|
+
the number of objects in and out must be the same:
|
398
|
+
|
399
|
+
>>> pickle_unflatten(["foo", "bar", "baz"], rest)
|
400
|
+
{1: "foo", 2: ["bar", <NS>, "baz"]}
|
401
|
+
"""
|
402
|
+
instances: list[T] = []
|
403
|
+
rest: list[object] = []
|
404
|
+
|
405
|
+
class Pickler(pickle.Pickler): # numpydoc ignore=GL08
|
406
|
+
"""
|
407
|
+
Use the `pickle.Pickler.persistent_id` hook to extract objects.
|
408
|
+
"""
|
409
|
+
|
410
|
+
@override
|
411
|
+
def persistent_id(self, obj: object) -> Literal[0, 1, None]: # pyright: ignore[reportIncompatibleMethodOverride] # numpydoc ignore=GL08
|
412
|
+
if isinstance(obj, cls):
|
413
|
+
instances.append(obj) # type: ignore[arg-type]
|
414
|
+
return 0
|
415
|
+
|
416
|
+
typ_ = type(obj)
|
417
|
+
if typ_ in _BASIC_PICKLED_TYPES: # No subclasses!
|
418
|
+
# If obj is a collection, recursively descend inside it
|
419
|
+
return None
|
420
|
+
if typ_ in _BASIC_REST_TYPES:
|
421
|
+
rest.append(obj)
|
422
|
+
return 1
|
423
|
+
|
424
|
+
try:
|
425
|
+
# Note: a class that defines __slots__ without defining __getstate__
|
426
|
+
# cannot be pickled with __reduce__(), but can with __reduce_ex__(5)
|
427
|
+
_ = obj.__reduce_ex__(pickle.HIGHEST_PROTOCOL)
|
428
|
+
except Exception: # pylint: disable=broad-exception-caught
|
429
|
+
rest.append(obj)
|
430
|
+
return 1
|
431
|
+
|
432
|
+
# Object can be pickled. Let the Pickler recursively descend inside it.
|
433
|
+
return None
|
434
|
+
|
435
|
+
f = io.BytesIO()
|
436
|
+
p = Pickler(f, protocol=pickle.HIGHEST_PROTOCOL)
|
437
|
+
p.dump(obj)
|
438
|
+
return instances, (f.getvalue(), *rest)
|
439
|
+
|
440
|
+
|
441
|
+
def pickle_unflatten(instances: Iterable[object], rest: FlattenRest) -> Any: # type: ignore[explicit-any]
|
442
|
+
"""
|
443
|
+
Reverse of ``pickle_flatten``.
|
444
|
+
|
445
|
+
Parameters
|
446
|
+
----------
|
447
|
+
instances : Iterable
|
448
|
+
Inner objects to be reinserted into the flattened container.
|
449
|
+
rest : FlattenRest
|
450
|
+
Extra bits, as returned by ``pickle_flatten``.
|
451
|
+
|
452
|
+
Returns
|
453
|
+
-------
|
454
|
+
object
|
455
|
+
The outer object originally passed to ``pickle_flatten`` after a
|
456
|
+
pickle->unpickle round-trip.
|
457
|
+
|
458
|
+
See Also
|
459
|
+
--------
|
460
|
+
pickle_flatten : Serializing function.
|
461
|
+
pickle.loads : Standard unpickle function.
|
462
|
+
|
463
|
+
Notes
|
464
|
+
-----
|
465
|
+
The `instances` iterable must yield at least the same number of elements as the ones
|
466
|
+
returned by ``pickle_without``, but the elements do not need to be the same objects
|
467
|
+
or even the same types of objects. Excess elements, if any, will be left untouched.
|
468
|
+
"""
|
469
|
+
iters = iter(instances), iter(rest)
|
470
|
+
pik = cast(bytes, next(iters[1]))
|
471
|
+
|
472
|
+
class Unpickler(pickle.Unpickler): # numpydoc ignore=GL08
|
473
|
+
"""Mirror of the overridden Pickler in pickle_flatten."""
|
474
|
+
|
475
|
+
@override
|
476
|
+
def persistent_load(self, pid: Literal[0, 1]) -> object: # pyright: ignore[reportIncompatibleMethodOverride] # numpydoc ignore=GL08
|
477
|
+
try:
|
478
|
+
return next(iters[pid])
|
479
|
+
except StopIteration as e:
|
480
|
+
msg = "Not enough objects to unpickle"
|
481
|
+
raise ValueError(msg) from e
|
482
|
+
|
483
|
+
f = io.BytesIO(pik)
|
484
|
+
return Unpickler(f).load()
|
485
|
+
|
486
|
+
|
487
|
+
class _AutoJITWrapper(Generic[T]): # numpydoc ignore=PR01
|
488
|
+
"""
|
489
|
+
Helper of :func:`jax_autojit`.
|
490
|
+
|
491
|
+
Wrap arbitrary inputs and outputs of the jitted function and
|
492
|
+
convert them to/from PyTrees.
|
493
|
+
"""
|
494
|
+
|
495
|
+
obj: T
|
496
|
+
_registered: ClassVar[bool] = False
|
497
|
+
__slots__: tuple[str, ...] = ("obj",)
|
498
|
+
|
499
|
+
def __init__(self, obj: T) -> None: # numpydoc ignore=GL08
|
500
|
+
self._register()
|
501
|
+
self.obj = obj
|
502
|
+
|
503
|
+
@classmethod
|
504
|
+
def _register(cls): # numpydoc ignore=SS06
|
505
|
+
"""
|
506
|
+
Register upon first use instead of at import time, to avoid
|
507
|
+
globally importing JAX.
|
508
|
+
"""
|
509
|
+
if not cls._registered:
|
510
|
+
import jax
|
511
|
+
|
512
|
+
jax.tree_util.register_pytree_node(
|
513
|
+
cls,
|
514
|
+
lambda obj: pickle_flatten(obj, jax.Array), # pyright: ignore[reportUnknownArgumentType]
|
515
|
+
lambda aux_data, children: pickle_unflatten(children, aux_data), # pyright: ignore[reportUnknownArgumentType]
|
516
|
+
)
|
517
|
+
cls._registered = True
|
518
|
+
|
519
|
+
|
520
|
+
def jax_autojit(
|
521
|
+
func: Callable[P, T],
|
522
|
+
) -> Callable[P, T]: # numpydoc ignore=PR01,RT01,SS03
|
523
|
+
"""
|
524
|
+
Wrap `func` with ``jax.jit``, with the following differences:
|
525
|
+
|
526
|
+
- Python scalar arguments and return values are not automatically converted to
|
527
|
+
``jax.Array`` objects.
|
528
|
+
- All non-array arguments are automatically treated as static.
|
529
|
+
Unlike ``jax.jit``, static arguments must be either hashable or serializable with
|
530
|
+
``pickle``.
|
531
|
+
- Unlike ``jax.jit``, non-array arguments and return values are not limited to
|
532
|
+
tuple/list/dict, but can be any object serializable with ``pickle``.
|
533
|
+
- Automatically descend into non-array arguments and find ``jax.Array`` objects
|
534
|
+
inside them, then rebuild the arguments when entering `func`, swapping the JAX
|
535
|
+
concrete arrays with tracer objects.
|
536
|
+
- Automatically descend into non-array return values and find ``jax.Array`` objects
|
537
|
+
inside them, then rebuild them downstream of exiting the JIT, swapping the JAX
|
538
|
+
tracer objects with concrete arrays.
|
539
|
+
|
540
|
+
See Also
|
541
|
+
--------
|
542
|
+
jax.jit : JAX JIT compilation function.
|
543
|
+
"""
|
544
|
+
import jax
|
545
|
+
|
546
|
+
@jax.jit # type: ignore[misc] # pyright: ignore[reportUntypedFunctionDecorator]
|
547
|
+
def inner( # type: ignore[decorated-any,explicit-any] # numpydoc ignore=GL08
|
548
|
+
wargs: _AutoJITWrapper[Any],
|
549
|
+
) -> _AutoJITWrapper[T]:
|
550
|
+
args, kwargs = wargs.obj
|
551
|
+
res = func(*args, **kwargs) # pyright: ignore[reportCallIssue]
|
552
|
+
return _AutoJITWrapper(res)
|
553
|
+
|
554
|
+
@wraps(func)
|
555
|
+
def outer(*args: P.args, **kwargs: P.kwargs) -> T: # numpydoc ignore=GL08
|
556
|
+
wargs = _AutoJITWrapper((args, kwargs))
|
557
|
+
return inner(wargs).obj
|
558
|
+
|
559
|
+
return outer
|