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