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,87 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- *
4
- * Since we support only IEEE-754 floating point numbers, conditional logic
5
- * supporting other arithmetic types has been removed.
6
- */
7
-
8
- /*
9
- *
10
- *
11
- * const.c
12
- *
13
- * Globally declared constants
14
- *
15
- *
16
- *
17
- * SYNOPSIS:
18
- *
19
- * extern double nameofconstant;
20
- *
21
- *
22
- *
23
- *
24
- * DESCRIPTION:
25
- *
26
- * This file contains a number of mathematical constants and
27
- * also some needed size parameters of the computer arithmetic.
28
- * The values are supplied as arrays of hexadecimal integers
29
- * for IEEE arithmetic, and in a normal decimal scientific notation for
30
- * other machines. The particular notation used is determined
31
- * by a symbol (IBMPC, or UNK) defined in the include file
32
- * mconf.h.
33
- *
34
- * The default size parameters are as follows.
35
- *
36
- * For UNK mode:
37
- * MACHEP = 1.38777878078144567553E-17 2**-56
38
- * MAXLOG = 8.8029691931113054295988E1 log(2**127)
39
- * MINLOG = -8.872283911167299960540E1 log(2**-128)
40
- *
41
- * For IEEE arithmetic (IBMPC):
42
- * MACHEP = 1.11022302462515654042E-16 2**-53
43
- * MAXLOG = 7.09782712893383996843E2 log(2**1024)
44
- * MINLOG = -7.08396418532264106224E2 log(2**-1022)
45
- *
46
- * The global symbols for mathematical constants are
47
- * SQ2OPI = 7.9788456080286535587989E-1 sqrt( 2/pi )
48
- * LOGSQ2 = 3.46573590279972654709E-1 log(2)/2
49
- * THPIO4 = 2.35619449019234492885 3*pi/4
50
- *
51
- * These lists are subject to change.
52
- */
53
- /* const.c */
54
-
55
- /*
56
- * Cephes Math Library Release 2.3: March, 1995
57
- * Copyright 1984, 1995 by Stephen L. Moshier
58
- */
59
- #pragma once
60
-
61
- namespace xsf {
62
- namespace cephes {
63
- namespace detail {
64
- constexpr std::uint64_t MAXITER = 500;
65
- constexpr double MACHEP = 1.11022302462515654042E-16; // 2**-53
66
- constexpr double MAXLOG = 7.09782712893383996732E2; // log(DBL_MAX)
67
- constexpr double MINLOG = -7.451332191019412076235E2; // log 2**-1022
68
- constexpr double SQRT1OPI = 5.64189583547756286948E-1; // sqrt( 1/pi)
69
- constexpr double SQRT2OPI = 7.9788456080286535587989E-1; // sqrt( 2/pi )
70
- constexpr double SQRT2PI = 0.79788456080286535587989; // sqrt(2pi)
71
- constexpr double LOGSQ2 = 3.46573590279972654709E-1; // log(2)/2
72
- constexpr double THPIO4 = 2.35619449019234492885; // 3*pi/4
73
- constexpr double SQRT3 = 1.732050807568877293527; // sqrt(3)
74
- constexpr double PI180 = 1.74532925199432957692E-2; // pi/180
75
- constexpr double SQRTPI = 2.50662827463100050242E0; // sqrt(pi)
76
- constexpr double LOGPI = 1.14472988584940017414; // log(pi)
77
- constexpr double MAXGAM = 171.624376956302725;
78
- constexpr double LOGSQRT2PI = 0.9189385332046727; // log(sqrt(pi))
79
-
80
- // Following two added by SciPy developers.
81
- // Euler's constant
82
- constexpr double SCIPY_EULER = 0.577215664901532860606512090082402431;
83
- // e as long double
84
- constexpr long double SCIPY_El = 2.718281828459045235360287471352662498L;
85
- } // namespace detail
86
- } // namespace cephes
87
- } // namespace xsf
@@ -1,293 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /* ellie.c
6
- *
7
- * Incomplete elliptic integral of the second kind
8
- *
9
- *
10
- *
11
- * SYNOPSIS:
12
- *
13
- * double phi, m, y, ellie();
14
- *
15
- * y = ellie( phi, m );
16
- *
17
- *
18
- *
19
- * DESCRIPTION:
20
- *
21
- * Approximates the integral
22
- *
23
- *
24
- * phi
25
- * -
26
- * | |
27
- * | 2
28
- * E(phi_\m) = | sqrt( 1 - m sin t ) dt
29
- * |
30
- * | |
31
- * -
32
- * 0
33
- *
34
- * of amplitude phi and modulus m, using the arithmetic -
35
- * geometric mean algorithm.
36
- *
37
- *
38
- *
39
- * ACCURACY:
40
- *
41
- * Tested at random arguments with phi in [-10, 10] and m in
42
- * [0, 1].
43
- * Relative error:
44
- * arithmetic domain # trials peak rms
45
- * IEEE -10,10 150000 3.3e-15 1.4e-16
46
- */
47
-
48
- /*
49
- * Cephes Math Library Release 2.0: April, 1987
50
- * Copyright 1984, 1987, 1993 by Stephen L. Moshier
51
- * Direct inquiries to 30 Frost Street, Cambridge, MA 02140
52
- */
53
- /* Copyright 2014, Eric W. Moore */
54
-
55
- /* Incomplete elliptic integral of second kind */
56
- #pragma once
57
-
58
- #include "../config.h"
59
- #include "const.h"
60
- #include "ellpe.h"
61
- #include "ellpk.h"
62
- #include "unity.h"
63
-
64
- namespace xsf {
65
- namespace cephes {
66
- namespace detail {
67
-
68
- /* To calculate legendre's incomplete elliptical integral of the second kind for
69
- * negative m, we use a power series in phi for small m*phi*phi, an asymptotic
70
- * series in m for large m*phi*phi* and the relation to Carlson's symmetric
71
- * integrals, R_F(x,y,z) and R_D(x,y,z).
72
- *
73
- * E(phi, m) = sin(phi) * R_F(cos(phi)^2, 1 - m * sin(phi)^2, 1.0)
74
- * - m * sin(phi)^3 * R_D(cos(phi)^2, 1 - m * sin(phi)^2, 1.0) / 3
75
- *
76
- * = R_F(c-1, c-m, c) - m * R_D(c-1, c-m, c) / 3
77
- *
78
- * where c = csc(phi)^2. We use the second form of this for (approximately)
79
- * phi > 1/(sqrt(DBL_MAX) ~ 1e-154, where csc(phi)^2 overflows. Elsewhere we
80
- * use the first form, accounting for the smallness of phi.
81
- *
82
- * The algorithm used is described in Carlson, B. C. Numerical computation of
83
- * real or complex elliptic integrals. (1994) https://arxiv.org/abs/math/9409227
84
- * Most variable names reflect Carlson's usage.
85
- *
86
- * In this routine, we assume m < 0 and 0 > phi > pi/2.
87
- */
88
- XSF_HOST_DEVICE inline double ellie_neg_m(double phi, double m) {
89
- double x, y, z, x1, y1, z1, ret, Q;
90
- double A0f, Af, Xf, Yf, Zf, E2f, E3f, scalef;
91
- double A0d, Ad, seriesn, seriesd, Xd, Yd, Zd, E2d, E3d, E4d, E5d, scaled;
92
- int n = 0;
93
- double mpp = (m * phi) * phi;
94
-
95
- if (-mpp < 1e-6 && phi < -m) {
96
- return phi + (mpp * phi * phi / 30.0 - mpp * mpp / 40.0 - mpp / 6.0) * phi;
97
- }
98
-
99
- if (-mpp > 1e6) {
100
- double sm = std::sqrt(-m);
101
- double sp = std::sin(phi);
102
- double cp = std::cos(phi);
103
-
104
- double a = -cosm1(phi);
105
- double b1 = std::log(4 * sp * sm / (1 + cp));
106
- double b = -(0.5 + b1) / 2.0 / m;
107
- double c = (0.75 + cp / sp / sp - b1) / 16.0 / m / m;
108
- return (a + b + c) * sm;
109
- }
110
-
111
- if (phi > 1e-153 && m > -1e200) {
112
- double s = std::sin(phi);
113
- double csc2 = 1.0 / s / s;
114
- scalef = 1.0;
115
- scaled = m / 3.0;
116
- x = 1.0 / std::tan(phi) / std::tan(phi);
117
- y = csc2 - m;
118
- z = csc2;
119
- } else {
120
- scalef = phi;
121
- scaled = mpp * phi / 3.0;
122
- x = 1.0;
123
- y = 1 - mpp;
124
- z = 1.0;
125
- }
126
-
127
- if (x == y && x == z) {
128
- return (scalef + scaled / x) / std::sqrt(x);
129
- }
130
-
131
- A0f = (x + y + z) / 3.0;
132
- Af = A0f;
133
- A0d = (x + y + 3.0 * z) / 5.0;
134
- Ad = A0d;
135
- x1 = x;
136
- y1 = y;
137
- z1 = z;
138
- seriesd = 0.0;
139
- seriesn = 1.0;
140
- /* Carlson gives 1/pow(3*r, 1.0/6.0) for this constant. if r == eps,
141
- * it is ~338.38. */
142
-
143
- /* N.B. This will evaluate its arguments multiple times. */
144
- Q = 400.0 * std::fmax(std::abs(A0f - x), std::fmax(std::abs(A0f - y), std::abs(A0f - z)));
145
-
146
- while (Q > std::abs(Af) && Q > std::abs(Ad) && n <= 100) {
147
- double sx = std::sqrt(x1);
148
- double sy = std::sqrt(y1);
149
- double sz = std::sqrt(z1);
150
- double lam = sx * sy + sx * sz + sy * sz;
151
- seriesd += seriesn / (sz * (z1 + lam));
152
- x1 = (x1 + lam) / 4.0;
153
- y1 = (y1 + lam) / 4.0;
154
- z1 = (z1 + lam) / 4.0;
155
- Af = (x1 + y1 + z1) / 3.0;
156
- Ad = (Ad + lam) / 4.0;
157
- n += 1;
158
- Q /= 4.0;
159
- seriesn /= 4.0;
160
- }
161
-
162
- Xf = (A0f - x) / Af / (1 << 2 * n);
163
- Yf = (A0f - y) / Af / (1 << 2 * n);
164
- Zf = -(Xf + Yf);
165
-
166
- E2f = Xf * Yf - Zf * Zf;
167
- E3f = Xf * Yf * Zf;
168
-
169
- ret = scalef * (1.0 - E2f / 10.0 + E3f / 14.0 + E2f * E2f / 24.0 - 3.0 * E2f * E3f / 44.0) / sqrt(Af);
170
-
171
- Xd = (A0d - x) / Ad / (1 << 2 * n);
172
- Yd = (A0d - y) / Ad / (1 << 2 * n);
173
- Zd = -(Xd + Yd) / 3.0;
174
-
175
- E2d = Xd * Yd - 6.0 * Zd * Zd;
176
- E3d = (3 * Xd * Yd - 8.0 * Zd * Zd) * Zd;
177
- E4d = 3.0 * (Xd * Yd - Zd * Zd) * Zd * Zd;
178
- E5d = Xd * Yd * Zd * Zd * Zd;
179
-
180
- ret -= scaled *
181
- (1.0 - 3.0 * E2d / 14.0 + E3d / 6.0 + 9.0 * E2d * E2d / 88.0 - 3.0 * E4d / 22.0 -
182
- 9.0 * E2d * E3d / 52.0 + 3.0 * E5d / 26.0) /
183
- (1 << 2 * n) / Ad / sqrt(Ad);
184
- ret -= 3.0 * scaled * seriesd;
185
- return ret;
186
- }
187
-
188
- } // namespace detail
189
-
190
- XSF_HOST_DEVICE inline double ellie(double phi, double m) {
191
- double a, b, c, e, temp;
192
- double lphi, t, E, denom, npio2;
193
- int d, mod, sign;
194
-
195
- if (std::isnan(phi) || std::isnan(m))
196
- return std::numeric_limits<double>::quiet_NaN();
197
- if (m > 1.0)
198
- return std::numeric_limits<double>::quiet_NaN();
199
- ;
200
- if (std::isinf(phi))
201
- return phi;
202
- if (std::isinf(m))
203
- return -m;
204
- if (m == 0.0)
205
- return (phi);
206
- lphi = phi;
207
- npio2 = std::floor(lphi / M_PI_2);
208
- if (std::fmod(std::abs(npio2), 2.0) == 1.0)
209
- npio2 += 1;
210
- lphi = lphi - npio2 * M_PI_2;
211
- if (lphi < 0.0) {
212
- lphi = -lphi;
213
- sign = -1;
214
- } else {
215
- sign = 1;
216
- }
217
- a = 1.0 - m;
218
- E = ellpe(m);
219
- if (a == 0.0) {
220
- temp = std::sin(lphi);
221
- goto done;
222
- }
223
- if (a > 1.0) {
224
- temp = detail::ellie_neg_m(lphi, m);
225
- goto done;
226
- }
227
-
228
- if (lphi < 0.135) {
229
- double m11 = (((((-7.0 / 2816.0) * m + (5.0 / 1056.0)) * m - (7.0 / 2640.0)) * m + (17.0 / 41580.0)) * m -
230
- (1.0 / 155925.0)) *
231
- m;
232
- double m9 = ((((-5.0 / 1152.0) * m + (1.0 / 144.0)) * m - (1.0 / 360.0)) * m + (1.0 / 5670.0)) * m;
233
- double m7 = ((-m / 112.0 + (1.0 / 84.0)) * m - (1.0 / 315.0)) * m;
234
- double m5 = (-m / 40.0 + (1.0 / 30)) * m;
235
- double m3 = -m / 6.0;
236
- double p2 = lphi * lphi;
237
-
238
- temp = ((((m11 * p2 + m9) * p2 + m7) * p2 + m5) * p2 + m3) * p2 * lphi + lphi;
239
- goto done;
240
- }
241
- t = std::tan(lphi);
242
- b = std::sqrt(a);
243
- /* Thanks to Brian Fitzgerald <fitzgb@mml0.meche.rpi.edu>
244
- * for pointing out an instability near odd multiples of pi/2. */
245
- if (std::abs(t) > 10.0) {
246
- /* Transform the amplitude */
247
- e = 1.0 / (b * t);
248
- /* ... but avoid multiple recursions. */
249
- if (std::abs(e) < 10.0) {
250
- e = std::atan(e);
251
- temp = E + m * std::sin(lphi) * std::sin(e) - ellie(e, m);
252
- goto done;
253
- }
254
- }
255
- c = std::sqrt(m);
256
- a = 1.0;
257
- d = 1;
258
- e = 0.0;
259
- mod = 0;
260
-
261
- while (std::abs(c / a) > detail::MACHEP) {
262
- temp = b / a;
263
- lphi = lphi + atan(t * temp) + mod * M_PI;
264
- denom = 1 - temp * t * t;
265
- if (std::abs(denom) > 10 * detail::MACHEP) {
266
- t = t * (1.0 + temp) / denom;
267
- mod = (lphi + M_PI_2) / M_PI;
268
- } else {
269
- t = std::tan(lphi);
270
- mod = static_cast<int>(std::floor((lphi - std::atan(t)) / M_PI));
271
- }
272
- c = (a - b) / 2.0;
273
- temp = std::sqrt(a * b);
274
- a = (a + b) / 2.0;
275
- b = temp;
276
- d += d;
277
- e += c * std::sin(lphi);
278
- }
279
-
280
- temp = E / ellpk(1.0 - m);
281
- temp *= (std::atan(t) + mod * M_PI) / (d * a);
282
- temp += e;
283
-
284
- done:
285
-
286
- if (sign < 0)
287
- temp = -temp;
288
- temp += npio2 * E;
289
- return (temp);
290
- }
291
-
292
- } // namespace cephes
293
- } // namespace xsf
@@ -1,251 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /* ellik.c
6
- *
7
- * Incomplete elliptic integral of the first kind
8
- *
9
- *
10
- *
11
- * SYNOPSIS:
12
- *
13
- * double phi, m, y, ellik();
14
- *
15
- * y = ellik( phi, m );
16
- *
17
- *
18
- *
19
- * DESCRIPTION:
20
- *
21
- * Approximates the integral
22
- *
23
- *
24
- *
25
- * phi
26
- * -
27
- * | |
28
- * | dt
29
- * F(phi | m) = | ------------------
30
- * | 2
31
- * | | sqrt( 1 - m sin t )
32
- * -
33
- * 0
34
- *
35
- * of amplitude phi and modulus m, using the arithmetic -
36
- * geometric mean algorithm.
37
- *
38
- *
39
- *
40
- *
41
- * ACCURACY:
42
- *
43
- * Tested at random points with m in [0, 1] and phi as indicated.
44
- *
45
- * Relative error:
46
- * arithmetic domain # trials peak rms
47
- * IEEE -10,10 200000 7.4e-16 1.0e-16
48
- *
49
- *
50
- */
51
-
52
- /*
53
- * Cephes Math Library Release 2.0: April, 1987
54
- * Copyright 1984, 1987 by Stephen L. Moshier
55
- * Direct inquiries to 30 Frost Street, Cambridge, MA 02140
56
- */
57
- /* Copyright 2014, Eric W. Moore */
58
-
59
- /* Incomplete elliptic integral of first kind */
60
- #pragma once
61
-
62
- #include "../config.h"
63
- #include "../error.h"
64
- #include "const.h"
65
- #include "ellpk.h"
66
-
67
- namespace xsf {
68
- namespace cephes {
69
-
70
- namespace detail {
71
-
72
- /* To calculate legendre's incomplete elliptical integral of the first kind for
73
- * negative m, we use a power series in phi for small m*phi*phi, an asymptotic
74
- * series in m for large m*phi*phi* and the relation to Carlson's symmetric
75
- * integral of the first kind.
76
- *
77
- * F(phi, m) = sin(phi) * R_F(cos(phi)^2, 1 - m * sin(phi)^2, 1.0)
78
- * = R_F(c-1, c-m, c)
79
- *
80
- * where c = csc(phi)^2. We use the second form of this for (approximately)
81
- * phi > 1/(sqrt(DBL_MAX) ~ 1e-154, where csc(phi)^2 overflows. Elsewhere we
82
- * use the first form, accounting for the smallness of phi.
83
- *
84
- * The algorithm used is described in Carlson, B. C. Numerical computation of
85
- * real or complex elliptic integrals. (1994) https://arxiv.org/abs/math/9409227
86
- * Most variable names reflect Carlson's usage.
87
- *
88
- * In this routine, we assume m < 0 and 0 > phi > pi/2.
89
- */
90
- XSF_HOST_DEVICE inline double ellik_neg_m(double phi, double m) {
91
- double x, y, z, x1, y1, z1, A0, A, Q, X, Y, Z, E2, E3, scale;
92
- int n = 0;
93
- double mpp = (m * phi) * phi;
94
-
95
- if (-mpp < 1e-6 && phi < -m) {
96
- return phi + (-mpp * phi * phi / 30.0 + 3.0 * mpp * mpp / 40.0 + mpp / 6.0) * phi;
97
- }
98
-
99
- if (-mpp > 4e7) {
100
- double sm = std::sqrt(-m);
101
- double sp = std::sin(phi);
102
- double cp = std::cos(phi);
103
-
104
- double a = std::log(4 * sp * sm / (1 + cp));
105
- double b = -(1 + cp / sp / sp - a) / 4 / m;
106
- return (a + b) / sm;
107
- }
108
-
109
- if (phi > 1e-153 && m > -1e305) {
110
- double s = std::sin(phi);
111
- double csc2 = 1.0 / (s * s);
112
- scale = 1.0;
113
- x = 1.0 / (std::tan(phi) * std::tan(phi));
114
- y = csc2 - m;
115
- z = csc2;
116
- } else {
117
- scale = phi;
118
- x = 1.0;
119
- y = 1 - m * scale * scale;
120
- z = 1.0;
121
- }
122
-
123
- if (x == y && x == z) {
124
- return scale / std::sqrt(x);
125
- }
126
-
127
- A0 = (x + y + z) / 3.0;
128
- A = A0;
129
- x1 = x;
130
- y1 = y;
131
- z1 = z;
132
- /* Carlson gives 1/pow(3*r, 1.0/6.0) for this constant. if r == eps,
133
- * it is ~338.38. */
134
- Q = 400.0 * std::fmax(std::abs(A0 - x), std::fmax(std::abs(A0 - y), std::abs(A0 - z)));
135
-
136
- while (Q > std::abs(A) && n <= 100) {
137
- double sx = std::sqrt(x1);
138
- double sy = std::sqrt(y1);
139
- double sz = std::sqrt(z1);
140
- double lam = sx * sy + sx * sz + sy * sz;
141
- x1 = (x1 + lam) / 4.0;
142
- y1 = (y1 + lam) / 4.0;
143
- z1 = (z1 + lam) / 4.0;
144
- A = (x1 + y1 + z1) / 3.0;
145
- n += 1;
146
- Q /= 4;
147
- }
148
- X = (A0 - x) / A / (1 << 2 * n);
149
- Y = (A0 - y) / A / (1 << 2 * n);
150
- Z = -(X + Y);
151
-
152
- E2 = X * Y - Z * Z;
153
- E3 = X * Y * Z;
154
-
155
- return scale * (1.0 - E2 / 10.0 + E3 / 14.0 + E2 * E2 / 24.0 - 3.0 * E2 * E3 / 44.0) / sqrt(A);
156
- }
157
-
158
- } // namespace detail
159
-
160
- XSF_HOST_DEVICE inline double ellik(double phi, double m) {
161
- double a, b, c, e, temp, t, K, denom, npio2;
162
- int d, mod, sign;
163
-
164
- if (std::isnan(phi) || std::isnan(m))
165
- return std::numeric_limits<double>::quiet_NaN();
166
- if (m > 1.0)
167
- return std::numeric_limits<double>::quiet_NaN();
168
- if (std::isinf(phi) || std::isinf(m)) {
169
- if (std::isinf(m) && std::isfinite(phi))
170
- return 0.0;
171
- else if (std::isinf(phi) && std::isfinite(m))
172
- return phi;
173
- else
174
- return std::numeric_limits<double>::quiet_NaN();
175
- }
176
- if (m == 0.0)
177
- return (phi);
178
- a = 1.0 - m;
179
- if (a == 0.0) {
180
- if (std::abs(phi) >= (double) M_PI_2) {
181
- set_error("ellik", SF_ERROR_SINGULAR, NULL);
182
- return (std::numeric_limits<double>::infinity());
183
- }
184
- /* DLMF 19.6.8, and 4.23.42 */
185
- return std::asinh(std::tan(phi));
186
- }
187
- npio2 = floor(phi / M_PI_2);
188
- if (std::fmod(std::abs(npio2), 2.0) == 1.0)
189
- npio2 += 1;
190
- if (npio2 != 0.0) {
191
- K = ellpk(a);
192
- phi = phi - npio2 * M_PI_2;
193
- } else
194
- K = 0.0;
195
- if (phi < 0.0) {
196
- phi = -phi;
197
- sign = -1;
198
- } else
199
- sign = 0;
200
- if (a > 1.0) {
201
- temp = detail::ellik_neg_m(phi, m);
202
- goto done;
203
- }
204
- b = std::sqrt(a);
205
- t = std::tan(phi);
206
- if (std::abs(t) > 10.0) {
207
- /* Transform the amplitude */
208
- e = 1.0 / (b * t);
209
- /* ... but avoid multiple recursions. */
210
- if (std::abs(e) < 10.0) {
211
- e = std::atan(e);
212
- if (npio2 == 0)
213
- K = ellpk(a);
214
- temp = K - ellik(e, m);
215
- goto done;
216
- }
217
- }
218
- a = 1.0;
219
- c = std::sqrt(m);
220
- d = 1;
221
- mod = 0;
222
-
223
- while (std::abs(c / a) > detail::MACHEP) {
224
- temp = b / a;
225
- phi = phi + atan(t * temp) + mod * M_PI;
226
- denom = 1.0 - temp * t * t;
227
- if (std::abs(denom) > 10 * detail::MACHEP) {
228
- t = t * (1.0 + temp) / denom;
229
- mod = (phi + M_PI_2) / M_PI;
230
- } else {
231
- t = std::tan(phi);
232
- mod = static_cast<int>(std::floor((phi - std::atan(t)) / M_PI));
233
- }
234
- c = (a - b) / 2.0;
235
- temp = std::sqrt(a * b);
236
- a = (a + b) / 2.0;
237
- b = temp;
238
- d += d;
239
- }
240
-
241
- temp = (std::atan(t) + mod * M_PI) / (d * a);
242
-
243
- done:
244
- if (sign < 0)
245
- temp = -temp;
246
- temp += npio2 * K;
247
- return (temp);
248
- }
249
-
250
- } // namespace cephes
251
- } // namespace xsf