scipy 1.15.2__cp312-cp312-musllinux_1_2_aarch64.whl → 1.16.0rc1__cp312-cp312-musllinux_1_2_aarch64.whl

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