scipy 1.15.2__cp312-cp312-musllinux_1_2_aarch64.whl → 1.16.0rc1__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 (649) hide show
  1. scipy/__config__.py +11 -11
  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 +263 -157
  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/cython_blas.cpython-312-aarch64-linux-musl.so +0 -0
  228. scipy/linalg/cython_lapack.cpython-312-aarch64-linux-musl.so +0 -0
  229. scipy/linalg/lapack.py +22 -2
  230. scipy/linalg/tests/_cython_examples/meson.build +7 -0
  231. scipy/linalg/tests/test_basic.py +31 -16
  232. scipy/linalg/tests/test_batch.py +588 -0
  233. scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
  234. scipy/linalg/tests/test_decomp.py +40 -3
  235. scipy/linalg/tests/test_decomp_cossin.py +14 -0
  236. scipy/linalg/tests/test_decomp_ldl.py +1 -1
  237. scipy/linalg/tests/test_interpolative.py +17 -0
  238. scipy/linalg/tests/test_lapack.py +115 -7
  239. scipy/linalg/tests/test_matfuncs.py +157 -102
  240. scipy/linalg/tests/test_procrustes.py +0 -7
  241. scipy/linalg/tests/test_solve_toeplitz.py +1 -1
  242. scipy/linalg/tests/test_special_matrices.py +1 -5
  243. scipy/ndimage/__init__.py +1 -0
  244. scipy/ndimage/_ctest.cpython-312-aarch64-linux-musl.so +0 -0
  245. scipy/ndimage/_cytest.cpython-312-aarch64-linux-musl.so +0 -0
  246. scipy/ndimage/_delegators.py +8 -2
  247. scipy/ndimage/_filters.py +433 -5
  248. scipy/ndimage/_interpolation.py +36 -6
  249. scipy/ndimage/_measurements.py +4 -2
  250. scipy/ndimage/_morphology.py +5 -0
  251. scipy/ndimage/_nd_image.cpython-312-aarch64-linux-musl.so +0 -0
  252. scipy/ndimage/_ndimage_api.py +2 -1
  253. scipy/ndimage/_ni_docstrings.py +5 -1
  254. scipy/ndimage/_ni_label.cpython-312-aarch64-linux-musl.so +0 -0
  255. scipy/ndimage/_ni_support.py +1 -5
  256. scipy/ndimage/_rank_filter_1d.cpython-312-aarch64-linux-musl.so +0 -0
  257. scipy/ndimage/_support_alternative_backends.py +18 -6
  258. scipy/ndimage/tests/test_filters.py +351 -259
  259. scipy/ndimage/tests/test_fourier.py +7 -9
  260. scipy/ndimage/tests/test_interpolation.py +68 -61
  261. scipy/ndimage/tests/test_measurements.py +18 -35
  262. scipy/ndimage/tests/test_morphology.py +143 -131
  263. scipy/ndimage/tests/test_splines.py +1 -3
  264. scipy/odr/__odrpack.cpython-312-aarch64-linux-musl.so +0 -0
  265. scipy/optimize/_basinhopping.py +13 -7
  266. scipy/optimize/_bglu_dense.cpython-312-aarch64-linux-musl.so +0 -0
  267. scipy/optimize/_bracket.py +46 -26
  268. scipy/optimize/_chandrupatla.py +9 -10
  269. scipy/optimize/_cobyla_py.py +104 -123
  270. scipy/optimize/_constraints.py +14 -10
  271. scipy/optimize/_differentiable_functions.py +371 -230
  272. scipy/optimize/_differentialevolution.py +4 -3
  273. scipy/optimize/_direct.cpython-312-aarch64-linux-musl.so +0 -0
  274. scipy/optimize/_dual_annealing.py +1 -1
  275. scipy/optimize/_elementwise.py +1 -4
  276. scipy/optimize/_group_columns.cpython-312-aarch64-linux-musl.so +0 -0
  277. scipy/optimize/_highspy/_core.cpython-312-aarch64-linux-musl.so +0 -0
  278. scipy/optimize/_highspy/_highs_options.cpython-312-aarch64-linux-musl.so +0 -0
  279. scipy/optimize/_highspy/_highs_wrapper.py +6 -4
  280. scipy/optimize/_lbfgsb.cpython-312-aarch64-linux-musl.so +0 -0
  281. scipy/optimize/_lbfgsb_py.py +57 -16
  282. scipy/optimize/_linprog_doc.py +2 -2
  283. scipy/optimize/_linprog_highs.py +11 -11
  284. scipy/optimize/_linprog_ip.py +25 -10
  285. scipy/optimize/_linprog_util.py +18 -19
  286. scipy/optimize/_lsap.cpython-312-aarch64-linux-musl.so +0 -0
  287. scipy/optimize/_lsq/common.py +3 -3
  288. scipy/optimize/_lsq/dogbox.py +16 -2
  289. scipy/optimize/_lsq/givens_elimination.cpython-312-aarch64-linux-musl.so +0 -0
  290. scipy/optimize/_lsq/least_squares.py +198 -126
  291. scipy/optimize/_lsq/lsq_linear.py +6 -6
  292. scipy/optimize/_lsq/trf.py +35 -8
  293. scipy/optimize/_milp.py +3 -1
  294. scipy/optimize/_minimize.py +105 -36
  295. scipy/optimize/_minpack.cpython-312-aarch64-linux-musl.so +0 -0
  296. scipy/optimize/_minpack_py.py +21 -14
  297. scipy/optimize/_moduleTNC.cpython-312-aarch64-linux-musl.so +0 -0
  298. scipy/optimize/_nnls.py +20 -21
  299. scipy/optimize/_nonlin.py +34 -3
  300. scipy/optimize/_numdiff.py +288 -110
  301. scipy/optimize/_optimize.py +86 -48
  302. scipy/optimize/_pava_pybind.cpython-312-aarch64-linux-musl.so +0 -0
  303. scipy/optimize/_remove_redundancy.py +5 -5
  304. scipy/optimize/_root_scalar.py +1 -1
  305. scipy/optimize/_shgo.py +6 -0
  306. scipy/optimize/_shgo_lib/_complex.py +1 -1
  307. scipy/optimize/_slsqp_py.py +216 -124
  308. scipy/optimize/_slsqplib.cpython-312-aarch64-linux-musl.so +0 -0
  309. scipy/optimize/_spectral.py +1 -1
  310. scipy/optimize/_tnc.py +8 -1
  311. scipy/optimize/_trlib/_trlib.cpython-312-aarch64-linux-musl.so +0 -0
  312. scipy/optimize/_trustregion.py +20 -6
  313. scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
  314. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
  315. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
  316. scipy/optimize/_trustregion_constr/projections.py +12 -8
  317. scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
  318. scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
  319. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
  320. scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
  321. scipy/optimize/_trustregion_exact.py +0 -1
  322. scipy/optimize/_zeros.cpython-312-aarch64-linux-musl.so +0 -0
  323. scipy/optimize/_zeros_py.py +97 -17
  324. scipy/optimize/cython_optimize/_zeros.cpython-312-aarch64-linux-musl.so +0 -0
  325. scipy/optimize/slsqp.py +0 -1
  326. scipy/optimize/tests/test__basinhopping.py +1 -1
  327. scipy/optimize/tests/test__differential_evolution.py +4 -4
  328. scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
  329. scipy/optimize/tests/test__numdiff.py +66 -22
  330. scipy/optimize/tests/test__remove_redundancy.py +2 -2
  331. scipy/optimize/tests/test__shgo.py +9 -1
  332. scipy/optimize/tests/test_bracket.py +71 -46
  333. scipy/optimize/tests/test_chandrupatla.py +133 -135
  334. scipy/optimize/tests/test_cobyla.py +74 -45
  335. scipy/optimize/tests/test_constraints.py +1 -1
  336. scipy/optimize/tests/test_differentiable_functions.py +226 -6
  337. scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
  338. scipy/optimize/tests/test_least_squares.py +125 -13
  339. scipy/optimize/tests/test_linear_assignment.py +3 -3
  340. scipy/optimize/tests/test_linprog.py +3 -3
  341. scipy/optimize/tests/test_lsq_linear.py +5 -5
  342. scipy/optimize/tests/test_minimize_constrained.py +2 -2
  343. scipy/optimize/tests/test_minpack.py +4 -4
  344. scipy/optimize/tests/test_nnls.py +43 -3
  345. scipy/optimize/tests/test_nonlin.py +36 -0
  346. scipy/optimize/tests/test_optimize.py +95 -17
  347. scipy/optimize/tests/test_slsqp.py +36 -4
  348. scipy/optimize/tests/test_zeros.py +34 -1
  349. scipy/signal/__init__.py +12 -23
  350. scipy/signal/_delegators.py +568 -0
  351. scipy/signal/_filter_design.py +459 -241
  352. scipy/signal/_fir_filter_design.py +262 -90
  353. scipy/signal/_lti_conversion.py +3 -2
  354. scipy/signal/_ltisys.py +118 -91
  355. scipy/signal/_max_len_seq_inner.cpython-312-aarch64-linux-musl.so +0 -0
  356. scipy/signal/_peak_finding_utils.cpython-312-aarch64-linux-musl.so +0 -0
  357. scipy/signal/_polyutils.py +172 -0
  358. scipy/signal/_short_time_fft.py +553 -76
  359. scipy/signal/_signal_api.py +30 -0
  360. scipy/signal/_signaltools.py +719 -396
  361. scipy/signal/_sigtools.cpython-312-aarch64-linux-musl.so +0 -0
  362. scipy/signal/_sosfilt.cpython-312-aarch64-linux-musl.so +0 -0
  363. scipy/signal/_spectral_py.py +221 -50
  364. scipy/signal/_spline.cpython-312-aarch64-linux-musl.so +0 -0
  365. scipy/signal/_spline_filters.py +108 -68
  366. scipy/signal/_support_alternative_backends.py +73 -0
  367. scipy/signal/_upfirdn.py +4 -1
  368. scipy/signal/_upfirdn_apply.cpython-312-aarch64-linux-musl.so +0 -0
  369. scipy/signal/_waveforms.py +2 -11
  370. scipy/signal/_wavelets.py +1 -1
  371. scipy/signal/fir_filter_design.py +1 -0
  372. scipy/signal/spline.py +4 -11
  373. scipy/signal/tests/_scipy_spectral_test_shim.py +5 -182
  374. scipy/signal/tests/test_bsplines.py +114 -79
  375. scipy/signal/tests/test_cont2discrete.py +9 -2
  376. scipy/signal/tests/test_filter_design.py +721 -481
  377. scipy/signal/tests/test_fir_filter_design.py +332 -140
  378. scipy/signal/tests/test_savitzky_golay.py +4 -3
  379. scipy/signal/tests/test_short_time_fft.py +231 -5
  380. scipy/signal/tests/test_signaltools.py +2149 -1348
  381. scipy/signal/tests/test_spectral.py +19 -6
  382. scipy/signal/tests/test_splines.py +161 -96
  383. scipy/signal/tests/test_upfirdn.py +84 -50
  384. scipy/signal/tests/test_waveforms.py +20 -0
  385. scipy/signal/tests/test_windows.py +607 -466
  386. scipy/signal/windows/_windows.py +287 -148
  387. scipy/sparse/__init__.py +23 -4
  388. scipy/sparse/_base.py +269 -120
  389. scipy/sparse/_bsr.py +7 -4
  390. scipy/sparse/_compressed.py +59 -234
  391. scipy/sparse/_construct.py +90 -38
  392. scipy/sparse/_coo.py +115 -181
  393. scipy/sparse/_csc.py +4 -4
  394. scipy/sparse/_csparsetools.cpython-312-aarch64-linux-musl.so +0 -0
  395. scipy/sparse/_csr.py +2 -2
  396. scipy/sparse/_data.py +48 -48
  397. scipy/sparse/_dia.py +105 -21
  398. scipy/sparse/_dok.py +0 -23
  399. scipy/sparse/_index.py +4 -4
  400. scipy/sparse/_matrix.py +23 -0
  401. scipy/sparse/_sparsetools.cpython-312-aarch64-linux-musl.so +0 -0
  402. scipy/sparse/_sputils.py +37 -22
  403. scipy/sparse/base.py +0 -9
  404. scipy/sparse/bsr.py +0 -14
  405. scipy/sparse/compressed.py +0 -23
  406. scipy/sparse/construct.py +0 -6
  407. scipy/sparse/coo.py +0 -14
  408. scipy/sparse/csc.py +0 -3
  409. scipy/sparse/csgraph/_flow.cpython-312-aarch64-linux-musl.so +0 -0
  410. scipy/sparse/csgraph/_matching.cpython-312-aarch64-linux-musl.so +0 -0
  411. scipy/sparse/csgraph/_min_spanning_tree.cpython-312-aarch64-linux-musl.so +0 -0
  412. scipy/sparse/csgraph/_reordering.cpython-312-aarch64-linux-musl.so +0 -0
  413. scipy/sparse/csgraph/_shortest_path.cpython-312-aarch64-linux-musl.so +0 -0
  414. scipy/sparse/csgraph/_tools.cpython-312-aarch64-linux-musl.so +0 -0
  415. scipy/sparse/csgraph/_traversal.cpython-312-aarch64-linux-musl.so +0 -0
  416. scipy/sparse/csgraph/tests/test_matching.py +14 -2
  417. scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
  418. scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
  419. scipy/sparse/csr.py +0 -5
  420. scipy/sparse/data.py +1 -6
  421. scipy/sparse/dia.py +0 -7
  422. scipy/sparse/dok.py +0 -10
  423. scipy/sparse/linalg/_dsolve/_superlu.cpython-312-aarch64-linux-musl.so +0 -0
  424. scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
  425. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
  426. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-312-aarch64-linux-musl.so +0 -0
  427. scipy/sparse/linalg/_eigen/arpack/arpack.py +28 -20
  428. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
  429. scipy/sparse/linalg/_expm_multiply.py +8 -3
  430. scipy/sparse/linalg/_interface.py +29 -26
  431. scipy/sparse/linalg/_isolve/_gcrotmk.py +6 -5
  432. scipy/sparse/linalg/_isolve/iterative.py +51 -45
  433. scipy/sparse/linalg/_isolve/lgmres.py +6 -6
  434. scipy/sparse/linalg/_isolve/minres.py +5 -5
  435. scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
  436. scipy/sparse/linalg/_isolve/utils.py +2 -8
  437. scipy/sparse/linalg/_matfuncs.py +1 -1
  438. scipy/sparse/linalg/_norm.py +1 -1
  439. scipy/sparse/linalg/_propack/_cpropack.cpython-312-aarch64-linux-musl.so +0 -0
  440. scipy/sparse/linalg/_propack/_dpropack.cpython-312-aarch64-linux-musl.so +0 -0
  441. scipy/sparse/linalg/_propack/_spropack.cpython-312-aarch64-linux-musl.so +0 -0
  442. scipy/sparse/linalg/_propack/_zpropack.cpython-312-aarch64-linux-musl.so +0 -0
  443. scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
  444. scipy/sparse/linalg/tests/test_expm_multiply.py +10 -0
  445. scipy/sparse/linalg/tests/test_interface.py +35 -0
  446. scipy/sparse/linalg/tests/test_pydata_sparse.py +18 -0
  447. scipy/sparse/tests/test_arithmetic1d.py +5 -2
  448. scipy/sparse/tests/test_base.py +217 -40
  449. scipy/sparse/tests/test_common1d.py +17 -12
  450. scipy/sparse/tests/test_construct.py +1 -1
  451. scipy/sparse/tests/test_coo.py +272 -4
  452. scipy/sparse/tests/test_sparsetools.py +5 -0
  453. scipy/sparse/tests/test_sputils.py +36 -7
  454. scipy/spatial/_ckdtree.cpython-312-aarch64-linux-musl.so +0 -0
  455. scipy/spatial/_distance_pybind.cpython-312-aarch64-linux-musl.so +0 -0
  456. scipy/spatial/_distance_wrap.cpython-312-aarch64-linux-musl.so +0 -0
  457. scipy/spatial/_hausdorff.cpython-312-aarch64-linux-musl.so +0 -0
  458. scipy/spatial/_qhull.cpython-312-aarch64-linux-musl.so +0 -0
  459. scipy/spatial/_voronoi.cpython-312-aarch64-linux-musl.so +0 -0
  460. scipy/spatial/distance.py +49 -42
  461. scipy/spatial/tests/test_distance.py +3 -1
  462. scipy/spatial/tests/test_kdtree.py +1 -0
  463. scipy/spatial/tests/test_qhull.py +106 -2
  464. scipy/spatial/transform/__init__.py +5 -3
  465. scipy/spatial/transform/_rigid_transform.cpython-312-aarch64-linux-musl.so +0 -0
  466. scipy/spatial/transform/_rotation.cpython-312-aarch64-linux-musl.so +0 -0
  467. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  468. scipy/spatial/transform/tests/test_rotation.py +1342 -790
  469. scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
  470. scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
  471. scipy/special/__init__.py +1 -47
  472. scipy/special/_add_newdocs.py +34 -772
  473. scipy/special/_basic.py +22 -25
  474. scipy/special/_comb.cpython-312-aarch64-linux-musl.so +0 -0
  475. scipy/special/_ellip_harm_2.cpython-312-aarch64-linux-musl.so +0 -0
  476. scipy/special/_gufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  477. scipy/special/_logsumexp.py +83 -69
  478. scipy/special/_orthogonal.pyi +1 -1
  479. scipy/special/_specfun.cpython-312-aarch64-linux-musl.so +0 -0
  480. scipy/special/_special_ufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  481. scipy/special/_spherical_bessel.py +4 -4
  482. scipy/special/_support_alternative_backends.py +212 -119
  483. scipy/special/_test_internal.cpython-312-aarch64-linux-musl.so +0 -0
  484. scipy/special/_testutils.py +4 -4
  485. scipy/special/_ufuncs.cpython-312-aarch64-linux-musl.so +0 -0
  486. scipy/special/_ufuncs.pyi +1 -0
  487. scipy/special/_ufuncs.pyx +215 -1400
  488. scipy/special/_ufuncs_cxx.cpython-312-aarch64-linux-musl.so +0 -0
  489. scipy/special/_ufuncs_cxx.pxd +2 -15
  490. scipy/special/_ufuncs_cxx.pyx +5 -44
  491. scipy/special/_ufuncs_cxx_defs.h +2 -16
  492. scipy/special/_ufuncs_defs.h +0 -8
  493. scipy/special/cython_special.cpython-312-aarch64-linux-musl.so +0 -0
  494. scipy/special/cython_special.pxd +1 -1
  495. scipy/special/tests/_cython_examples/meson.build +10 -1
  496. scipy/special/tests/test_basic.py +153 -20
  497. scipy/special/tests/test_boost_ufuncs.py +3 -0
  498. scipy/special/tests/test_cdflib.py +35 -11
  499. scipy/special/tests/test_gammainc.py +16 -0
  500. scipy/special/tests/test_hyp2f1.py +23 -2
  501. scipy/special/tests/test_log1mexp.py +85 -0
  502. scipy/special/tests/test_logsumexp.py +220 -64
  503. scipy/special/tests/test_mpmath.py +1 -0
  504. scipy/special/tests/test_nan_inputs.py +1 -1
  505. scipy/special/tests/test_orthogonal.py +17 -18
  506. scipy/special/tests/test_sf_error.py +3 -2
  507. scipy/special/tests/test_sph_harm.py +6 -7
  508. scipy/special/tests/test_support_alternative_backends.py +211 -76
  509. scipy/stats/__init__.py +4 -1
  510. scipy/stats/_ansari_swilk_statistics.cpython-312-aarch64-linux-musl.so +0 -0
  511. scipy/stats/_axis_nan_policy.py +4 -3
  512. scipy/stats/_biasedurn.cpython-312-aarch64-linux-musl.so +0 -0
  513. scipy/stats/_continued_fraction.py +387 -0
  514. scipy/stats/_continuous_distns.py +296 -319
  515. scipy/stats/_covariance.py +6 -3
  516. scipy/stats/_discrete_distns.py +39 -32
  517. scipy/stats/_distn_infrastructure.py +39 -12
  518. scipy/stats/_distribution_infrastructure.py +900 -238
  519. scipy/stats/_entropy.py +7 -8
  520. scipy/{_lib → stats}/_finite_differences.py +1 -1
  521. scipy/stats/_hypotests.py +82 -49
  522. scipy/stats/_kde.py +53 -49
  523. scipy/stats/_ksstats.py +1 -1
  524. scipy/stats/_levy_stable/__init__.py +7 -15
  525. scipy/stats/_levy_stable/levyst.cpython-312-aarch64-linux-musl.so +0 -0
  526. scipy/stats/_morestats.py +112 -67
  527. scipy/stats/_mstats_basic.py +13 -17
  528. scipy/stats/_mstats_extras.py +8 -8
  529. scipy/stats/_multivariate.py +89 -113
  530. scipy/stats/_new_distributions.py +97 -20
  531. scipy/stats/_page_trend_test.py +12 -5
  532. scipy/stats/_probability_distribution.py +265 -43
  533. scipy/stats/_qmc.py +14 -9
  534. scipy/stats/_qmc_cy.cpython-312-aarch64-linux-musl.so +0 -0
  535. scipy/stats/_qmvnt.py +16 -95
  536. scipy/stats/_qmvnt_cy.cpython-312-aarch64-linux-musl.so +0 -0
  537. scipy/stats/_quantile.py +335 -0
  538. scipy/stats/_rcont/rcont.cpython-312-aarch64-linux-musl.so +0 -0
  539. scipy/stats/_resampling.py +4 -29
  540. scipy/stats/_sampling.py +1 -1
  541. scipy/stats/_sobol.cpython-312-aarch64-linux-musl.so +0 -0
  542. scipy/stats/_stats.cpython-312-aarch64-linux-musl.so +0 -0
  543. scipy/stats/_stats_mstats_common.py +19 -2
  544. scipy/stats/_stats_py.py +534 -460
  545. scipy/stats/_stats_pythran.cpython-312-aarch64-linux-musl.so +0 -0
  546. scipy/stats/_unuran/unuran_wrapper.cpython-312-aarch64-linux-musl.so +0 -0
  547. scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
  548. scipy/stats/_variation.py +5 -7
  549. scipy/stats/_wilcoxon.py +13 -7
  550. scipy/stats/tests/common_tests.py +6 -4
  551. scipy/stats/tests/test_axis_nan_policy.py +62 -24
  552. scipy/stats/tests/test_continued_fraction.py +173 -0
  553. scipy/stats/tests/test_continuous.py +379 -60
  554. scipy/stats/tests/test_continuous_basic.py +18 -12
  555. scipy/stats/tests/test_discrete_basic.py +14 -8
  556. scipy/stats/tests/test_discrete_distns.py +16 -16
  557. scipy/stats/tests/test_distributions.py +117 -75
  558. scipy/stats/tests/test_entropy.py +40 -48
  559. scipy/stats/tests/test_fit.py +4 -3
  560. scipy/stats/tests/test_hypotests.py +153 -24
  561. scipy/stats/tests/test_kdeoth.py +109 -41
  562. scipy/stats/tests/test_marray.py +289 -0
  563. scipy/stats/tests/test_morestats.py +79 -47
  564. scipy/stats/tests/test_mstats_basic.py +3 -3
  565. scipy/stats/tests/test_multivariate.py +434 -83
  566. scipy/stats/tests/test_qmc.py +13 -10
  567. scipy/stats/tests/test_quantile.py +199 -0
  568. scipy/stats/tests/test_rank.py +119 -112
  569. scipy/stats/tests/test_resampling.py +47 -56
  570. scipy/stats/tests/test_sampling.py +9 -4
  571. scipy/stats/tests/test_stats.py +799 -939
  572. scipy/stats/tests/test_variation.py +8 -6
  573. scipy/version.py +2 -2
  574. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/LICENSE.txt +1 -1
  575. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/METADATA +9 -9
  576. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/RECORD +1316 -1323
  577. scipy.libs/libgcc_s-69c45f16.so.1 +0 -0
  578. scipy.libs/libgfortran-db0b6589.so.5.0.0 +0 -0
  579. scipy.libs/{libstdc++-1b614e01.so.6.0.32 → libstdc++-1f1a71be.so.6.0.33} +0 -0
  580. scipy/_lib/array_api_extra/_funcs.py +0 -484
  581. scipy/_lib/array_api_extra/_typing.py +0 -8
  582. scipy/interpolate/_bspl.cpython-312-aarch64-linux-musl.so +0 -0
  583. scipy/optimize/_cobyla.cpython-312-aarch64-linux-musl.so +0 -0
  584. scipy/optimize/_cython_nnls.cpython-312-aarch64-linux-musl.so +0 -0
  585. scipy/optimize/_slsqp.cpython-312-aarch64-linux-musl.so +0 -0
  586. scipy/spatial/qhull_src/COPYING.txt +0 -38
  587. scipy/special/libsf_error_state.so +0 -0
  588. scipy/special/tests/test_log_softmax.py +0 -109
  589. scipy/special/tests/test_xsf_cuda.py +0 -114
  590. scipy/special/xsf/binom.h +0 -89
  591. scipy/special/xsf/cdflib.h +0 -100
  592. scipy/special/xsf/cephes/airy.h +0 -307
  593. scipy/special/xsf/cephes/besselpoly.h +0 -51
  594. scipy/special/xsf/cephes/beta.h +0 -257
  595. scipy/special/xsf/cephes/cbrt.h +0 -131
  596. scipy/special/xsf/cephes/chbevl.h +0 -85
  597. scipy/special/xsf/cephes/chdtr.h +0 -193
  598. scipy/special/xsf/cephes/const.h +0 -87
  599. scipy/special/xsf/cephes/ellie.h +0 -293
  600. scipy/special/xsf/cephes/ellik.h +0 -251
  601. scipy/special/xsf/cephes/ellpe.h +0 -107
  602. scipy/special/xsf/cephes/ellpk.h +0 -117
  603. scipy/special/xsf/cephes/expn.h +0 -260
  604. scipy/special/xsf/cephes/gamma.h +0 -398
  605. scipy/special/xsf/cephes/hyp2f1.h +0 -596
  606. scipy/special/xsf/cephes/hyperg.h +0 -361
  607. scipy/special/xsf/cephes/i0.h +0 -149
  608. scipy/special/xsf/cephes/i1.h +0 -158
  609. scipy/special/xsf/cephes/igam.h +0 -421
  610. scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
  611. scipy/special/xsf/cephes/igami.h +0 -313
  612. scipy/special/xsf/cephes/j0.h +0 -225
  613. scipy/special/xsf/cephes/j1.h +0 -198
  614. scipy/special/xsf/cephes/jv.h +0 -715
  615. scipy/special/xsf/cephes/k0.h +0 -164
  616. scipy/special/xsf/cephes/k1.h +0 -163
  617. scipy/special/xsf/cephes/kn.h +0 -243
  618. scipy/special/xsf/cephes/lanczos.h +0 -112
  619. scipy/special/xsf/cephes/ndtr.h +0 -275
  620. scipy/special/xsf/cephes/poch.h +0 -85
  621. scipy/special/xsf/cephes/polevl.h +0 -167
  622. scipy/special/xsf/cephes/psi.h +0 -194
  623. scipy/special/xsf/cephes/rgamma.h +0 -111
  624. scipy/special/xsf/cephes/scipy_iv.h +0 -811
  625. scipy/special/xsf/cephes/shichi.h +0 -248
  626. scipy/special/xsf/cephes/sici.h +0 -224
  627. scipy/special/xsf/cephes/sindg.h +0 -221
  628. scipy/special/xsf/cephes/tandg.h +0 -139
  629. scipy/special/xsf/cephes/trig.h +0 -58
  630. scipy/special/xsf/cephes/unity.h +0 -186
  631. scipy/special/xsf/cephes/zeta.h +0 -172
  632. scipy/special/xsf/config.h +0 -304
  633. scipy/special/xsf/digamma.h +0 -205
  634. scipy/special/xsf/error.h +0 -57
  635. scipy/special/xsf/evalpoly.h +0 -47
  636. scipy/special/xsf/expint.h +0 -266
  637. scipy/special/xsf/hyp2f1.h +0 -694
  638. scipy/special/xsf/iv_ratio.h +0 -173
  639. scipy/special/xsf/lambertw.h +0 -150
  640. scipy/special/xsf/loggamma.h +0 -163
  641. scipy/special/xsf/sici.h +0 -200
  642. scipy/special/xsf/tools.h +0 -427
  643. scipy/special/xsf/trig.h +0 -164
  644. scipy/special/xsf/wright_bessel.h +0 -843
  645. scipy/special/xsf/zlog1.h +0 -35
  646. scipy/stats/_mvn.cpython-312-aarch64-linux-musl.so +0 -0
  647. scipy.libs/libgcc_s-7393e603.so.1 +0 -0
  648. scipy.libs/libgfortran-eb933d8e.so.5.0.0 +0 -0
  649. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/WHEEL +0 -0
@@ -1,164 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /* k0.c
6
- *
7
- * Modified Bessel function, third kind, order zero
8
- *
9
- *
10
- *
11
- * SYNOPSIS:
12
- *
13
- * double x, y, k0();
14
- *
15
- * y = k0( x );
16
- *
17
- *
18
- *
19
- * DESCRIPTION:
20
- *
21
- * Returns modified Bessel function of the third kind
22
- * of order zero of the argument.
23
- *
24
- * The range is partitioned into the two intervals [0,8] and
25
- * (8, infinity). Chebyshev polynomial expansions are employed
26
- * in each interval.
27
- *
28
- *
29
- *
30
- * ACCURACY:
31
- *
32
- * Tested at 2000 random points between 0 and 8. Peak absolute
33
- * error (relative when K0 > 1) was 1.46e-14; rms, 4.26e-15.
34
- * Relative error:
35
- * arithmetic domain # trials peak rms
36
- * IEEE 0, 30 30000 1.2e-15 1.6e-16
37
- *
38
- * ERROR MESSAGES:
39
- *
40
- * message condition value returned
41
- * K0 domain x <= 0 INFINITY
42
- *
43
- */
44
- /* k0e()
45
- *
46
- * Modified Bessel function, third kind, order zero,
47
- * exponentially scaled
48
- *
49
- *
50
- *
51
- * SYNOPSIS:
52
- *
53
- * double x, y, k0e();
54
- *
55
- * y = k0e( x );
56
- *
57
- *
58
- *
59
- * DESCRIPTION:
60
- *
61
- * Returns exponentially scaled modified Bessel function
62
- * of the third kind of order zero of the argument.
63
- *
64
- *
65
- *
66
- * ACCURACY:
67
- *
68
- * Relative error:
69
- * arithmetic domain # trials peak rms
70
- * IEEE 0, 30 30000 1.4e-15 1.4e-16
71
- * See k0().
72
- *
73
- */
74
-
75
- /*
76
- * Cephes Math Library Release 2.8: June, 2000
77
- * Copyright 1984, 1987, 2000 by Stephen L. Moshier
78
- */
79
- #pragma once
80
-
81
- #include "../config.h"
82
- #include "../error.h"
83
-
84
- #include "chbevl.h"
85
- #include "i0.h"
86
-
87
- namespace xsf {
88
- namespace cephes {
89
-
90
- namespace detail {
91
- /* Chebyshev coefficients for K0(x) + log(x/2) I0(x)
92
- * in the interval [0,2]. The odd order coefficients are all
93
- * zero; only the even order coefficients are listed.
94
- *
95
- * lim(x->0){ K0(x) + log(x/2) I0(x) } = -EUL.
96
- */
97
-
98
- constexpr double k0_A[] = {1.37446543561352307156E-16, 4.25981614279661018399E-14, 1.03496952576338420167E-11,
99
- 1.90451637722020886025E-9, 2.53479107902614945675E-7, 2.28621210311945178607E-5,
100
- 1.26461541144692592338E-3, 3.59799365153615016266E-2, 3.44289899924628486886E-1,
101
- -5.35327393233902768720E-1};
102
-
103
- /* Chebyshev coefficients for exp(x) sqrt(x) K0(x)
104
- * in the inverted interval [2,infinity].
105
- *
106
- * lim(x->inf){ exp(x) sqrt(x) K0(x) } = sqrt(pi/2).
107
- */
108
- constexpr double k0_B[] = {
109
- 5.30043377268626276149E-18, -1.64758043015242134646E-17, 5.21039150503902756861E-17,
110
- -1.67823109680541210385E-16, 5.51205597852431940784E-16, -1.84859337734377901440E-15,
111
- 6.34007647740507060557E-15, -2.22751332699166985548E-14, 8.03289077536357521100E-14,
112
- -2.98009692317273043925E-13, 1.14034058820847496303E-12, -4.51459788337394416547E-12,
113
- 1.85594911495471785253E-11, -7.95748924447710747776E-11, 3.57739728140030116597E-10,
114
- -1.69753450938905987466E-9, 8.57403401741422608519E-9, -4.66048989768794782956E-8,
115
- 2.76681363944501510342E-7, -1.83175552271911948767E-6, 1.39498137188764993662E-5,
116
- -1.28495495816278026384E-4, 1.56988388573005337491E-3, -3.14481013119645005427E-2,
117
- 2.44030308206595545468E0};
118
-
119
- } // namespace detail
120
-
121
- XSF_HOST_DEVICE inline double k0(double x) {
122
- double y, z;
123
-
124
- if (x == 0.0) {
125
- set_error("k0", SF_ERROR_SINGULAR, NULL);
126
- return std::numeric_limits<double>::infinity();
127
- } else if (x < 0.0) {
128
- set_error("k0", SF_ERROR_DOMAIN, NULL);
129
- return std::numeric_limits<double>::quiet_NaN();
130
- }
131
-
132
- if (x <= 2.0) {
133
- y = x * x - 2.0;
134
- y = chbevl(y, detail::k0_A, 10) - std::log(0.5 * x) * i0(x);
135
- return (y);
136
- }
137
- z = 8.0 / x - 2.0;
138
- y = std::exp(-x) * chbevl(z, detail::k0_B, 25) / std::sqrt(x);
139
- return (y);
140
- }
141
-
142
- XSF_HOST_DEVICE double inline k0e(double x) {
143
- double y;
144
-
145
- if (x == 0.0) {
146
- set_error("k0e", SF_ERROR_SINGULAR, NULL);
147
- return std::numeric_limits<double>::infinity();
148
- } else if (x < 0.0) {
149
- set_error("k0e", SF_ERROR_DOMAIN, NULL);
150
- return std::numeric_limits<double>::quiet_NaN();
151
- }
152
-
153
- if (x <= 2.0) {
154
- y = x * x - 2.0;
155
- y = chbevl(y, detail::k0_A, 10) - std::log(0.5 * x) * i0(x);
156
- return (y * exp(x));
157
- }
158
-
159
- y = chbevl(8.0 / x - 2.0, detail::k0_B, 25) / std::sqrt(x);
160
- return (y);
161
- }
162
-
163
- } // namespace cephes
164
- } // namespace xsf
@@ -1,163 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /* k1.c
6
- *
7
- * Modified Bessel function, third kind, order one
8
- *
9
- *
10
- *
11
- * SYNOPSIS:
12
- *
13
- * double x, y, k1();
14
- *
15
- * y = k1( x );
16
- *
17
- *
18
- *
19
- * DESCRIPTION:
20
- *
21
- * Computes the modified Bessel function of the third kind
22
- * of order one of the argument.
23
- *
24
- * The range is partitioned into the two intervals [0,2] and
25
- * (2, infinity). Chebyshev polynomial expansions are employed
26
- * in each interval.
27
- *
28
- *
29
- *
30
- * ACCURACY:
31
- *
32
- * Relative error:
33
- * arithmetic domain # trials peak rms
34
- * IEEE 0, 30 30000 1.2e-15 1.6e-16
35
- *
36
- * ERROR MESSAGES:
37
- *
38
- * message condition value returned
39
- * k1 domain x <= 0 INFINITY
40
- *
41
- */
42
- /* k1e.c
43
- *
44
- * Modified Bessel function, third kind, order one,
45
- * exponentially scaled
46
- *
47
- *
48
- *
49
- * SYNOPSIS:
50
- *
51
- * double x, y, k1e();
52
- *
53
- * y = k1e( x );
54
- *
55
- *
56
- *
57
- * DESCRIPTION:
58
- *
59
- * Returns exponentially scaled modified Bessel function
60
- * of the third kind of order one of the argument:
61
- *
62
- * k1e(x) = exp(x) * k1(x).
63
- *
64
- *
65
- *
66
- * ACCURACY:
67
- *
68
- * Relative error:
69
- * arithmetic domain # trials peak rms
70
- * IEEE 0, 30 30000 7.8e-16 1.2e-16
71
- * See k1().
72
- *
73
- */
74
-
75
- /*
76
- * Cephes Math Library Release 2.8: June, 2000
77
- * Copyright 1984, 1987, 2000 by Stephen L. Moshier
78
- */
79
- #pragma once
80
-
81
- #include "../config.h"
82
- #include "../error.h"
83
-
84
- #include "chbevl.h"
85
- #include "const.h"
86
-
87
- namespace xsf {
88
- namespace cephes {
89
-
90
- namespace detail {
91
- /* Chebyshev coefficients for x(K1(x) - log(x/2) I1(x))
92
- * in the interval [0,2].
93
- *
94
- * lim(x->0){ x(K1(x) - log(x/2) I1(x)) } = 1.
95
- */
96
-
97
- constexpr double k1_A[] = {
98
- -7.02386347938628759343E-18, -2.42744985051936593393E-15, -6.66690169419932900609E-13,
99
- -1.41148839263352776110E-10, -2.21338763073472585583E-8, -2.43340614156596823496E-6,
100
- -1.73028895751305206302E-4, -6.97572385963986435018E-3, -1.22611180822657148235E-1,
101
- -3.53155960776544875667E-1, 1.52530022733894777053E0};
102
-
103
- /* Chebyshev coefficients for exp(x) sqrt(x) K1(x)
104
- * in the interval [2,infinity].
105
- *
106
- * lim(x->inf){ exp(x) sqrt(x) K1(x) } = sqrt(pi/2).
107
- */
108
- constexpr double k1_B[] = {
109
- -5.75674448366501715755E-18, 1.79405087314755922667E-17, -5.68946255844285935196E-17,
110
- 1.83809354436663880070E-16, -6.05704724837331885336E-16, 2.03870316562433424052E-15,
111
- -7.01983709041831346144E-15, 2.47715442448130437068E-14, -8.97670518232499435011E-14,
112
- 3.34841966607842919884E-13, -1.28917396095102890680E-12, 5.13963967348173025100E-12,
113
- -2.12996783842756842877E-11, 9.21831518760500529508E-11, -4.19035475934189648750E-10,
114
- 2.01504975519703286596E-9, -1.03457624656780970260E-8, 5.74108412545004946722E-8,
115
- -3.50196060308781257119E-7, 2.40648494783721712015E-6, -1.93619797416608296024E-5,
116
- 1.95215518471351631108E-4, -2.85781685962277938680E-3, 1.03923736576817238437E-1,
117
- 2.72062619048444266945E0};
118
-
119
- } // namespace detail
120
-
121
- XSF_HOST_DEVICE inline double k1(double x) {
122
- double y, z;
123
-
124
- if (x == 0.0) {
125
- set_error("k1", SF_ERROR_SINGULAR, NULL);
126
- return std::numeric_limits<double>::infinity();
127
- } else if (x < 0.0) {
128
- set_error("k1", SF_ERROR_DOMAIN, NULL);
129
- return std::numeric_limits<double>::quiet_NaN();
130
- }
131
- z = 0.5 * x;
132
-
133
- if (x <= 2.0) {
134
- y = x * x - 2.0;
135
- y = std::log(z) * i1(x) + chbevl(y, detail::k1_A, 11) / x;
136
- return (y);
137
- }
138
-
139
- return (std::exp(-x) * chbevl(8.0 / x - 2.0, detail::k1_B, 25) / std::sqrt(x));
140
- }
141
-
142
- XSF_HOST_DEVICE double k1e(double x) {
143
- double y;
144
-
145
- if (x == 0.0) {
146
- set_error("k1e", SF_ERROR_SINGULAR, NULL);
147
- return std::numeric_limits<double>::infinity();
148
- } else if (x < 0.0) {
149
- set_error("k1e", SF_ERROR_DOMAIN, NULL);
150
- return std::numeric_limits<double>::quiet_NaN();
151
- }
152
-
153
- if (x <= 2.0) {
154
- y = x * x - 2.0;
155
- y = std::log(0.5 * x) * i1(x) + chbevl(y, detail::k1_A, 11) / x;
156
- return (y * exp(x));
157
- }
158
-
159
- return (chbevl(8.0 / x - 2.0, detail::k1_B, 25) / std::sqrt(x));
160
- }
161
-
162
- } // namespace cephes
163
- } // namespace xsf
@@ -1,243 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /* kn.c
6
- *
7
- * Modified Bessel function, third kind, integer order
8
- *
9
- *
10
- *
11
- * SYNOPSIS:
12
- *
13
- * double x, y, kn();
14
- * int n;
15
- *
16
- * y = kn( n, x );
17
- *
18
- *
19
- *
20
- * DESCRIPTION:
21
- *
22
- * Returns modified Bessel function of the third kind
23
- * of order n of the argument.
24
- *
25
- * The range is partitioned into the two intervals [0,9.55] and
26
- * (9.55, infinity). An ascending power series is used in the
27
- * low range, and an asymptotic expansion in the high range.
28
- *
29
- *
30
- *
31
- * ACCURACY:
32
- *
33
- * Relative error:
34
- * arithmetic domain # trials peak rms
35
- * IEEE 0,30 90000 1.8e-8 3.0e-10
36
- *
37
- * Error is high only near the crossover point x = 9.55
38
- * between the two expansions used.
39
- */
40
-
41
- /*
42
- * Cephes Math Library Release 2.8: June, 2000
43
- * Copyright 1984, 1987, 1988, 2000 by Stephen L. Moshier
44
- */
45
-
46
- /*
47
- * Algorithm for Kn.
48
- * n-1
49
- * -n - (n-k-1)! 2 k
50
- * K (x) = 0.5 (x/2) > -------- (-x /4)
51
- * n - k!
52
- * k=0
53
- *
54
- * inf. 2 k
55
- * n n - (x /4)
56
- * + (-1) 0.5(x/2) > {p(k+1) + p(n+k+1) - 2log(x/2)} ---------
57
- * - k! (n+k)!
58
- * k=0
59
- *
60
- * where p(m) is the psi function: p(1) = -EUL and
61
- *
62
- * m-1
63
- * -
64
- * p(m) = -EUL + > 1/k
65
- * -
66
- * k=1
67
- *
68
- * For large x,
69
- * 2 2 2
70
- * u-1 (u-1 )(u-3 )
71
- * K (z) = sqrt(pi/2z) exp(-z) { 1 + ------- + ------------ + ...}
72
- * v 1 2
73
- * 1! (8z) 2! (8z)
74
- * asymptotically, where
75
- *
76
- * 2
77
- * u = 4 v .
78
- *
79
- */
80
- #pragma once
81
-
82
- #include "../config.h"
83
- #include "../error.h"
84
-
85
- #include "const.h"
86
-
87
- namespace xsf {
88
- namespace cephes {
89
-
90
- namespace detail {
91
-
92
- constexpr int kn_MAXFAC = 31;
93
-
94
- }
95
-
96
- XSF_HOST_DEVICE inline double kn(int nn, double x) {
97
- double k, kf, nk1f, nkf, zn, t, s, z0, z;
98
- double ans, fn, pn, pk, zmn, tlg, tox;
99
- int i, n;
100
-
101
- if (nn < 0)
102
- n = -nn;
103
- else
104
- n = nn;
105
-
106
- if (n > detail::kn_MAXFAC) {
107
- overf:
108
- set_error("kn", SF_ERROR_OVERFLOW, NULL);
109
- return (std::numeric_limits<double>::infinity());
110
- }
111
-
112
- if (x <= 0.0) {
113
- if (x < 0.0) {
114
- set_error("kn", SF_ERROR_DOMAIN, NULL);
115
- return std::numeric_limits<double>::quiet_NaN();
116
- } else {
117
- set_error("kn", SF_ERROR_SINGULAR, NULL);
118
- return std::numeric_limits<double>::infinity();
119
- }
120
- }
121
-
122
- if (x > 9.55)
123
- goto asymp;
124
-
125
- ans = 0.0;
126
- z0 = 0.25 * x * x;
127
- fn = 1.0;
128
- pn = 0.0;
129
- zmn = 1.0;
130
- tox = 2.0 / x;
131
-
132
- if (n > 0) {
133
- /* compute factorial of n and psi(n) */
134
- pn = -detail::SCIPY_EULER;
135
- k = 1.0;
136
- for (i = 1; i < n; i++) {
137
- pn += 1.0 / k;
138
- k += 1.0;
139
- fn *= k;
140
- }
141
-
142
- zmn = tox;
143
-
144
- if (n == 1) {
145
- ans = 1.0 / x;
146
- } else {
147
- nk1f = fn / n;
148
- kf = 1.0;
149
- s = nk1f;
150
- z = -z0;
151
- zn = 1.0;
152
- for (i = 1; i < n; i++) {
153
- nk1f = nk1f / (n - i);
154
- kf = kf * i;
155
- zn *= z;
156
- t = nk1f * zn / kf;
157
- s += t;
158
- if ((std::numeric_limits<double>::max() - std::abs(t)) < std::abs(s)) {
159
- goto overf;
160
- }
161
- if ((tox > 1.0) && ((std::numeric_limits<double>::max() / tox) < zmn)) {
162
- goto overf;
163
- }
164
- zmn *= tox;
165
- }
166
- s *= 0.5;
167
- t = std::abs(s);
168
- if ((zmn > 1.0) && ((std::numeric_limits<double>::max() / zmn) < t)) {
169
- goto overf;
170
- }
171
- if ((t > 1.0) && ((std::numeric_limits<double>::max() / t) < zmn)) {
172
- goto overf;
173
- }
174
- ans = s * zmn;
175
- }
176
- }
177
-
178
- tlg = 2.0 * log(0.5 * x);
179
- pk = -detail::SCIPY_EULER;
180
- if (n == 0) {
181
- pn = pk;
182
- t = 1.0;
183
- } else {
184
- pn = pn + 1.0 / n;
185
- t = 1.0 / fn;
186
- }
187
- s = (pk + pn - tlg) * t;
188
- k = 1.0;
189
- do {
190
- t *= z0 / (k * (k + n));
191
- pk += 1.0 / k;
192
- pn += 1.0 / (k + n);
193
- s += (pk + pn - tlg) * t;
194
- k += 1.0;
195
- } while (fabs(t / s) > detail::MACHEP);
196
-
197
- s = 0.5 * s / zmn;
198
- if (n & 1) {
199
- s = -s;
200
- }
201
- ans += s;
202
-
203
- return (ans);
204
-
205
- /* Asymptotic expansion for Kn(x) */
206
- /* Converges to 1.4e-17 for x > 18.4 */
207
-
208
- asymp:
209
-
210
- if (x > detail::MAXLOG) {
211
- set_error("kn", SF_ERROR_UNDERFLOW, NULL);
212
- return (0.0);
213
- }
214
- k = n;
215
- pn = 4.0 * k * k;
216
- pk = 1.0;
217
- z0 = 8.0 * x;
218
- fn = 1.0;
219
- t = 1.0;
220
- s = t;
221
- nkf = std::numeric_limits<double>::infinity();
222
- i = 0;
223
- do {
224
- z = pn - pk * pk;
225
- t = t * z / (fn * z0);
226
- nk1f = std::abs(t);
227
- if ((i >= n) && (nk1f > nkf)) {
228
- goto adone;
229
- }
230
- nkf = nk1f;
231
- s += t;
232
- fn += 1.0;
233
- pk += 2.0;
234
- i += 1;
235
- } while (std::abs(t / s) > detail::MACHEP);
236
-
237
- adone:
238
- ans = std::exp(-x) * std::sqrt(M_PI / (2.0 * x)) * s;
239
- return (ans);
240
- }
241
-
242
- } // namespace cephes
243
- } // namespace xsf
@@ -1,112 +0,0 @@
1
- /* (C) Copyright John Maddock 2006.
2
- * Use, modification and distribution are subject to the
3
- * Boost Software License, Version 1.0. (See accompanying file
4
- * LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt)
5
- */
6
-
7
- /* Both lanczos.h and lanczos.c were formed from Boost's lanczos.hpp
8
- *
9
- * Scipy changes:
10
- * - 06-22-2016: Removed all code not related to double precision and
11
- * ported to c for use in Cephes. Note that the order of the
12
- * coefficients is reversed to match the behavior of polevl.
13
- */
14
-
15
- /*
16
- * Optimal values for G for each N are taken from
17
- * https://web.viu.ca/pughg/phdThesis/phdThesis.pdf,
18
- * as are the theoretical error bounds.
19
- *
20
- * Constants calculated using the method described by Godfrey
21
- * https://my.fit.edu/~gabdo/gamma.txt and elaborated by Toth at
22
- * https://www.rskey.org/gamma.htm using NTL::RR at 1000 bit precision.
23
- */
24
-
25
- /*
26
- * Lanczos Coefficients for N=13 G=6.024680040776729583740234375
27
- * Max experimental error (with arbitrary precision arithmetic) 1.196214e-17
28
- * Generated with compiler: Microsoft Visual C++ version 8.0 on Win32 at Mar 23 2006
29
- *
30
- * Use for double precision.
31
- */
32
-
33
- #pragma once
34
-
35
- #include "../config.h"
36
- #include "polevl.h"
37
-
38
- namespace xsf {
39
- namespace cephes {
40
-
41
- namespace detail {
42
-
43
- constexpr double lanczos_num[] = {
44
- 2.506628274631000270164908177133837338626, 210.8242777515793458725097339207133627117,
45
- 8071.672002365816210638002902272250613822, 186056.2653952234950402949897160456992822,
46
- 2876370.628935372441225409051620849613599, 31426415.58540019438061423162831820536287,
47
- 248874557.8620541565114603864132294232163, 1439720407.311721673663223072794912393972,
48
- 6039542586.35202800506429164430729792107, 17921034426.03720969991975575445893111267,
49
- 35711959237.35566804944018545154716670596, 42919803642.64909876895789904700198885093,
50
- 23531376880.41075968857200767445163675473};
51
-
52
- constexpr double lanczos_denom[] = {1, 66, 1925, 32670, 357423, 2637558, 13339535,
53
- 45995730, 105258076, 150917976, 120543840, 39916800, 0};
54
-
55
- constexpr double lanczos_sum_expg_scaled_num[] = {
56
- 0.006061842346248906525783753964555936883222, 0.5098416655656676188125178644804694509993,
57
- 19.51992788247617482847860966235652136208, 449.9445569063168119446858607650988409623,
58
- 6955.999602515376140356310115515198987526, 75999.29304014542649875303443598909137092,
59
- 601859.6171681098786670226533699352302507, 3481712.15498064590882071018964774556468,
60
- 14605578.08768506808414169982791359218571, 43338889.32467613834773723740590533316085,
61
- 86363131.28813859145546927288977868422342, 103794043.1163445451906271053616070238554,
62
- 56906521.91347156388090791033559122686859};
63
-
64
- constexpr double lanczos_sum_expg_scaled_denom[] = {
65
- 1, 66, 1925, 32670, 357423, 2637558, 13339535, 45995730, 105258076, 150917976, 120543840, 39916800, 0};
66
-
67
- constexpr double lanczos_sum_near_1_d[] = {
68
- 0.3394643171893132535170101292240837927725e-9, -0.2499505151487868335680273909354071938387e-8,
69
- 0.8690926181038057039526127422002498960172e-8, -0.1933117898880828348692541394841204288047e-7,
70
- 0.3075580174791348492737947340039992829546e-7, -0.2752907702903126466004207345038327818713e-7,
71
- -0.1515973019871092388943437623825208095123e-5, 0.004785200610085071473880915854204301886437,
72
- -0.1993758927614728757314233026257810172008, 1.483082862367253753040442933770164111678,
73
- -3.327150580651624233553677113928873034916, 2.208709979316623790862569924861841433016};
74
-
75
- constexpr double lanczos_sum_near_2_d[] = {
76
- 0.1009141566987569892221439918230042368112e-8, -0.7430396708998719707642735577238449585822e-8,
77
- 0.2583592566524439230844378948704262291927e-7, -0.5746670642147041587497159649318454348117e-7,
78
- 0.9142922068165324132060550591210267992072e-7, -0.8183698410724358930823737982119474130069e-7,
79
- -0.4506604409707170077136555010018549819192e-5, 0.01422519127192419234315002746252160965831,
80
- -0.5926941084905061794445733628891024027949, 4.408830289125943377923077727900630927902,
81
- -9.8907772644920670589288081640128194231, 6.565936202082889535528455955485877361223};
82
-
83
- XSF_HOST_DEVICE double lanczos_sum(double x) { return ratevl(x, lanczos_num, 12, lanczos_denom, 12); }
84
-
85
- XSF_HOST_DEVICE double lanczos_sum_near_1(double dx) {
86
- double result = 0;
87
- unsigned k;
88
-
89
- for (k = 1; k <= 12; ++k) {
90
- result += (-lanczos_sum_near_1_d[k - 1] * dx) / (k * dx + k * k);
91
- }
92
- return result;
93
- }
94
-
95
- XSF_HOST_DEVICE double lanczos_sum_near_2(double dx) {
96
- double result = 0;
97
- double x = dx + 2;
98
- unsigned k;
99
-
100
- for (k = 1; k <= 12; ++k) {
101
- result += (-lanczos_sum_near_2_d[k - 1] * dx) / (x + k * x + k * k - 1);
102
- }
103
- return result;
104
- }
105
- } // namespace detail
106
-
107
- constexpr double lanczos_g = 6.024680040776729583740234375;
108
- XSF_HOST_DEVICE double lanczos_sum_expg_scaled(double x) {
109
- return ratevl(x, detail::lanczos_sum_expg_scaled_num, 12, detail::lanczos_sum_expg_scaled_denom, 12);
110
- }
111
- } // namespace cephes
112
- } // namespace xsf