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