scipy 1.15.2__cp312-cp312-musllinux_1_2_aarch64.whl → 1.16.0__cp312-cp312-musllinux_1_2_aarch64.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.
Files changed (651) hide show
  1. scipy/__config__.py +13 -13
  2. scipy/__init__.py +3 -6
  3. scipy/_cyutility.cpython-312-aarch64-linux-musl.so +0 -0
  4. scipy/_lib/_array_api.py +497 -161
  5. scipy/_lib/_array_api_compat_vendor.py +9 -0
  6. scipy/_lib/_bunch.py +4 -0
  7. scipy/_lib/_ccallback_c.cpython-312-aarch64-linux-musl.so +0 -0
  8. scipy/_lib/_docscrape.py +1 -1
  9. scipy/_lib/_elementwise_iterative_method.py +15 -26
  10. scipy/_lib/_fpumode.cpython-312-aarch64-linux-musl.so +0 -0
  11. scipy/_lib/_sparse.py +41 -0
  12. scipy/_lib/_test_ccallback.cpython-312-aarch64-linux-musl.so +0 -0
  13. scipy/_lib/_test_deprecation_call.cpython-312-aarch64-linux-musl.so +0 -0
  14. scipy/_lib/_test_deprecation_def.cpython-312-aarch64-linux-musl.so +0 -0
  15. scipy/_lib/_testutils.py +6 -2
  16. scipy/_lib/_uarray/_uarray.cpython-312-aarch64-linux-musl.so +0 -0
  17. scipy/_lib/_util.py +222 -125
  18. scipy/_lib/array_api_compat/__init__.py +4 -4
  19. scipy/_lib/array_api_compat/_internal.py +19 -6
  20. scipy/_lib/array_api_compat/common/__init__.py +1 -1
  21. scipy/_lib/array_api_compat/common/_aliases.py +365 -193
  22. scipy/_lib/array_api_compat/common/_fft.py +94 -64
  23. scipy/_lib/array_api_compat/common/_helpers.py +413 -180
  24. scipy/_lib/array_api_compat/common/_linalg.py +116 -40
  25. scipy/_lib/array_api_compat/common/_typing.py +179 -10
  26. scipy/_lib/array_api_compat/cupy/__init__.py +1 -4
  27. scipy/_lib/array_api_compat/cupy/_aliases.py +61 -41
  28. scipy/_lib/array_api_compat/cupy/_info.py +16 -6
  29. scipy/_lib/array_api_compat/cupy/_typing.py +24 -39
  30. scipy/_lib/array_api_compat/dask/array/__init__.py +6 -3
  31. scipy/_lib/array_api_compat/dask/array/_aliases.py +267 -108
  32. scipy/_lib/array_api_compat/dask/array/_info.py +105 -34
  33. scipy/_lib/array_api_compat/dask/array/fft.py +5 -8
  34. scipy/_lib/array_api_compat/dask/array/linalg.py +21 -22
  35. scipy/_lib/array_api_compat/numpy/__init__.py +13 -15
  36. scipy/_lib/array_api_compat/numpy/_aliases.py +98 -49
  37. scipy/_lib/array_api_compat/numpy/_info.py +36 -16
  38. scipy/_lib/array_api_compat/numpy/_typing.py +27 -43
  39. scipy/_lib/array_api_compat/numpy/fft.py +11 -5
  40. scipy/_lib/array_api_compat/numpy/linalg.py +75 -22
  41. scipy/_lib/array_api_compat/torch/__init__.py +3 -5
  42. scipy/_lib/array_api_compat/torch/_aliases.py +262 -159
  43. scipy/_lib/array_api_compat/torch/_info.py +27 -16
  44. scipy/_lib/array_api_compat/torch/_typing.py +3 -0
  45. scipy/_lib/array_api_compat/torch/fft.py +17 -18
  46. scipy/_lib/array_api_compat/torch/linalg.py +16 -16
  47. scipy/_lib/array_api_extra/__init__.py +26 -3
  48. scipy/_lib/array_api_extra/_delegation.py +171 -0
  49. scipy/_lib/array_api_extra/_lib/__init__.py +1 -0
  50. scipy/_lib/array_api_extra/_lib/_at.py +463 -0
  51. scipy/_lib/array_api_extra/_lib/_backends.py +46 -0
  52. scipy/_lib/array_api_extra/_lib/_funcs.py +937 -0
  53. scipy/_lib/array_api_extra/_lib/_lazy.py +357 -0
  54. scipy/_lib/array_api_extra/_lib/_testing.py +278 -0
  55. scipy/_lib/array_api_extra/_lib/_utils/__init__.py +1 -0
  56. scipy/_lib/array_api_extra/_lib/_utils/_compat.py +74 -0
  57. scipy/_lib/array_api_extra/_lib/_utils/_compat.pyi +45 -0
  58. scipy/_lib/array_api_extra/_lib/_utils/_helpers.py +559 -0
  59. scipy/_lib/array_api_extra/_lib/_utils/_typing.py +10 -0
  60. scipy/_lib/array_api_extra/_lib/_utils/_typing.pyi +105 -0
  61. scipy/_lib/array_api_extra/testing.py +359 -0
  62. scipy/_lib/decorator.py +2 -2
  63. scipy/_lib/doccer.py +1 -7
  64. scipy/_lib/messagestream.cpython-312-aarch64-linux-musl.so +0 -0
  65. scipy/_lib/pyprima/__init__.py +212 -0
  66. scipy/_lib/pyprima/cobyla/__init__.py +0 -0
  67. scipy/_lib/pyprima/cobyla/cobyla.py +559 -0
  68. scipy/_lib/pyprima/cobyla/cobylb.py +714 -0
  69. scipy/_lib/pyprima/cobyla/geometry.py +226 -0
  70. scipy/_lib/pyprima/cobyla/initialize.py +215 -0
  71. scipy/_lib/pyprima/cobyla/trustregion.py +492 -0
  72. scipy/_lib/pyprima/cobyla/update.py +289 -0
  73. scipy/_lib/pyprima/common/__init__.py +0 -0
  74. scipy/_lib/pyprima/common/_bounds.py +34 -0
  75. scipy/_lib/pyprima/common/_linear_constraints.py +46 -0
  76. scipy/_lib/pyprima/common/_nonlinear_constraints.py +54 -0
  77. scipy/_lib/pyprima/common/_project.py +173 -0
  78. scipy/_lib/pyprima/common/checkbreak.py +93 -0
  79. scipy/_lib/pyprima/common/consts.py +47 -0
  80. scipy/_lib/pyprima/common/evaluate.py +99 -0
  81. scipy/_lib/pyprima/common/history.py +38 -0
  82. scipy/_lib/pyprima/common/infos.py +30 -0
  83. scipy/_lib/pyprima/common/linalg.py +435 -0
  84. scipy/_lib/pyprima/common/message.py +290 -0
  85. scipy/_lib/pyprima/common/powalg.py +131 -0
  86. scipy/_lib/pyprima/common/preproc.py +277 -0
  87. scipy/_lib/pyprima/common/present.py +5 -0
  88. scipy/_lib/pyprima/common/ratio.py +54 -0
  89. scipy/_lib/pyprima/common/redrho.py +47 -0
  90. scipy/_lib/pyprima/common/selectx.py +296 -0
  91. scipy/_lib/tests/test__util.py +105 -121
  92. scipy/_lib/tests/test_array_api.py +169 -34
  93. scipy/_lib/tests/test_bunch.py +7 -0
  94. scipy/_lib/tests/test_ccallback.py +2 -10
  95. scipy/_lib/tests/test_public_api.py +13 -0
  96. scipy/cluster/_hierarchy.cpython-312-aarch64-linux-musl.so +0 -0
  97. scipy/cluster/_optimal_leaf_ordering.cpython-312-aarch64-linux-musl.so +0 -0
  98. scipy/cluster/_vq.cpython-312-aarch64-linux-musl.so +0 -0
  99. scipy/cluster/hierarchy.py +393 -223
  100. scipy/cluster/tests/test_hierarchy.py +273 -335
  101. scipy/cluster/tests/test_vq.py +45 -61
  102. scipy/cluster/vq.py +39 -35
  103. scipy/conftest.py +282 -151
  104. scipy/constants/_constants.py +4 -1
  105. scipy/constants/tests/test_codata.py +2 -2
  106. scipy/constants/tests/test_constants.py +11 -18
  107. scipy/datasets/_download_all.py +15 -1
  108. scipy/datasets/_fetchers.py +7 -1
  109. scipy/datasets/_utils.py +1 -1
  110. scipy/differentiate/_differentiate.py +25 -25
  111. scipy/differentiate/tests/test_differentiate.py +24 -25
  112. scipy/fft/_basic.py +20 -0
  113. scipy/fft/_helper.py +3 -34
  114. scipy/fft/_pocketfft/helper.py +29 -1
  115. scipy/fft/_pocketfft/pypocketfft.cpython-312-aarch64-linux-musl.so +0 -0
  116. scipy/fft/_pocketfft/tests/test_basic.py +2 -4
  117. scipy/fft/_pocketfft/tests/test_real_transforms.py +4 -4
  118. scipy/fft/_realtransforms.py +13 -0
  119. scipy/fft/tests/test_basic.py +27 -25
  120. scipy/fft/tests/test_fftlog.py +16 -7
  121. scipy/fft/tests/test_helper.py +18 -34
  122. scipy/fft/tests/test_real_transforms.py +8 -10
  123. scipy/fftpack/convolve.cpython-312-aarch64-linux-musl.so +0 -0
  124. scipy/fftpack/tests/test_basic.py +2 -4
  125. scipy/fftpack/tests/test_real_transforms.py +8 -9
  126. scipy/integrate/_bvp.py +9 -3
  127. scipy/integrate/_cubature.py +3 -2
  128. scipy/integrate/_dop.cpython-312-aarch64-linux-musl.so +0 -0
  129. scipy/integrate/_ivp/common.py +3 -3
  130. scipy/integrate/_ivp/ivp.py +9 -2
  131. scipy/integrate/_ivp/tests/test_ivp.py +19 -0
  132. scipy/integrate/_lsoda.cpython-312-aarch64-linux-musl.so +0 -0
  133. scipy/integrate/_ode.py +9 -2
  134. scipy/integrate/_odepack.cpython-312-aarch64-linux-musl.so +0 -0
  135. scipy/integrate/_quad_vec.py +21 -29
  136. scipy/integrate/_quadpack.cpython-312-aarch64-linux-musl.so +0 -0
  137. scipy/integrate/_quadpack_py.py +11 -7
  138. scipy/integrate/_quadrature.py +3 -3
  139. scipy/integrate/_rules/_base.py +2 -2
  140. scipy/integrate/_tanhsinh.py +57 -54
  141. scipy/integrate/_test_multivariate.cpython-312-aarch64-linux-musl.so +0 -0
  142. scipy/integrate/_test_odeint_banded.cpython-312-aarch64-linux-musl.so +0 -0
  143. scipy/integrate/_vode.cpython-312-aarch64-linux-musl.so +0 -0
  144. scipy/integrate/tests/test__quad_vec.py +0 -6
  145. scipy/integrate/tests/test_banded_ode_solvers.py +85 -0
  146. scipy/integrate/tests/test_cubature.py +21 -35
  147. scipy/integrate/tests/test_quadrature.py +6 -8
  148. scipy/integrate/tests/test_tanhsinh.py +61 -43
  149. scipy/interpolate/__init__.py +70 -58
  150. scipy/interpolate/_bary_rational.py +22 -22
  151. scipy/interpolate/_bsplines.py +119 -66
  152. scipy/interpolate/_cubic.py +65 -50
  153. scipy/interpolate/_dfitpack.cpython-312-aarch64-linux-musl.so +0 -0
  154. scipy/interpolate/_dierckx.cpython-312-aarch64-linux-musl.so +0 -0
  155. scipy/interpolate/_fitpack.cpython-312-aarch64-linux-musl.so +0 -0
  156. scipy/interpolate/_fitpack2.py +9 -6
  157. scipy/interpolate/_fitpack_impl.py +32 -26
  158. scipy/interpolate/_fitpack_repro.py +23 -19
  159. scipy/interpolate/_interpnd.cpython-312-aarch64-linux-musl.so +0 -0
  160. scipy/interpolate/_interpolate.py +30 -12
  161. scipy/interpolate/_ndbspline.py +13 -18
  162. scipy/interpolate/_ndgriddata.py +5 -8
  163. scipy/interpolate/_polyint.py +95 -31
  164. scipy/interpolate/_ppoly.cpython-312-aarch64-linux-musl.so +0 -0
  165. scipy/interpolate/_rbf.py +2 -2
  166. scipy/interpolate/_rbfinterp.py +1 -1
  167. scipy/interpolate/_rbfinterp_pythran.cpython-312-aarch64-linux-musl.so +0 -0
  168. scipy/interpolate/_rgi.py +31 -26
  169. scipy/interpolate/_rgi_cython.cpython-312-aarch64-linux-musl.so +0 -0
  170. scipy/interpolate/dfitpack.py +0 -20
  171. scipy/interpolate/interpnd.py +1 -2
  172. scipy/interpolate/tests/test_bary_rational.py +2 -2
  173. scipy/interpolate/tests/test_bsplines.py +97 -1
  174. scipy/interpolate/tests/test_fitpack2.py +39 -1
  175. scipy/interpolate/tests/test_interpnd.py +32 -20
  176. scipy/interpolate/tests/test_interpolate.py +48 -4
  177. scipy/interpolate/tests/test_rgi.py +2 -1
  178. scipy/io/_fast_matrix_market/__init__.py +2 -0
  179. scipy/io/_fast_matrix_market/_fmm_core.cpython-312-aarch64-linux-musl.so +0 -0
  180. scipy/io/_harwell_boeing/_fortran_format_parser.py +19 -16
  181. scipy/io/_harwell_boeing/hb.py +7 -11
  182. scipy/io/_idl.py +5 -7
  183. scipy/io/_netcdf.py +15 -5
  184. scipy/io/_test_fortran.cpython-312-aarch64-linux-musl.so +0 -0
  185. scipy/io/arff/tests/test_arffread.py +3 -3
  186. scipy/io/matlab/__init__.py +5 -3
  187. scipy/io/matlab/_mio.py +4 -1
  188. scipy/io/matlab/_mio5.py +19 -13
  189. scipy/io/matlab/_mio5_utils.cpython-312-aarch64-linux-musl.so +0 -0
  190. scipy/io/matlab/_mio_utils.cpython-312-aarch64-linux-musl.so +0 -0
  191. scipy/io/matlab/_miobase.py +4 -1
  192. scipy/io/matlab/_streams.cpython-312-aarch64-linux-musl.so +0 -0
  193. scipy/io/matlab/tests/test_mio.py +46 -18
  194. scipy/io/matlab/tests/test_mio_funcs.py +1 -1
  195. scipy/io/tests/test_mmio.py +7 -1
  196. scipy/io/tests/test_wavfile.py +41 -0
  197. scipy/io/wavfile.py +57 -10
  198. scipy/linalg/_basic.py +113 -86
  199. scipy/linalg/_cythonized_array_utils.cpython-312-aarch64-linux-musl.so +0 -0
  200. scipy/linalg/_decomp.py +22 -9
  201. scipy/linalg/_decomp_cholesky.py +28 -13
  202. scipy/linalg/_decomp_cossin.py +45 -30
  203. scipy/linalg/_decomp_interpolative.cpython-312-aarch64-linux-musl.so +0 -0
  204. scipy/linalg/_decomp_ldl.py +4 -1
  205. scipy/linalg/_decomp_lu.py +18 -6
  206. scipy/linalg/_decomp_lu_cython.cpython-312-aarch64-linux-musl.so +0 -0
  207. scipy/linalg/_decomp_polar.py +2 -0
  208. scipy/linalg/_decomp_qr.py +6 -2
  209. scipy/linalg/_decomp_qz.py +3 -0
  210. scipy/linalg/_decomp_schur.py +3 -1
  211. scipy/linalg/_decomp_svd.py +13 -2
  212. scipy/linalg/_decomp_update.cpython-312-aarch64-linux-musl.so +0 -0
  213. scipy/linalg/_expm_frechet.py +4 -0
  214. scipy/linalg/_fblas.cpython-312-aarch64-linux-musl.so +0 -0
  215. scipy/linalg/_flapack.cpython-312-aarch64-linux-musl.so +0 -0
  216. scipy/linalg/_linalg_pythran.cpython-312-aarch64-linux-musl.so +0 -0
  217. scipy/linalg/_matfuncs.py +187 -4
  218. scipy/linalg/_matfuncs_expm.cpython-312-aarch64-linux-musl.so +0 -0
  219. scipy/linalg/_matfuncs_schur_sqrtm.cpython-312-aarch64-linux-musl.so +0 -0
  220. scipy/linalg/_matfuncs_sqrtm.py +1 -99
  221. scipy/linalg/_matfuncs_sqrtm_triu.cpython-312-aarch64-linux-musl.so +0 -0
  222. scipy/linalg/_procrustes.py +2 -0
  223. scipy/linalg/_sketches.py +17 -6
  224. scipy/linalg/_solve_toeplitz.cpython-312-aarch64-linux-musl.so +0 -0
  225. scipy/linalg/_solvers.py +7 -2
  226. scipy/linalg/_special_matrices.py +26 -36
  227. scipy/linalg/blas.py +35 -24
  228. scipy/linalg/cython_blas.cpython-312-aarch64-linux-musl.so +0 -0
  229. scipy/linalg/cython_lapack.cpython-312-aarch64-linux-musl.so +0 -0
  230. scipy/linalg/lapack.py +22 -2
  231. scipy/linalg/tests/_cython_examples/meson.build +7 -0
  232. scipy/linalg/tests/test_basic.py +31 -16
  233. scipy/linalg/tests/test_batch.py +588 -0
  234. scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
  235. scipy/linalg/tests/test_decomp.py +40 -3
  236. scipy/linalg/tests/test_decomp_cossin.py +14 -0
  237. scipy/linalg/tests/test_decomp_ldl.py +1 -1
  238. scipy/linalg/tests/test_interpolative.py +17 -0
  239. scipy/linalg/tests/test_lapack.py +115 -7
  240. scipy/linalg/tests/test_matfuncs.py +157 -102
  241. scipy/linalg/tests/test_procrustes.py +0 -7
  242. scipy/linalg/tests/test_solve_toeplitz.py +1 -1
  243. scipy/linalg/tests/test_special_matrices.py +1 -5
  244. scipy/ndimage/__init__.py +1 -0
  245. scipy/ndimage/_ctest.cpython-312-aarch64-linux-musl.so +0 -0
  246. scipy/ndimage/_cytest.cpython-312-aarch64-linux-musl.so +0 -0
  247. scipy/ndimage/_delegators.py +8 -2
  248. scipy/ndimage/_filters.py +453 -5
  249. scipy/ndimage/_interpolation.py +36 -6
  250. scipy/ndimage/_measurements.py +4 -2
  251. scipy/ndimage/_morphology.py +5 -0
  252. scipy/ndimage/_nd_image.cpython-312-aarch64-linux-musl.so +0 -0
  253. scipy/ndimage/_ndimage_api.py +2 -1
  254. scipy/ndimage/_ni_docstrings.py +5 -1
  255. scipy/ndimage/_ni_label.cpython-312-aarch64-linux-musl.so +0 -0
  256. scipy/ndimage/_ni_support.py +1 -5
  257. scipy/ndimage/_rank_filter_1d.cpython-312-aarch64-linux-musl.so +0 -0
  258. scipy/ndimage/_support_alternative_backends.py +18 -6
  259. scipy/ndimage/tests/test_filters.py +384 -259
  260. scipy/ndimage/tests/test_fourier.py +7 -9
  261. scipy/ndimage/tests/test_interpolation.py +68 -61
  262. scipy/ndimage/tests/test_measurements.py +18 -35
  263. scipy/ndimage/tests/test_morphology.py +143 -131
  264. scipy/ndimage/tests/test_splines.py +1 -3
  265. scipy/odr/__odrpack.cpython-312-aarch64-linux-musl.so +0 -0
  266. scipy/optimize/_basinhopping.py +13 -7
  267. scipy/optimize/_bglu_dense.cpython-312-aarch64-linux-musl.so +0 -0
  268. scipy/optimize/_bracket.py +46 -26
  269. scipy/optimize/_chandrupatla.py +9 -10
  270. scipy/optimize/_cobyla_py.py +104 -123
  271. scipy/optimize/_constraints.py +14 -10
  272. scipy/optimize/_differentiable_functions.py +371 -230
  273. scipy/optimize/_differentialevolution.py +4 -3
  274. scipy/optimize/_direct.cpython-312-aarch64-linux-musl.so +0 -0
  275. scipy/optimize/_dual_annealing.py +1 -1
  276. scipy/optimize/_elementwise.py +1 -4
  277. scipy/optimize/_group_columns.cpython-312-aarch64-linux-musl.so +0 -0
  278. scipy/optimize/_highspy/_core.cpython-312-aarch64-linux-musl.so +0 -0
  279. scipy/optimize/_highspy/_highs_options.cpython-312-aarch64-linux-musl.so +0 -0
  280. scipy/optimize/_highspy/_highs_wrapper.py +6 -4
  281. scipy/optimize/_lbfgsb.cpython-312-aarch64-linux-musl.so +0 -0
  282. scipy/optimize/_lbfgsb_py.py +80 -24
  283. scipy/optimize/_linprog_doc.py +2 -2
  284. scipy/optimize/_linprog_highs.py +11 -11
  285. scipy/optimize/_linprog_ip.py +25 -10
  286. scipy/optimize/_linprog_util.py +18 -19
  287. scipy/optimize/_lsap.cpython-312-aarch64-linux-musl.so +0 -0
  288. scipy/optimize/_lsq/common.py +3 -3
  289. scipy/optimize/_lsq/dogbox.py +16 -2
  290. scipy/optimize/_lsq/givens_elimination.cpython-312-aarch64-linux-musl.so +0 -0
  291. scipy/optimize/_lsq/least_squares.py +198 -126
  292. scipy/optimize/_lsq/lsq_linear.py +6 -6
  293. scipy/optimize/_lsq/trf.py +35 -8
  294. scipy/optimize/_milp.py +3 -1
  295. scipy/optimize/_minimize.py +105 -36
  296. scipy/optimize/_minpack.cpython-312-aarch64-linux-musl.so +0 -0
  297. scipy/optimize/_minpack_py.py +21 -14
  298. scipy/optimize/_moduleTNC.cpython-312-aarch64-linux-musl.so +0 -0
  299. scipy/optimize/_nnls.py +20 -21
  300. scipy/optimize/_nonlin.py +34 -3
  301. scipy/optimize/_numdiff.py +288 -110
  302. scipy/optimize/_optimize.py +86 -48
  303. scipy/optimize/_pava_pybind.cpython-312-aarch64-linux-musl.so +0 -0
  304. scipy/optimize/_remove_redundancy.py +5 -5
  305. scipy/optimize/_root_scalar.py +1 -1
  306. scipy/optimize/_shgo.py +6 -0
  307. scipy/optimize/_shgo_lib/_complex.py +1 -1
  308. scipy/optimize/_slsqp_py.py +216 -124
  309. scipy/optimize/_slsqplib.cpython-312-aarch64-linux-musl.so +0 -0
  310. scipy/optimize/_spectral.py +1 -1
  311. scipy/optimize/_tnc.py +8 -1
  312. scipy/optimize/_trlib/_trlib.cpython-312-aarch64-linux-musl.so +0 -0
  313. scipy/optimize/_trustregion.py +20 -6
  314. scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
  315. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
  316. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
  317. scipy/optimize/_trustregion_constr/projections.py +12 -8
  318. scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
  319. scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
  320. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
  321. scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
  322. scipy/optimize/_trustregion_exact.py +0 -1
  323. scipy/optimize/_zeros.cpython-312-aarch64-linux-musl.so +0 -0
  324. scipy/optimize/_zeros_py.py +97 -17
  325. scipy/optimize/cython_optimize/_zeros.cpython-312-aarch64-linux-musl.so +0 -0
  326. scipy/optimize/slsqp.py +0 -1
  327. scipy/optimize/tests/test__basinhopping.py +1 -1
  328. scipy/optimize/tests/test__differential_evolution.py +4 -4
  329. scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
  330. scipy/optimize/tests/test__numdiff.py +66 -22
  331. scipy/optimize/tests/test__remove_redundancy.py +2 -2
  332. scipy/optimize/tests/test__shgo.py +9 -1
  333. scipy/optimize/tests/test_bracket.py +71 -46
  334. scipy/optimize/tests/test_chandrupatla.py +133 -135
  335. scipy/optimize/tests/test_cobyla.py +74 -45
  336. scipy/optimize/tests/test_constraints.py +1 -1
  337. scipy/optimize/tests/test_differentiable_functions.py +226 -6
  338. scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
  339. scipy/optimize/tests/test_least_squares.py +125 -13
  340. scipy/optimize/tests/test_linear_assignment.py +3 -3
  341. scipy/optimize/tests/test_linprog.py +3 -3
  342. scipy/optimize/tests/test_lsq_linear.py +6 -6
  343. scipy/optimize/tests/test_minimize_constrained.py +2 -2
  344. scipy/optimize/tests/test_minpack.py +4 -4
  345. scipy/optimize/tests/test_nnls.py +43 -3
  346. scipy/optimize/tests/test_nonlin.py +36 -0
  347. scipy/optimize/tests/test_optimize.py +98 -20
  348. scipy/optimize/tests/test_slsqp.py +36 -4
  349. scipy/optimize/tests/test_zeros.py +34 -1
  350. scipy/signal/__init__.py +12 -23
  351. scipy/signal/_delegators.py +568 -0
  352. scipy/signal/_filter_design.py +459 -241
  353. scipy/signal/_fir_filter_design.py +262 -90
  354. scipy/signal/_lti_conversion.py +3 -2
  355. scipy/signal/_ltisys.py +118 -91
  356. scipy/signal/_max_len_seq_inner.cpython-312-aarch64-linux-musl.so +0 -0
  357. scipy/signal/_peak_finding_utils.cpython-312-aarch64-linux-musl.so +0 -0
  358. scipy/signal/_polyutils.py +172 -0
  359. scipy/signal/_short_time_fft.py +553 -76
  360. scipy/signal/_signal_api.py +30 -0
  361. scipy/signal/_signaltools.py +719 -396
  362. scipy/signal/_sigtools.cpython-312-aarch64-linux-musl.so +0 -0
  363. scipy/signal/_sosfilt.cpython-312-aarch64-linux-musl.so +0 -0
  364. scipy/signal/_spectral_py.py +230 -50
  365. scipy/signal/_spline.cpython-312-aarch64-linux-musl.so +0 -0
  366. scipy/signal/_spline_filters.py +108 -68
  367. scipy/signal/_support_alternative_backends.py +73 -0
  368. scipy/signal/_upfirdn.py +4 -1
  369. scipy/signal/_upfirdn_apply.cpython-312-aarch64-linux-musl.so +0 -0
  370. scipy/signal/_waveforms.py +2 -11
  371. scipy/signal/_wavelets.py +1 -1
  372. scipy/signal/fir_filter_design.py +1 -0
  373. scipy/signal/spline.py +4 -11
  374. scipy/signal/tests/_scipy_spectral_test_shim.py +5 -182
  375. scipy/signal/tests/test_bsplines.py +114 -79
  376. scipy/signal/tests/test_cont2discrete.py +9 -2
  377. scipy/signal/tests/test_filter_design.py +721 -481
  378. scipy/signal/tests/test_fir_filter_design.py +332 -140
  379. scipy/signal/tests/test_savitzky_golay.py +4 -3
  380. scipy/signal/tests/test_short_time_fft.py +231 -5
  381. scipy/signal/tests/test_signaltools.py +2150 -1349
  382. scipy/signal/tests/test_spectral.py +50 -6
  383. scipy/signal/tests/test_splines.py +161 -96
  384. scipy/signal/tests/test_upfirdn.py +84 -50
  385. scipy/signal/tests/test_waveforms.py +20 -0
  386. scipy/signal/tests/test_windows.py +607 -466
  387. scipy/signal/windows/_windows.py +287 -148
  388. scipy/sparse/__init__.py +23 -4
  389. scipy/sparse/_base.py +269 -120
  390. scipy/sparse/_bsr.py +7 -4
  391. scipy/sparse/_compressed.py +59 -234
  392. scipy/sparse/_construct.py +90 -38
  393. scipy/sparse/_coo.py +115 -181
  394. scipy/sparse/_csc.py +4 -4
  395. scipy/sparse/_csparsetools.cpython-312-aarch64-linux-musl.so +0 -0
  396. scipy/sparse/_csr.py +2 -2
  397. scipy/sparse/_data.py +48 -48
  398. scipy/sparse/_dia.py +105 -21
  399. scipy/sparse/_dok.py +0 -23
  400. scipy/sparse/_index.py +4 -4
  401. scipy/sparse/_matrix.py +23 -0
  402. scipy/sparse/_sparsetools.cpython-312-aarch64-linux-musl.so +0 -0
  403. scipy/sparse/_sputils.py +37 -22
  404. scipy/sparse/base.py +0 -9
  405. scipy/sparse/bsr.py +0 -14
  406. scipy/sparse/compressed.py +0 -23
  407. scipy/sparse/construct.py +0 -6
  408. scipy/sparse/coo.py +0 -14
  409. scipy/sparse/csc.py +0 -3
  410. scipy/sparse/csgraph/_flow.cpython-312-aarch64-linux-musl.so +0 -0
  411. scipy/sparse/csgraph/_matching.cpython-312-aarch64-linux-musl.so +0 -0
  412. scipy/sparse/csgraph/_min_spanning_tree.cpython-312-aarch64-linux-musl.so +0 -0
  413. scipy/sparse/csgraph/_reordering.cpython-312-aarch64-linux-musl.so +0 -0
  414. scipy/sparse/csgraph/_shortest_path.cpython-312-aarch64-linux-musl.so +0 -0
  415. scipy/sparse/csgraph/_tools.cpython-312-aarch64-linux-musl.so +0 -0
  416. scipy/sparse/csgraph/_traversal.cpython-312-aarch64-linux-musl.so +0 -0
  417. scipy/sparse/csgraph/tests/test_matching.py +14 -2
  418. scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
  419. scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
  420. scipy/sparse/csr.py +0 -5
  421. scipy/sparse/data.py +1 -6
  422. scipy/sparse/dia.py +0 -7
  423. scipy/sparse/dok.py +0 -10
  424. scipy/sparse/linalg/_dsolve/_superlu.cpython-312-aarch64-linux-musl.so +0 -0
  425. scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
  426. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
  427. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-312-aarch64-linux-musl.so +0 -0
  428. scipy/sparse/linalg/_eigen/arpack/arpack.py +28 -20
  429. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
  430. scipy/sparse/linalg/_expm_multiply.py +8 -3
  431. scipy/sparse/linalg/_interface.py +29 -26
  432. scipy/sparse/linalg/_isolve/_gcrotmk.py +6 -5
  433. scipy/sparse/linalg/_isolve/iterative.py +51 -45
  434. scipy/sparse/linalg/_isolve/lgmres.py +6 -6
  435. scipy/sparse/linalg/_isolve/minres.py +5 -5
  436. scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
  437. scipy/sparse/linalg/_isolve/utils.py +2 -8
  438. scipy/sparse/linalg/_matfuncs.py +1 -1
  439. scipy/sparse/linalg/_norm.py +1 -1
  440. scipy/sparse/linalg/_propack/_cpropack.cpython-312-aarch64-linux-musl.so +0 -0
  441. scipy/sparse/linalg/_propack/_dpropack.cpython-312-aarch64-linux-musl.so +0 -0
  442. scipy/sparse/linalg/_propack/_spropack.cpython-312-aarch64-linux-musl.so +0 -0
  443. scipy/sparse/linalg/_propack/_zpropack.cpython-312-aarch64-linux-musl.so +0 -0
  444. scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
  445. scipy/sparse/linalg/tests/test_expm_multiply.py +10 -0
  446. scipy/sparse/linalg/tests/test_interface.py +35 -0
  447. scipy/sparse/linalg/tests/test_pydata_sparse.py +18 -0
  448. scipy/sparse/tests/test_arithmetic1d.py +5 -2
  449. scipy/sparse/tests/test_base.py +224 -40
  450. scipy/sparse/tests/test_common1d.py +17 -12
  451. scipy/sparse/tests/test_construct.py +1 -1
  452. scipy/sparse/tests/test_coo.py +272 -4
  453. scipy/sparse/tests/test_sparsetools.py +5 -0
  454. scipy/sparse/tests/test_sputils.py +36 -7
  455. scipy/spatial/_ckdtree.cpython-312-aarch64-linux-musl.so +0 -0
  456. scipy/spatial/_distance_pybind.cpython-312-aarch64-linux-musl.so +0 -0
  457. scipy/spatial/_distance_wrap.cpython-312-aarch64-linux-musl.so +0 -0
  458. scipy/spatial/_hausdorff.cpython-312-aarch64-linux-musl.so +0 -0
  459. scipy/spatial/_qhull.cpython-312-aarch64-linux-musl.so +0 -0
  460. scipy/spatial/_voronoi.cpython-312-aarch64-linux-musl.so +0 -0
  461. scipy/spatial/distance.py +49 -42
  462. scipy/spatial/tests/test_distance.py +15 -1
  463. scipy/spatial/tests/test_kdtree.py +1 -0
  464. scipy/spatial/tests/test_qhull.py +106 -2
  465. scipy/spatial/transform/__init__.py +5 -3
  466. scipy/spatial/transform/_rigid_transform.cpython-312-aarch64-linux-musl.so +0 -0
  467. scipy/spatial/transform/_rotation.cpython-312-aarch64-linux-musl.so +0 -0
  468. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  469. scipy/spatial/transform/tests/test_rotation.py +1342 -790
  470. scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
  471. scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
  472. scipy/special/__init__.py +1 -47
  473. scipy/special/_add_newdocs.py +34 -772
  474. scipy/special/_basic.py +22 -25
  475. scipy/special/_comb.cpython-312-aarch64-linux-musl.so +0 -0
  476. scipy/special/_ellip_harm_2.cpython-312-aarch64-linux-musl.so +0 -0
  477. scipy/special/_gufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  478. scipy/special/_logsumexp.py +83 -69
  479. scipy/special/_orthogonal.pyi +1 -1
  480. scipy/special/_specfun.cpython-312-aarch64-linux-musl.so +0 -0
  481. scipy/special/_special_ufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  482. scipy/special/_spherical_bessel.py +4 -4
  483. scipy/special/_support_alternative_backends.py +212 -119
  484. scipy/special/_test_internal.cpython-312-aarch64-linux-musl.so +0 -0
  485. scipy/special/_testutils.py +4 -4
  486. scipy/special/_ufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  487. scipy/special/_ufuncs.pyi +1 -0
  488. scipy/special/_ufuncs.pyx +215 -1400
  489. scipy/special/_ufuncs_cxx.cpython-312-aarch64-linux-musl.so +0 -0
  490. scipy/special/_ufuncs_cxx.pxd +2 -15
  491. scipy/special/_ufuncs_cxx.pyx +5 -44
  492. scipy/special/_ufuncs_cxx_defs.h +2 -16
  493. scipy/special/_ufuncs_defs.h +0 -8
  494. scipy/special/cython_special.cpython-312-aarch64-linux-musl.so +0 -0
  495. scipy/special/cython_special.pxd +1 -1
  496. scipy/special/tests/_cython_examples/meson.build +10 -1
  497. scipy/special/tests/test_basic.py +153 -20
  498. scipy/special/tests/test_boost_ufuncs.py +3 -0
  499. scipy/special/tests/test_cdflib.py +35 -11
  500. scipy/special/tests/test_gammainc.py +16 -0
  501. scipy/special/tests/test_hyp2f1.py +23 -2
  502. scipy/special/tests/test_log1mexp.py +85 -0
  503. scipy/special/tests/test_logsumexp.py +220 -64
  504. scipy/special/tests/test_mpmath.py +1 -0
  505. scipy/special/tests/test_nan_inputs.py +1 -1
  506. scipy/special/tests/test_orthogonal.py +17 -18
  507. scipy/special/tests/test_sf_error.py +3 -2
  508. scipy/special/tests/test_sph_harm.py +6 -7
  509. scipy/special/tests/test_support_alternative_backends.py +211 -76
  510. scipy/stats/__init__.py +4 -1
  511. scipy/stats/_ansari_swilk_statistics.cpython-312-aarch64-linux-musl.so +0 -0
  512. scipy/stats/_axis_nan_policy.py +5 -12
  513. scipy/stats/_biasedurn.cpython-312-aarch64-linux-musl.so +0 -0
  514. scipy/stats/_continued_fraction.py +387 -0
  515. scipy/stats/_continuous_distns.py +296 -319
  516. scipy/stats/_correlation.py +1 -1
  517. scipy/stats/_covariance.py +6 -3
  518. scipy/stats/_discrete_distns.py +39 -32
  519. scipy/stats/_distn_infrastructure.py +39 -12
  520. scipy/stats/_distribution_infrastructure.py +920 -238
  521. scipy/stats/_entropy.py +9 -10
  522. scipy/{_lib → stats}/_finite_differences.py +1 -1
  523. scipy/stats/_hypotests.py +83 -50
  524. scipy/stats/_kde.py +53 -49
  525. scipy/stats/_ksstats.py +1 -1
  526. scipy/stats/_levy_stable/__init__.py +7 -15
  527. scipy/stats/_levy_stable/levyst.cpython-312-aarch64-linux-musl.so +0 -0
  528. scipy/stats/_morestats.py +118 -73
  529. scipy/stats/_mstats_basic.py +13 -17
  530. scipy/stats/_mstats_extras.py +8 -8
  531. scipy/stats/_multivariate.py +89 -113
  532. scipy/stats/_new_distributions.py +97 -20
  533. scipy/stats/_page_trend_test.py +12 -5
  534. scipy/stats/_probability_distribution.py +265 -43
  535. scipy/stats/_qmc.py +14 -9
  536. scipy/stats/_qmc_cy.cpython-312-aarch64-linux-musl.so +0 -0
  537. scipy/stats/_qmvnt.py +16 -95
  538. scipy/stats/_qmvnt_cy.cpython-312-aarch64-linux-musl.so +0 -0
  539. scipy/stats/_quantile.py +335 -0
  540. scipy/stats/_rcont/rcont.cpython-312-aarch64-linux-musl.so +0 -0
  541. scipy/stats/_resampling.py +5 -30
  542. scipy/stats/_sampling.py +1 -1
  543. scipy/stats/_sobol.cpython-312-aarch64-linux-musl.so +0 -0
  544. scipy/stats/_stats.cpython-312-aarch64-linux-musl.so +0 -0
  545. scipy/stats/_stats_mstats_common.py +21 -2
  546. scipy/stats/_stats_py.py +551 -477
  547. scipy/stats/_stats_pythran.cpython-312-aarch64-linux-musl.so +0 -0
  548. scipy/stats/_unuran/unuran_wrapper.cpython-312-aarch64-linux-musl.so +0 -0
  549. scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
  550. scipy/stats/_variation.py +6 -8
  551. scipy/stats/_wilcoxon.py +13 -7
  552. scipy/stats/tests/common_tests.py +6 -4
  553. scipy/stats/tests/test_axis_nan_policy.py +62 -24
  554. scipy/stats/tests/test_continued_fraction.py +173 -0
  555. scipy/stats/tests/test_continuous.py +379 -60
  556. scipy/stats/tests/test_continuous_basic.py +18 -12
  557. scipy/stats/tests/test_discrete_basic.py +14 -8
  558. scipy/stats/tests/test_discrete_distns.py +16 -16
  559. scipy/stats/tests/test_distributions.py +117 -75
  560. scipy/stats/tests/test_entropy.py +40 -48
  561. scipy/stats/tests/test_fit.py +4 -3
  562. scipy/stats/tests/test_hypotests.py +153 -24
  563. scipy/stats/tests/test_kdeoth.py +109 -41
  564. scipy/stats/tests/test_marray.py +289 -0
  565. scipy/stats/tests/test_morestats.py +81 -49
  566. scipy/stats/tests/test_mstats_basic.py +3 -3
  567. scipy/stats/tests/test_multivariate.py +434 -83
  568. scipy/stats/tests/test_qmc.py +13 -10
  569. scipy/stats/tests/test_quantile.py +199 -0
  570. scipy/stats/tests/test_rank.py +119 -112
  571. scipy/stats/tests/test_resampling.py +47 -56
  572. scipy/stats/tests/test_sampling.py +9 -4
  573. scipy/stats/tests/test_stats.py +799 -939
  574. scipy/stats/tests/test_variation.py +8 -6
  575. scipy/version.py +2 -2
  576. {scipy-1.15.2.dist-info → scipy-1.16.0.dist-info}/LICENSE.txt +4 -4
  577. {scipy-1.15.2.dist-info → scipy-1.16.0.dist-info}/METADATA +12 -12
  578. {scipy-1.15.2.dist-info → scipy-1.16.0.dist-info}/RECORD +1316 -1323
  579. scipy.libs/libgcc_s-2d945d6c.so.1 +0 -0
  580. scipy.libs/libgfortran-67378ab2.so.5.0.0 +0 -0
  581. scipy.libs/{libstdc++-1b614e01.so.6.0.32 → libstdc++-85f2cd6d.so.6.0.33} +0 -0
  582. scipy/_lib/array_api_extra/_funcs.py +0 -484
  583. scipy/_lib/array_api_extra/_typing.py +0 -8
  584. scipy/interpolate/_bspl.cpython-312-aarch64-linux-musl.so +0 -0
  585. scipy/optimize/_cobyla.cpython-312-aarch64-linux-musl.so +0 -0
  586. scipy/optimize/_cython_nnls.cpython-312-aarch64-linux-musl.so +0 -0
  587. scipy/optimize/_slsqp.cpython-312-aarch64-linux-musl.so +0 -0
  588. scipy/spatial/qhull_src/COPYING.txt +0 -38
  589. scipy/special/libsf_error_state.so +0 -0
  590. scipy/special/tests/test_log_softmax.py +0 -109
  591. scipy/special/tests/test_xsf_cuda.py +0 -114
  592. scipy/special/xsf/binom.h +0 -89
  593. scipy/special/xsf/cdflib.h +0 -100
  594. scipy/special/xsf/cephes/airy.h +0 -307
  595. scipy/special/xsf/cephes/besselpoly.h +0 -51
  596. scipy/special/xsf/cephes/beta.h +0 -257
  597. scipy/special/xsf/cephes/cbrt.h +0 -131
  598. scipy/special/xsf/cephes/chbevl.h +0 -85
  599. scipy/special/xsf/cephes/chdtr.h +0 -193
  600. scipy/special/xsf/cephes/const.h +0 -87
  601. scipy/special/xsf/cephes/ellie.h +0 -293
  602. scipy/special/xsf/cephes/ellik.h +0 -251
  603. scipy/special/xsf/cephes/ellpe.h +0 -107
  604. scipy/special/xsf/cephes/ellpk.h +0 -117
  605. scipy/special/xsf/cephes/expn.h +0 -260
  606. scipy/special/xsf/cephes/gamma.h +0 -398
  607. scipy/special/xsf/cephes/hyp2f1.h +0 -596
  608. scipy/special/xsf/cephes/hyperg.h +0 -361
  609. scipy/special/xsf/cephes/i0.h +0 -149
  610. scipy/special/xsf/cephes/i1.h +0 -158
  611. scipy/special/xsf/cephes/igam.h +0 -421
  612. scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
  613. scipy/special/xsf/cephes/igami.h +0 -313
  614. scipy/special/xsf/cephes/j0.h +0 -225
  615. scipy/special/xsf/cephes/j1.h +0 -198
  616. scipy/special/xsf/cephes/jv.h +0 -715
  617. scipy/special/xsf/cephes/k0.h +0 -164
  618. scipy/special/xsf/cephes/k1.h +0 -163
  619. scipy/special/xsf/cephes/kn.h +0 -243
  620. scipy/special/xsf/cephes/lanczos.h +0 -112
  621. scipy/special/xsf/cephes/ndtr.h +0 -275
  622. scipy/special/xsf/cephes/poch.h +0 -85
  623. scipy/special/xsf/cephes/polevl.h +0 -167
  624. scipy/special/xsf/cephes/psi.h +0 -194
  625. scipy/special/xsf/cephes/rgamma.h +0 -111
  626. scipy/special/xsf/cephes/scipy_iv.h +0 -811
  627. scipy/special/xsf/cephes/shichi.h +0 -248
  628. scipy/special/xsf/cephes/sici.h +0 -224
  629. scipy/special/xsf/cephes/sindg.h +0 -221
  630. scipy/special/xsf/cephes/tandg.h +0 -139
  631. scipy/special/xsf/cephes/trig.h +0 -58
  632. scipy/special/xsf/cephes/unity.h +0 -186
  633. scipy/special/xsf/cephes/zeta.h +0 -172
  634. scipy/special/xsf/config.h +0 -304
  635. scipy/special/xsf/digamma.h +0 -205
  636. scipy/special/xsf/error.h +0 -57
  637. scipy/special/xsf/evalpoly.h +0 -47
  638. scipy/special/xsf/expint.h +0 -266
  639. scipy/special/xsf/hyp2f1.h +0 -694
  640. scipy/special/xsf/iv_ratio.h +0 -173
  641. scipy/special/xsf/lambertw.h +0 -150
  642. scipy/special/xsf/loggamma.h +0 -163
  643. scipy/special/xsf/sici.h +0 -200
  644. scipy/special/xsf/tools.h +0 -427
  645. scipy/special/xsf/trig.h +0 -164
  646. scipy/special/xsf/wright_bessel.h +0 -843
  647. scipy/special/xsf/zlog1.h +0 -35
  648. scipy/stats/_mvn.cpython-312-aarch64-linux-musl.so +0 -0
  649. scipy.libs/libgcc_s-7393e603.so.1 +0 -0
  650. scipy.libs/libgfortran-eb933d8e.so.5.0.0 +0 -0
  651. {scipy-1.15.2.dist-info → scipy-1.16.0.dist-info}/WHEEL +0 -0
@@ -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
@@ -0,0 +1,10 @@
1
+ # numpydoc ignore=GL08
2
+ # pylint: disable=missing-module-docstring,duplicate-code
3
+
4
+ Array = object
5
+ DType = object
6
+ Device = object
7
+ GetIndex = object
8
+ SetIndex = object
9
+
10
+ __all__ = ["Array", "DType", "Device", "GetIndex", "SetIndex"]