scipy 1.15.3__cp312-cp312-macosx_14_0_arm64.whl → 1.16.0__cp312-cp312-macosx_14_0_arm64.whl

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