scipy 1.15.2__cp313-cp313t-macosx_14_0_arm64.whl → 1.16.0rc1__cp313-cp313t-macosx_14_0_arm64.whl

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