scipy 1.15.2__cp311-cp311-macosx_14_0_arm64.whl → 1.16.0rc1__cp311-cp311-macosx_14_0_arm64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (621) hide show
  1. scipy/__config__.py +3 -3
  2. scipy/__init__.py +3 -6
  3. scipy/_cyutility.cpython-311-darwin.so +0 -0
  4. scipy/_lib/_array_api.py +497 -161
  5. scipy/_lib/_array_api_compat_vendor.py +9 -0
  6. scipy/_lib/_bunch.py +4 -0
  7. scipy/_lib/_ccallback_c.cpython-311-darwin.so +0 -0
  8. scipy/_lib/_docscrape.py +1 -1
  9. scipy/_lib/_elementwise_iterative_method.py +15 -26
  10. scipy/_lib/_sparse.py +41 -0
  11. scipy/_lib/_test_ccallback.cpython-311-darwin.so +0 -0
  12. scipy/_lib/_test_deprecation_call.cpython-311-darwin.so +0 -0
  13. scipy/_lib/_test_deprecation_def.cpython-311-darwin.so +0 -0
  14. scipy/_lib/_testutils.py +6 -2
  15. scipy/_lib/_util.py +222 -125
  16. scipy/_lib/array_api_compat/__init__.py +4 -4
  17. scipy/_lib/array_api_compat/_internal.py +19 -6
  18. scipy/_lib/array_api_compat/common/__init__.py +1 -1
  19. scipy/_lib/array_api_compat/common/_aliases.py +365 -193
  20. scipy/_lib/array_api_compat/common/_fft.py +94 -64
  21. scipy/_lib/array_api_compat/common/_helpers.py +413 -180
  22. scipy/_lib/array_api_compat/common/_linalg.py +116 -40
  23. scipy/_lib/array_api_compat/common/_typing.py +179 -10
  24. scipy/_lib/array_api_compat/cupy/__init__.py +1 -4
  25. scipy/_lib/array_api_compat/cupy/_aliases.py +61 -41
  26. scipy/_lib/array_api_compat/cupy/_info.py +16 -6
  27. scipy/_lib/array_api_compat/cupy/_typing.py +24 -39
  28. scipy/_lib/array_api_compat/dask/array/__init__.py +6 -3
  29. scipy/_lib/array_api_compat/dask/array/_aliases.py +267 -108
  30. scipy/_lib/array_api_compat/dask/array/_info.py +105 -34
  31. scipy/_lib/array_api_compat/dask/array/fft.py +5 -8
  32. scipy/_lib/array_api_compat/dask/array/linalg.py +21 -22
  33. scipy/_lib/array_api_compat/numpy/__init__.py +13 -15
  34. scipy/_lib/array_api_compat/numpy/_aliases.py +98 -49
  35. scipy/_lib/array_api_compat/numpy/_info.py +36 -16
  36. scipy/_lib/array_api_compat/numpy/_typing.py +27 -43
  37. scipy/_lib/array_api_compat/numpy/fft.py +11 -5
  38. scipy/_lib/array_api_compat/numpy/linalg.py +75 -22
  39. scipy/_lib/array_api_compat/torch/__init__.py +3 -5
  40. scipy/_lib/array_api_compat/torch/_aliases.py +262 -159
  41. scipy/_lib/array_api_compat/torch/_info.py +27 -16
  42. scipy/_lib/array_api_compat/torch/_typing.py +3 -0
  43. scipy/_lib/array_api_compat/torch/fft.py +17 -18
  44. scipy/_lib/array_api_compat/torch/linalg.py +16 -16
  45. scipy/_lib/array_api_extra/__init__.py +26 -3
  46. scipy/_lib/array_api_extra/_delegation.py +171 -0
  47. scipy/_lib/array_api_extra/_lib/__init__.py +1 -0
  48. scipy/_lib/array_api_extra/_lib/_at.py +463 -0
  49. scipy/_lib/array_api_extra/_lib/_backends.py +46 -0
  50. scipy/_lib/array_api_extra/_lib/_funcs.py +937 -0
  51. scipy/_lib/array_api_extra/_lib/_lazy.py +357 -0
  52. scipy/_lib/array_api_extra/_lib/_testing.py +278 -0
  53. scipy/_lib/array_api_extra/_lib/_utils/__init__.py +1 -0
  54. scipy/_lib/array_api_extra/_lib/_utils/_compat.py +74 -0
  55. scipy/_lib/array_api_extra/_lib/_utils/_compat.pyi +45 -0
  56. scipy/_lib/array_api_extra/_lib/_utils/_helpers.py +559 -0
  57. scipy/_lib/array_api_extra/_lib/_utils/_typing.py +10 -0
  58. scipy/_lib/array_api_extra/_lib/_utils/_typing.pyi +105 -0
  59. scipy/_lib/array_api_extra/testing.py +359 -0
  60. scipy/_lib/decorator.py +2 -2
  61. scipy/_lib/doccer.py +1 -7
  62. scipy/_lib/messagestream.cpython-311-darwin.so +0 -0
  63. scipy/_lib/pyprima/__init__.py +212 -0
  64. scipy/_lib/pyprima/cobyla/__init__.py +0 -0
  65. scipy/_lib/pyprima/cobyla/cobyla.py +559 -0
  66. scipy/_lib/pyprima/cobyla/cobylb.py +714 -0
  67. scipy/_lib/pyprima/cobyla/geometry.py +226 -0
  68. scipy/_lib/pyprima/cobyla/initialize.py +215 -0
  69. scipy/_lib/pyprima/cobyla/trustregion.py +492 -0
  70. scipy/_lib/pyprima/cobyla/update.py +289 -0
  71. scipy/_lib/pyprima/common/__init__.py +0 -0
  72. scipy/_lib/pyprima/common/_bounds.py +34 -0
  73. scipy/_lib/pyprima/common/_linear_constraints.py +46 -0
  74. scipy/_lib/pyprima/common/_nonlinear_constraints.py +54 -0
  75. scipy/_lib/pyprima/common/_project.py +173 -0
  76. scipy/_lib/pyprima/common/checkbreak.py +93 -0
  77. scipy/_lib/pyprima/common/consts.py +47 -0
  78. scipy/_lib/pyprima/common/evaluate.py +99 -0
  79. scipy/_lib/pyprima/common/history.py +38 -0
  80. scipy/_lib/pyprima/common/infos.py +30 -0
  81. scipy/_lib/pyprima/common/linalg.py +435 -0
  82. scipy/_lib/pyprima/common/message.py +290 -0
  83. scipy/_lib/pyprima/common/powalg.py +131 -0
  84. scipy/_lib/pyprima/common/preproc.py +277 -0
  85. scipy/_lib/pyprima/common/present.py +5 -0
  86. scipy/_lib/pyprima/common/ratio.py +54 -0
  87. scipy/_lib/pyprima/common/redrho.py +47 -0
  88. scipy/_lib/pyprima/common/selectx.py +296 -0
  89. scipy/_lib/tests/test__util.py +105 -121
  90. scipy/_lib/tests/test_array_api.py +169 -34
  91. scipy/_lib/tests/test_bunch.py +7 -0
  92. scipy/_lib/tests/test_ccallback.py +2 -10
  93. scipy/_lib/tests/test_public_api.py +13 -0
  94. scipy/cluster/_hierarchy.cpython-311-darwin.so +0 -0
  95. scipy/cluster/_optimal_leaf_ordering.cpython-311-darwin.so +0 -0
  96. scipy/cluster/_vq.cpython-311-darwin.so +0 -0
  97. scipy/cluster/hierarchy.py +393 -223
  98. scipy/cluster/tests/test_hierarchy.py +273 -335
  99. scipy/cluster/tests/test_vq.py +45 -61
  100. scipy/cluster/vq.py +39 -35
  101. scipy/conftest.py +263 -157
  102. scipy/constants/_constants.py +4 -1
  103. scipy/constants/tests/test_codata.py +2 -2
  104. scipy/constants/tests/test_constants.py +11 -18
  105. scipy/datasets/_download_all.py +15 -1
  106. scipy/datasets/_fetchers.py +7 -1
  107. scipy/datasets/_utils.py +1 -1
  108. scipy/differentiate/_differentiate.py +25 -25
  109. scipy/differentiate/tests/test_differentiate.py +24 -25
  110. scipy/fft/_basic.py +20 -0
  111. scipy/fft/_helper.py +3 -34
  112. scipy/fft/_pocketfft/helper.py +29 -1
  113. scipy/fft/_pocketfft/tests/test_basic.py +2 -4
  114. scipy/fft/_pocketfft/tests/test_real_transforms.py +4 -4
  115. scipy/fft/_realtransforms.py +13 -0
  116. scipy/fft/tests/test_basic.py +27 -25
  117. scipy/fft/tests/test_fftlog.py +16 -7
  118. scipy/fft/tests/test_helper.py +18 -34
  119. scipy/fft/tests/test_real_transforms.py +8 -10
  120. scipy/fftpack/convolve.cpython-311-darwin.so +0 -0
  121. scipy/fftpack/tests/test_basic.py +2 -4
  122. scipy/fftpack/tests/test_real_transforms.py +8 -9
  123. scipy/integrate/_bvp.py +9 -3
  124. scipy/integrate/_cubature.py +3 -2
  125. scipy/integrate/_dop.cpython-311-darwin.so +0 -0
  126. scipy/integrate/_ivp/common.py +3 -3
  127. scipy/integrate/_ivp/ivp.py +9 -2
  128. scipy/integrate/_ivp/tests/test_ivp.py +19 -0
  129. scipy/integrate/_lsoda.cpython-311-darwin.so +0 -0
  130. scipy/integrate/_ode.py +9 -2
  131. scipy/integrate/_quad_vec.py +21 -29
  132. scipy/integrate/_quadpack.cpython-311-darwin.so +0 -0
  133. scipy/integrate/_quadpack_py.py +11 -7
  134. scipy/integrate/_quadrature.py +3 -3
  135. scipy/integrate/_rules/_base.py +2 -2
  136. scipy/integrate/_tanhsinh.py +57 -54
  137. scipy/integrate/_test_odeint_banded.cpython-311-darwin.so +0 -0
  138. scipy/integrate/_vode.cpython-311-darwin.so +0 -0
  139. scipy/integrate/tests/test__quad_vec.py +0 -6
  140. scipy/integrate/tests/test_banded_ode_solvers.py +85 -0
  141. scipy/integrate/tests/test_cubature.py +21 -35
  142. scipy/integrate/tests/test_quadrature.py +6 -8
  143. scipy/integrate/tests/test_tanhsinh.py +61 -43
  144. scipy/interpolate/__init__.py +70 -58
  145. scipy/interpolate/_bary_rational.py +22 -22
  146. scipy/interpolate/_bsplines.py +119 -66
  147. scipy/interpolate/_cubic.py +65 -50
  148. scipy/interpolate/_dfitpack.cpython-311-darwin.so +0 -0
  149. scipy/interpolate/_dierckx.cpython-311-darwin.so +0 -0
  150. scipy/interpolate/_fitpack2.py +9 -6
  151. scipy/interpolate/_fitpack_impl.py +32 -26
  152. scipy/interpolate/_fitpack_repro.py +23 -19
  153. scipy/interpolate/_interpnd.cpython-311-darwin.so +0 -0
  154. scipy/interpolate/_interpolate.py +30 -12
  155. scipy/interpolate/_ndbspline.py +13 -18
  156. scipy/interpolate/_ndgriddata.py +5 -8
  157. scipy/interpolate/_polyint.py +95 -31
  158. scipy/interpolate/_ppoly.cpython-311-darwin.so +0 -0
  159. scipy/interpolate/_rbf.py +2 -2
  160. scipy/interpolate/_rbfinterp.py +1 -1
  161. scipy/interpolate/_rgi.py +31 -26
  162. scipy/interpolate/_rgi_cython.cpython-311-darwin.so +0 -0
  163. scipy/interpolate/dfitpack.py +0 -20
  164. scipy/interpolate/interpnd.py +1 -2
  165. scipy/interpolate/tests/test_bary_rational.py +2 -2
  166. scipy/interpolate/tests/test_bsplines.py +97 -1
  167. scipy/interpolate/tests/test_fitpack2.py +39 -1
  168. scipy/interpolate/tests/test_interpnd.py +32 -20
  169. scipy/interpolate/tests/test_interpolate.py +48 -4
  170. scipy/interpolate/tests/test_rgi.py +2 -1
  171. scipy/io/_fast_matrix_market/__init__.py +2 -0
  172. scipy/io/_harwell_boeing/_fortran_format_parser.py +19 -16
  173. scipy/io/_harwell_boeing/hb.py +7 -11
  174. scipy/io/_idl.py +5 -7
  175. scipy/io/_netcdf.py +15 -5
  176. scipy/io/_test_fortran.cpython-311-darwin.so +0 -0
  177. scipy/io/arff/tests/test_arffread.py +3 -3
  178. scipy/io/matlab/__init__.py +5 -3
  179. scipy/io/matlab/_mio.py +4 -1
  180. scipy/io/matlab/_mio5.py +19 -13
  181. scipy/io/matlab/_mio5_utils.cpython-311-darwin.so +0 -0
  182. scipy/io/matlab/_mio_utils.cpython-311-darwin.so +0 -0
  183. scipy/io/matlab/_miobase.py +4 -1
  184. scipy/io/matlab/_streams.cpython-311-darwin.so +0 -0
  185. scipy/io/matlab/tests/test_mio.py +46 -18
  186. scipy/io/matlab/tests/test_mio_funcs.py +1 -1
  187. scipy/io/tests/test_mmio.py +7 -1
  188. scipy/io/tests/test_wavfile.py +41 -0
  189. scipy/io/wavfile.py +57 -10
  190. scipy/linalg/_basic.py +113 -86
  191. scipy/linalg/_cythonized_array_utils.cpython-311-darwin.so +0 -0
  192. scipy/linalg/_decomp.py +22 -9
  193. scipy/linalg/_decomp_cholesky.py +28 -13
  194. scipy/linalg/_decomp_cossin.py +45 -30
  195. scipy/linalg/_decomp_interpolative.cpython-311-darwin.so +0 -0
  196. scipy/linalg/_decomp_ldl.py +4 -1
  197. scipy/linalg/_decomp_lu.py +18 -6
  198. scipy/linalg/_decomp_lu_cython.cpython-311-darwin.so +0 -0
  199. scipy/linalg/_decomp_polar.py +2 -0
  200. scipy/linalg/_decomp_qr.py +6 -2
  201. scipy/linalg/_decomp_qz.py +3 -0
  202. scipy/linalg/_decomp_schur.py +3 -1
  203. scipy/linalg/_decomp_svd.py +13 -2
  204. scipy/linalg/_decomp_update.cpython-311-darwin.so +0 -0
  205. scipy/linalg/_expm_frechet.py +4 -0
  206. scipy/linalg/_fblas.cpython-311-darwin.so +0 -0
  207. scipy/linalg/_flapack.cpython-311-darwin.so +0 -0
  208. scipy/linalg/_matfuncs.py +187 -4
  209. scipy/linalg/_matfuncs_schur_sqrtm.cpython-311-darwin.so +0 -0
  210. scipy/linalg/_matfuncs_sqrtm.py +1 -99
  211. scipy/linalg/_matfuncs_sqrtm_triu.cpython-311-darwin.so +0 -0
  212. scipy/linalg/_procrustes.py +2 -0
  213. scipy/linalg/_sketches.py +17 -6
  214. scipy/linalg/_solve_toeplitz.cpython-311-darwin.so +0 -0
  215. scipy/linalg/_solvers.py +7 -2
  216. scipy/linalg/_special_matrices.py +26 -36
  217. scipy/linalg/cython_blas.cpython-311-darwin.so +0 -0
  218. scipy/linalg/cython_lapack.cpython-311-darwin.so +0 -0
  219. scipy/linalg/lapack.py +22 -2
  220. scipy/linalg/tests/_cython_examples/meson.build +7 -0
  221. scipy/linalg/tests/test_basic.py +31 -16
  222. scipy/linalg/tests/test_batch.py +588 -0
  223. scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
  224. scipy/linalg/tests/test_decomp.py +40 -3
  225. scipy/linalg/tests/test_decomp_cossin.py +14 -0
  226. scipy/linalg/tests/test_decomp_ldl.py +1 -1
  227. scipy/linalg/tests/test_interpolative.py +17 -0
  228. scipy/linalg/tests/test_lapack.py +115 -7
  229. scipy/linalg/tests/test_matfuncs.py +157 -102
  230. scipy/linalg/tests/test_procrustes.py +0 -7
  231. scipy/linalg/tests/test_solve_toeplitz.py +1 -1
  232. scipy/linalg/tests/test_special_matrices.py +1 -5
  233. scipy/ndimage/__init__.py +1 -0
  234. scipy/ndimage/_cytest.cpython-311-darwin.so +0 -0
  235. scipy/ndimage/_delegators.py +8 -2
  236. scipy/ndimage/_filters.py +433 -5
  237. scipy/ndimage/_interpolation.py +36 -6
  238. scipy/ndimage/_measurements.py +4 -2
  239. scipy/ndimage/_morphology.py +5 -0
  240. scipy/ndimage/_nd_image.cpython-311-darwin.so +0 -0
  241. scipy/ndimage/_ndimage_api.py +2 -1
  242. scipy/ndimage/_ni_docstrings.py +5 -1
  243. scipy/ndimage/_ni_label.cpython-311-darwin.so +0 -0
  244. scipy/ndimage/_ni_support.py +1 -5
  245. scipy/ndimage/_rank_filter_1d.cpython-311-darwin.so +0 -0
  246. scipy/ndimage/_support_alternative_backends.py +18 -6
  247. scipy/ndimage/tests/test_filters.py +351 -259
  248. scipy/ndimage/tests/test_fourier.py +7 -9
  249. scipy/ndimage/tests/test_interpolation.py +68 -61
  250. scipy/ndimage/tests/test_measurements.py +18 -35
  251. scipy/ndimage/tests/test_morphology.py +143 -131
  252. scipy/ndimage/tests/test_splines.py +1 -3
  253. scipy/optimize/_basinhopping.py +13 -7
  254. scipy/optimize/_bglu_dense.cpython-311-darwin.so +0 -0
  255. scipy/optimize/_bracket.py +46 -26
  256. scipy/optimize/_chandrupatla.py +9 -10
  257. scipy/optimize/_cobyla_py.py +104 -123
  258. scipy/optimize/_constraints.py +14 -10
  259. scipy/optimize/_differentiable_functions.py +371 -230
  260. scipy/optimize/_differentialevolution.py +4 -3
  261. scipy/optimize/_dual_annealing.py +1 -1
  262. scipy/optimize/_elementwise.py +1 -4
  263. scipy/optimize/_highspy/_highs_wrapper.py +6 -4
  264. scipy/optimize/_lbfgsb_py.py +57 -16
  265. scipy/optimize/_linprog_doc.py +2 -2
  266. scipy/optimize/_linprog_highs.py +11 -11
  267. scipy/optimize/_linprog_ip.py +25 -10
  268. scipy/optimize/_linprog_util.py +18 -19
  269. scipy/optimize/_lsq/common.py +3 -3
  270. scipy/optimize/_lsq/dogbox.py +16 -2
  271. scipy/optimize/_lsq/givens_elimination.cpython-311-darwin.so +0 -0
  272. scipy/optimize/_lsq/least_squares.py +198 -126
  273. scipy/optimize/_lsq/lsq_linear.py +6 -6
  274. scipy/optimize/_lsq/trf.py +35 -8
  275. scipy/optimize/_milp.py +3 -1
  276. scipy/optimize/_minimize.py +105 -36
  277. scipy/optimize/_minpack.cpython-311-darwin.so +0 -0
  278. scipy/optimize/_minpack_py.py +21 -14
  279. scipy/optimize/_moduleTNC.cpython-311-darwin.so +0 -0
  280. scipy/optimize/_nnls.py +20 -21
  281. scipy/optimize/_nonlin.py +34 -3
  282. scipy/optimize/_numdiff.py +288 -110
  283. scipy/optimize/_optimize.py +86 -48
  284. scipy/optimize/_remove_redundancy.py +5 -5
  285. scipy/optimize/_root_scalar.py +1 -1
  286. scipy/optimize/_shgo.py +6 -0
  287. scipy/optimize/_shgo_lib/_complex.py +1 -1
  288. scipy/optimize/_slsqp_py.py +216 -124
  289. scipy/optimize/_slsqplib.cpython-311-darwin.so +0 -0
  290. scipy/optimize/_spectral.py +1 -1
  291. scipy/optimize/_tnc.py +8 -1
  292. scipy/optimize/_trlib/_trlib.cpython-311-darwin.so +0 -0
  293. scipy/optimize/_trustregion.py +20 -6
  294. scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
  295. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
  296. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
  297. scipy/optimize/_trustregion_constr/projections.py +12 -8
  298. scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
  299. scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
  300. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
  301. scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
  302. scipy/optimize/_trustregion_exact.py +0 -1
  303. scipy/optimize/_zeros.cpython-311-darwin.so +0 -0
  304. scipy/optimize/_zeros_py.py +97 -17
  305. scipy/optimize/cython_optimize/_zeros.cpython-311-darwin.so +0 -0
  306. scipy/optimize/slsqp.py +0 -1
  307. scipy/optimize/tests/test__basinhopping.py +1 -1
  308. scipy/optimize/tests/test__differential_evolution.py +4 -4
  309. scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
  310. scipy/optimize/tests/test__numdiff.py +66 -22
  311. scipy/optimize/tests/test__remove_redundancy.py +2 -2
  312. scipy/optimize/tests/test__shgo.py +9 -1
  313. scipy/optimize/tests/test_bracket.py +71 -46
  314. scipy/optimize/tests/test_chandrupatla.py +133 -135
  315. scipy/optimize/tests/test_cobyla.py +74 -45
  316. scipy/optimize/tests/test_constraints.py +1 -1
  317. scipy/optimize/tests/test_differentiable_functions.py +226 -6
  318. scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
  319. scipy/optimize/tests/test_least_squares.py +125 -13
  320. scipy/optimize/tests/test_linear_assignment.py +3 -3
  321. scipy/optimize/tests/test_linprog.py +3 -3
  322. scipy/optimize/tests/test_lsq_linear.py +5 -5
  323. scipy/optimize/tests/test_minimize_constrained.py +2 -2
  324. scipy/optimize/tests/test_minpack.py +4 -4
  325. scipy/optimize/tests/test_nnls.py +43 -3
  326. scipy/optimize/tests/test_nonlin.py +36 -0
  327. scipy/optimize/tests/test_optimize.py +95 -17
  328. scipy/optimize/tests/test_slsqp.py +36 -4
  329. scipy/optimize/tests/test_zeros.py +34 -1
  330. scipy/signal/__init__.py +12 -23
  331. scipy/signal/_delegators.py +568 -0
  332. scipy/signal/_filter_design.py +459 -241
  333. scipy/signal/_fir_filter_design.py +262 -90
  334. scipy/signal/_lti_conversion.py +3 -2
  335. scipy/signal/_ltisys.py +118 -91
  336. scipy/signal/_peak_finding_utils.cpython-311-darwin.so +0 -0
  337. scipy/signal/_polyutils.py +172 -0
  338. scipy/signal/_short_time_fft.py +553 -76
  339. scipy/signal/_signal_api.py +30 -0
  340. scipy/signal/_signaltools.py +719 -396
  341. scipy/signal/_sigtools.cpython-311-darwin.so +0 -0
  342. scipy/signal/_sosfilt.cpython-311-darwin.so +0 -0
  343. scipy/signal/_spectral_py.py +221 -50
  344. scipy/signal/_spline_filters.py +108 -68
  345. scipy/signal/_support_alternative_backends.py +73 -0
  346. scipy/signal/_upfirdn.py +4 -1
  347. scipy/signal/_upfirdn_apply.cpython-311-darwin.so +0 -0
  348. scipy/signal/_waveforms.py +2 -11
  349. scipy/signal/_wavelets.py +1 -1
  350. scipy/signal/fir_filter_design.py +1 -0
  351. scipy/signal/spline.py +4 -11
  352. scipy/signal/tests/_scipy_spectral_test_shim.py +5 -182
  353. scipy/signal/tests/test_bsplines.py +114 -79
  354. scipy/signal/tests/test_cont2discrete.py +9 -2
  355. scipy/signal/tests/test_filter_design.py +721 -481
  356. scipy/signal/tests/test_fir_filter_design.py +332 -140
  357. scipy/signal/tests/test_savitzky_golay.py +4 -3
  358. scipy/signal/tests/test_short_time_fft.py +231 -5
  359. scipy/signal/tests/test_signaltools.py +2149 -1348
  360. scipy/signal/tests/test_spectral.py +19 -6
  361. scipy/signal/tests/test_splines.py +161 -96
  362. scipy/signal/tests/test_upfirdn.py +84 -50
  363. scipy/signal/tests/test_waveforms.py +20 -0
  364. scipy/signal/tests/test_windows.py +607 -466
  365. scipy/signal/windows/_windows.py +287 -148
  366. scipy/sparse/__init__.py +23 -4
  367. scipy/sparse/_base.py +269 -120
  368. scipy/sparse/_bsr.py +7 -4
  369. scipy/sparse/_compressed.py +59 -234
  370. scipy/sparse/_construct.py +90 -38
  371. scipy/sparse/_coo.py +115 -181
  372. scipy/sparse/_csc.py +4 -4
  373. scipy/sparse/_csparsetools.cpython-311-darwin.so +0 -0
  374. scipy/sparse/_csr.py +2 -2
  375. scipy/sparse/_data.py +48 -48
  376. scipy/sparse/_dia.py +105 -21
  377. scipy/sparse/_dok.py +0 -23
  378. scipy/sparse/_index.py +4 -4
  379. scipy/sparse/_matrix.py +23 -0
  380. scipy/sparse/_sparsetools.cpython-311-darwin.so +0 -0
  381. scipy/sparse/_sputils.py +37 -22
  382. scipy/sparse/base.py +0 -9
  383. scipy/sparse/bsr.py +0 -14
  384. scipy/sparse/compressed.py +0 -23
  385. scipy/sparse/construct.py +0 -6
  386. scipy/sparse/coo.py +0 -14
  387. scipy/sparse/csc.py +0 -3
  388. scipy/sparse/csgraph/_flow.cpython-311-darwin.so +0 -0
  389. scipy/sparse/csgraph/_matching.cpython-311-darwin.so +0 -0
  390. scipy/sparse/csgraph/_min_spanning_tree.cpython-311-darwin.so +0 -0
  391. scipy/sparse/csgraph/_reordering.cpython-311-darwin.so +0 -0
  392. scipy/sparse/csgraph/_shortest_path.cpython-311-darwin.so +0 -0
  393. scipy/sparse/csgraph/_tools.cpython-311-darwin.so +0 -0
  394. scipy/sparse/csgraph/_traversal.cpython-311-darwin.so +0 -0
  395. scipy/sparse/csgraph/tests/test_matching.py +14 -2
  396. scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
  397. scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
  398. scipy/sparse/csr.py +0 -5
  399. scipy/sparse/data.py +1 -6
  400. scipy/sparse/dia.py +0 -7
  401. scipy/sparse/dok.py +0 -10
  402. scipy/sparse/linalg/_dsolve/_superlu.cpython-311-darwin.so +0 -0
  403. scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
  404. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
  405. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-311-darwin.so +0 -0
  406. scipy/sparse/linalg/_eigen/arpack/arpack.py +28 -20
  407. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
  408. scipy/sparse/linalg/_expm_multiply.py +8 -3
  409. scipy/sparse/linalg/_interface.py +29 -26
  410. scipy/sparse/linalg/_isolve/_gcrotmk.py +6 -5
  411. scipy/sparse/linalg/_isolve/iterative.py +51 -45
  412. scipy/sparse/linalg/_isolve/lgmres.py +6 -6
  413. scipy/sparse/linalg/_isolve/minres.py +5 -5
  414. scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
  415. scipy/sparse/linalg/_isolve/utils.py +2 -8
  416. scipy/sparse/linalg/_matfuncs.py +1 -1
  417. scipy/sparse/linalg/_norm.py +1 -1
  418. scipy/sparse/linalg/_propack/_cpropack.cpython-311-darwin.so +0 -0
  419. scipy/sparse/linalg/_propack/_dpropack.cpython-311-darwin.so +0 -0
  420. scipy/sparse/linalg/_propack/_spropack.cpython-311-darwin.so +0 -0
  421. scipy/sparse/linalg/_propack/_zpropack.cpython-311-darwin.so +0 -0
  422. scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
  423. scipy/sparse/linalg/tests/test_expm_multiply.py +10 -0
  424. scipy/sparse/linalg/tests/test_interface.py +35 -0
  425. scipy/sparse/linalg/tests/test_pydata_sparse.py +18 -0
  426. scipy/sparse/tests/test_arithmetic1d.py +5 -2
  427. scipy/sparse/tests/test_base.py +217 -40
  428. scipy/sparse/tests/test_common1d.py +17 -12
  429. scipy/sparse/tests/test_construct.py +1 -1
  430. scipy/sparse/tests/test_coo.py +272 -4
  431. scipy/sparse/tests/test_sparsetools.py +5 -0
  432. scipy/sparse/tests/test_sputils.py +36 -7
  433. scipy/spatial/_ckdtree.cpython-311-darwin.so +0 -0
  434. scipy/spatial/_hausdorff.cpython-311-darwin.so +0 -0
  435. scipy/spatial/_qhull.cpython-311-darwin.so +0 -0
  436. scipy/spatial/_voronoi.cpython-311-darwin.so +0 -0
  437. scipy/spatial/distance.py +49 -42
  438. scipy/spatial/tests/test_distance.py +3 -1
  439. scipy/spatial/tests/test_kdtree.py +1 -0
  440. scipy/spatial/tests/test_qhull.py +106 -2
  441. scipy/spatial/transform/__init__.py +5 -3
  442. scipy/spatial/transform/_rigid_transform.cpython-311-darwin.so +0 -0
  443. scipy/spatial/transform/_rotation.cpython-311-darwin.so +0 -0
  444. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  445. scipy/spatial/transform/tests/test_rotation.py +1342 -790
  446. scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
  447. scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
  448. scipy/special/__init__.py +1 -47
  449. scipy/special/_add_newdocs.py +34 -772
  450. scipy/special/_basic.py +22 -25
  451. scipy/special/_comb.cpython-311-darwin.so +0 -0
  452. scipy/special/_ellip_harm_2.cpython-311-darwin.so +0 -0
  453. scipy/special/_gufuncs.cpython-311-darwin.so +0 -0
  454. scipy/special/_logsumexp.py +83 -69
  455. scipy/special/_orthogonal.pyi +1 -1
  456. scipy/special/_specfun.cpython-311-darwin.so +0 -0
  457. scipy/special/_special_ufuncs.cpython-311-darwin.so +0 -0
  458. scipy/special/_spherical_bessel.py +4 -4
  459. scipy/special/_support_alternative_backends.py +212 -119
  460. scipy/special/_test_internal.cpython-311-darwin.so +0 -0
  461. scipy/special/_testutils.py +4 -4
  462. scipy/special/_ufuncs.cpython-311-darwin.so +0 -0
  463. scipy/special/_ufuncs.pyi +1 -0
  464. scipy/special/_ufuncs.pyx +215 -1400
  465. scipy/special/_ufuncs_cxx.cpython-311-darwin.so +0 -0
  466. scipy/special/_ufuncs_cxx.pxd +2 -15
  467. scipy/special/_ufuncs_cxx.pyx +5 -44
  468. scipy/special/_ufuncs_cxx_defs.h +2 -16
  469. scipy/special/_ufuncs_defs.h +0 -8
  470. scipy/special/cython_special.cpython-311-darwin.so +0 -0
  471. scipy/special/cython_special.pxd +1 -1
  472. scipy/special/tests/_cython_examples/meson.build +10 -1
  473. scipy/special/tests/test_basic.py +153 -20
  474. scipy/special/tests/test_boost_ufuncs.py +3 -0
  475. scipy/special/tests/test_cdflib.py +35 -11
  476. scipy/special/tests/test_gammainc.py +16 -0
  477. scipy/special/tests/test_hyp2f1.py +23 -2
  478. scipy/special/tests/test_log1mexp.py +85 -0
  479. scipy/special/tests/test_logsumexp.py +220 -64
  480. scipy/special/tests/test_mpmath.py +1 -0
  481. scipy/special/tests/test_nan_inputs.py +1 -1
  482. scipy/special/tests/test_orthogonal.py +17 -18
  483. scipy/special/tests/test_sf_error.py +3 -2
  484. scipy/special/tests/test_sph_harm.py +6 -7
  485. scipy/special/tests/test_support_alternative_backends.py +211 -76
  486. scipy/stats/__init__.py +4 -1
  487. scipy/stats/_ansari_swilk_statistics.cpython-311-darwin.so +0 -0
  488. scipy/stats/_axis_nan_policy.py +4 -3
  489. scipy/stats/_biasedurn.cpython-311-darwin.so +0 -0
  490. scipy/stats/_continued_fraction.py +387 -0
  491. scipy/stats/_continuous_distns.py +296 -319
  492. scipy/stats/_covariance.py +6 -3
  493. scipy/stats/_discrete_distns.py +39 -32
  494. scipy/stats/_distn_infrastructure.py +39 -12
  495. scipy/stats/_distribution_infrastructure.py +900 -238
  496. scipy/stats/_entropy.py +7 -8
  497. scipy/{_lib → stats}/_finite_differences.py +1 -1
  498. scipy/stats/_hypotests.py +82 -49
  499. scipy/stats/_kde.py +53 -49
  500. scipy/stats/_ksstats.py +1 -1
  501. scipy/stats/_levy_stable/__init__.py +7 -15
  502. scipy/stats/_levy_stable/levyst.cpython-311-darwin.so +0 -0
  503. scipy/stats/_morestats.py +112 -67
  504. scipy/stats/_mstats_basic.py +13 -17
  505. scipy/stats/_mstats_extras.py +8 -8
  506. scipy/stats/_multivariate.py +89 -113
  507. scipy/stats/_new_distributions.py +97 -20
  508. scipy/stats/_page_trend_test.py +12 -5
  509. scipy/stats/_probability_distribution.py +265 -43
  510. scipy/stats/_qmc.py +14 -9
  511. scipy/stats/_qmc_cy.cpython-311-darwin.so +0 -0
  512. scipy/stats/_qmvnt.py +16 -95
  513. scipy/stats/_qmvnt_cy.cpython-311-darwin.so +0 -0
  514. scipy/stats/_quantile.py +335 -0
  515. scipy/stats/_rcont/rcont.cpython-311-darwin.so +0 -0
  516. scipy/stats/_resampling.py +4 -29
  517. scipy/stats/_sampling.py +1 -1
  518. scipy/stats/_sobol.cpython-311-darwin.so +0 -0
  519. scipy/stats/_stats.cpython-311-darwin.so +0 -0
  520. scipy/stats/_stats_mstats_common.py +19 -2
  521. scipy/stats/_stats_py.py +534 -460
  522. scipy/stats/_unuran/unuran_wrapper.cpython-311-darwin.so +0 -0
  523. scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
  524. scipy/stats/_variation.py +5 -7
  525. scipy/stats/_wilcoxon.py +13 -7
  526. scipy/stats/tests/common_tests.py +6 -4
  527. scipy/stats/tests/test_axis_nan_policy.py +62 -24
  528. scipy/stats/tests/test_continued_fraction.py +173 -0
  529. scipy/stats/tests/test_continuous.py +379 -60
  530. scipy/stats/tests/test_continuous_basic.py +18 -12
  531. scipy/stats/tests/test_discrete_basic.py +14 -8
  532. scipy/stats/tests/test_discrete_distns.py +16 -16
  533. scipy/stats/tests/test_distributions.py +117 -75
  534. scipy/stats/tests/test_entropy.py +40 -48
  535. scipy/stats/tests/test_fit.py +4 -3
  536. scipy/stats/tests/test_hypotests.py +153 -24
  537. scipy/stats/tests/test_kdeoth.py +109 -41
  538. scipy/stats/tests/test_marray.py +289 -0
  539. scipy/stats/tests/test_morestats.py +79 -47
  540. scipy/stats/tests/test_mstats_basic.py +3 -3
  541. scipy/stats/tests/test_multivariate.py +434 -83
  542. scipy/stats/tests/test_qmc.py +13 -10
  543. scipy/stats/tests/test_quantile.py +199 -0
  544. scipy/stats/tests/test_rank.py +119 -112
  545. scipy/stats/tests/test_resampling.py +47 -56
  546. scipy/stats/tests/test_sampling.py +9 -4
  547. scipy/stats/tests/test_stats.py +799 -939
  548. scipy/stats/tests/test_variation.py +8 -6
  549. scipy/version.py +2 -2
  550. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/LICENSE.txt +1 -1
  551. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/METADATA +9 -9
  552. {scipy-1.15.2.dist-info → scipy-1.16.0rc1.dist-info}/RECORD +553 -560
  553. scipy-1.16.0rc1.dist-info/WHEEL +6 -0
  554. scipy/_lib/array_api_extra/_funcs.py +0 -484
  555. scipy/_lib/array_api_extra/_typing.py +0 -8
  556. scipy/interpolate/_bspl.cpython-311-darwin.so +0 -0
  557. scipy/optimize/_cobyla.cpython-311-darwin.so +0 -0
  558. scipy/optimize/_cython_nnls.cpython-311-darwin.so +0 -0
  559. scipy/optimize/_slsqp.cpython-311-darwin.so +0 -0
  560. scipy/spatial/qhull_src/COPYING.txt +0 -38
  561. scipy/special/libsf_error_state.dylib +0 -0
  562. scipy/special/tests/test_log_softmax.py +0 -109
  563. scipy/special/tests/test_xsf_cuda.py +0 -114
  564. scipy/special/xsf/binom.h +0 -89
  565. scipy/special/xsf/cdflib.h +0 -100
  566. scipy/special/xsf/cephes/airy.h +0 -307
  567. scipy/special/xsf/cephes/besselpoly.h +0 -51
  568. scipy/special/xsf/cephes/beta.h +0 -257
  569. scipy/special/xsf/cephes/cbrt.h +0 -131
  570. scipy/special/xsf/cephes/chbevl.h +0 -85
  571. scipy/special/xsf/cephes/chdtr.h +0 -193
  572. scipy/special/xsf/cephes/const.h +0 -87
  573. scipy/special/xsf/cephes/ellie.h +0 -293
  574. scipy/special/xsf/cephes/ellik.h +0 -251
  575. scipy/special/xsf/cephes/ellpe.h +0 -107
  576. scipy/special/xsf/cephes/ellpk.h +0 -117
  577. scipy/special/xsf/cephes/expn.h +0 -260
  578. scipy/special/xsf/cephes/gamma.h +0 -398
  579. scipy/special/xsf/cephes/hyp2f1.h +0 -596
  580. scipy/special/xsf/cephes/hyperg.h +0 -361
  581. scipy/special/xsf/cephes/i0.h +0 -149
  582. scipy/special/xsf/cephes/i1.h +0 -158
  583. scipy/special/xsf/cephes/igam.h +0 -421
  584. scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
  585. scipy/special/xsf/cephes/igami.h +0 -313
  586. scipy/special/xsf/cephes/j0.h +0 -225
  587. scipy/special/xsf/cephes/j1.h +0 -198
  588. scipy/special/xsf/cephes/jv.h +0 -715
  589. scipy/special/xsf/cephes/k0.h +0 -164
  590. scipy/special/xsf/cephes/k1.h +0 -163
  591. scipy/special/xsf/cephes/kn.h +0 -243
  592. scipy/special/xsf/cephes/lanczos.h +0 -112
  593. scipy/special/xsf/cephes/ndtr.h +0 -275
  594. scipy/special/xsf/cephes/poch.h +0 -85
  595. scipy/special/xsf/cephes/polevl.h +0 -167
  596. scipy/special/xsf/cephes/psi.h +0 -194
  597. scipy/special/xsf/cephes/rgamma.h +0 -111
  598. scipy/special/xsf/cephes/scipy_iv.h +0 -811
  599. scipy/special/xsf/cephes/shichi.h +0 -248
  600. scipy/special/xsf/cephes/sici.h +0 -224
  601. scipy/special/xsf/cephes/sindg.h +0 -221
  602. scipy/special/xsf/cephes/tandg.h +0 -139
  603. scipy/special/xsf/cephes/trig.h +0 -58
  604. scipy/special/xsf/cephes/unity.h +0 -186
  605. scipy/special/xsf/cephes/zeta.h +0 -172
  606. scipy/special/xsf/config.h +0 -304
  607. scipy/special/xsf/digamma.h +0 -205
  608. scipy/special/xsf/error.h +0 -57
  609. scipy/special/xsf/evalpoly.h +0 -47
  610. scipy/special/xsf/expint.h +0 -266
  611. scipy/special/xsf/hyp2f1.h +0 -694
  612. scipy/special/xsf/iv_ratio.h +0 -173
  613. scipy/special/xsf/lambertw.h +0 -150
  614. scipy/special/xsf/loggamma.h +0 -163
  615. scipy/special/xsf/sici.h +0 -200
  616. scipy/special/xsf/tools.h +0 -427
  617. scipy/special/xsf/trig.h +0 -164
  618. scipy/special/xsf/wright_bessel.h +0 -843
  619. scipy/special/xsf/zlog1.h +0 -35
  620. scipy/stats/_mvn.cpython-311-darwin.so +0 -0
  621. scipy-1.15.2.dist-info/WHEEL +0 -4
@@ -1,398 +0,0 @@
1
- /* Translated into C++ by SciPy developers in 2024.
2
- * Original header with Copyright information appears below.
3
- */
4
-
5
- /*
6
- * Gamma function
7
- *
8
- *
9
- *
10
- * SYNOPSIS:
11
- *
12
- * double x, y, Gamma();
13
- *
14
- * y = Gamma( x );
15
- *
16
- *
17
- *
18
- * DESCRIPTION:
19
- *
20
- * Returns Gamma function of the argument. The result is
21
- * correctly signed.
22
- *
23
- * Arguments |x| <= 34 are reduced by recurrence and the function
24
- * approximated by a rational function of degree 6/7 in the
25
- * interval (2,3). Large arguments are handled by Stirling's
26
- * formula. Large negative arguments are made positive using
27
- * a reflection formula.
28
- *
29
- *
30
- * ACCURACY:
31
- *
32
- * Relative error:
33
- * arithmetic domain # trials peak rms
34
- * IEEE -170,-33 20000 2.3e-15 3.3e-16
35
- * IEEE -33, 33 20000 9.4e-16 2.2e-16
36
- * IEEE 33, 171.6 20000 2.3e-15 3.2e-16
37
- *
38
- * Error for arguments outside the test range will be larger
39
- * owing to error amplification by the exponential function.
40
- *
41
- */
42
-
43
- /* lgam()
44
- *
45
- * Natural logarithm of Gamma function
46
- *
47
- *
48
- *
49
- * SYNOPSIS:
50
- *
51
- * double x, y, lgam();
52
- *
53
- * y = lgam( x );
54
- *
55
- *
56
- *
57
- * DESCRIPTION:
58
- *
59
- * Returns the base e (2.718...) logarithm of the absolute
60
- * value of the Gamma function of the argument.
61
- *
62
- * For arguments greater than 13, the logarithm of the Gamma
63
- * function is approximated by the logarithmic version of
64
- * Stirling's formula using a polynomial approximation of
65
- * degree 4. Arguments between -33 and +33 are reduced by
66
- * recurrence to the interval [2,3] of a rational approximation.
67
- * The cosecant reflection formula is employed for arguments
68
- * less than -33.
69
- *
70
- * Arguments greater than MAXLGM return INFINITY and an error
71
- * message. MAXLGM = 2.556348e305 for IEEE arithmetic.
72
- *
73
- *
74
- *
75
- * ACCURACY:
76
- *
77
- *
78
- * arithmetic domain # trials peak rms
79
- * IEEE 0, 3 28000 5.4e-16 1.1e-16
80
- * IEEE 2.718, 2.556e305 40000 3.5e-16 8.3e-17
81
- * The error criterion was relative when the function magnitude
82
- * was greater than one but absolute when it was less than one.
83
- *
84
- * The following test used the relative error criterion, though
85
- * at certain points the relative error could be much higher than
86
- * indicated.
87
- * IEEE -200, -4 10000 4.8e-16 1.3e-16
88
- *
89
- */
90
-
91
- /*
92
- * Cephes Math Library Release 2.2: July, 1992
93
- * Copyright 1984, 1987, 1989, 1992 by Stephen L. Moshier
94
- * Direct inquiries to 30 Frost Street, Cambridge, MA 02140
95
- */
96
- #pragma once
97
-
98
- #include "../config.h"
99
- #include "../error.h"
100
- #include "const.h"
101
- #include "polevl.h"
102
- #include "trig.h"
103
-
104
- namespace xsf {
105
- namespace cephes {
106
- namespace detail {
107
- constexpr double gamma_P[] = {1.60119522476751861407E-4, 1.19135147006586384913E-3, 1.04213797561761569935E-2,
108
- 4.76367800457137231464E-2, 2.07448227648435975150E-1, 4.94214826801497100753E-1,
109
- 9.99999999999999996796E-1};
110
-
111
- constexpr double gamma_Q[] = {-2.31581873324120129819E-5, 5.39605580493303397842E-4, -4.45641913851797240494E-3,
112
- 1.18139785222060435552E-2, 3.58236398605498653373E-2, -2.34591795718243348568E-1,
113
- 7.14304917030273074085E-2, 1.00000000000000000320E0};
114
-
115
- /* Stirling's formula for the Gamma function */
116
- constexpr double gamma_STIR[5] = {
117
- 7.87311395793093628397E-4, -2.29549961613378126380E-4, -2.68132617805781232825E-3,
118
- 3.47222221605458667310E-3, 8.33333333333482257126E-2,
119
- };
120
-
121
- constexpr double MAXSTIR = 143.01608;
122
-
123
- /* Gamma function computed by Stirling's formula.
124
- * The polynomial STIR is valid for 33 <= x <= 172.
125
- */
126
- XSF_HOST_DEVICE inline double stirf(double x) {
127
- double y, w, v;
128
-
129
- if (x >= MAXGAM) {
130
- return (std::numeric_limits<double>::infinity());
131
- }
132
- w = 1.0 / x;
133
- w = 1.0 + w * xsf::cephes::polevl(w, gamma_STIR, 4);
134
- y = std::exp(x);
135
- if (x > MAXSTIR) { /* Avoid overflow in pow() */
136
- v = std::pow(x, 0.5 * x - 0.25);
137
- y = v * (v / y);
138
- } else {
139
- y = std::pow(x, x - 0.5) / y;
140
- }
141
- y = SQRTPI * y * w;
142
- return (y);
143
- }
144
- } // namespace detail
145
-
146
- XSF_HOST_DEVICE inline double Gamma(double x) {
147
- double p, q, z;
148
- int i;
149
- int sgngam = 1;
150
-
151
- if (!std::isfinite(x)) {
152
- if (x > 0) {
153
- // gamma(+inf) = +inf
154
- return x;
155
- }
156
- // gamma(NaN) and gamma(-inf) both should equal NaN.
157
- return std::numeric_limits<double>::quiet_NaN();
158
- }
159
-
160
- if (x == 0) {
161
- /* For pole at zero, value depends on sign of zero.
162
- * +inf when approaching from right, -inf when approaching
163
- * from left. */
164
- return std::copysign(std::numeric_limits<double>::infinity(), x);
165
- }
166
-
167
- q = std::abs(x);
168
-
169
- if (q > 33.0) {
170
- if (x < 0.0) {
171
- p = std::floor(q);
172
- if (p == q) {
173
- // x is a negative integer. This is a pole.
174
- set_error("Gamma", SF_ERROR_SINGULAR, NULL);
175
- return (std::numeric_limits<double>::quiet_NaN());
176
- }
177
- i = p;
178
- if ((i & 1) == 0) {
179
- sgngam = -1;
180
- }
181
- z = q - p;
182
- if (z > 0.5) {
183
- p += 1.0;
184
- z = q - p;
185
- }
186
- z = q * sinpi(z);
187
- if (z == 0.0) {
188
- return (sgngam * std::numeric_limits<double>::infinity());
189
- }
190
- z = std::abs(z);
191
- z = M_PI / (z * detail::stirf(q));
192
- } else {
193
- z = detail::stirf(x);
194
- }
195
- return (sgngam * z);
196
- }
197
-
198
- z = 1.0;
199
- while (x >= 3.0) {
200
- x -= 1.0;
201
- z *= x;
202
- }
203
-
204
- while (x < 0.0) {
205
- if (x > -1.E-9) {
206
- goto small;
207
- }
208
- z /= x;
209
- x += 1.0;
210
- }
211
-
212
- while (x < 2.0) {
213
- if (x < 1.e-9) {
214
- goto small;
215
- }
216
- z /= x;
217
- x += 1.0;
218
- }
219
-
220
- if (x == 2.0) {
221
- return (z);
222
- }
223
-
224
- x -= 2.0;
225
- p = polevl(x, detail::gamma_P, 6);
226
- q = polevl(x, detail::gamma_Q, 7);
227
- return (z * p / q);
228
-
229
- small:
230
- if (x == 0.0) {
231
- /* For this to have happened, x must have started as a negative integer. */
232
- set_error("Gamma", SF_ERROR_SINGULAR, NULL);
233
- return (std::numeric_limits<double>::quiet_NaN());
234
- } else
235
- return (z / ((1.0 + 0.5772156649015329 * x) * x));
236
- }
237
-
238
- namespace detail {
239
- /* A[]: Stirling's formula expansion of log Gamma
240
- * B[], C[]: log Gamma function between 2 and 3
241
- */
242
- constexpr double gamma_A[] = {8.11614167470508450300E-4, -5.95061904284301438324E-4, 7.93650340457716943945E-4,
243
- -2.77777777730099687205E-3, 8.33333333333331927722E-2};
244
-
245
- constexpr double gamma_B[] = {-1.37825152569120859100E3, -3.88016315134637840924E4, -3.31612992738871184744E5,
246
- -1.16237097492762307383E6, -1.72173700820839662146E6, -8.53555664245765465627E5};
247
-
248
- constexpr double gamma_C[] = {
249
- /* 1.00000000000000000000E0, */
250
- -3.51815701436523470549E2, -1.70642106651881159223E4, -2.20528590553854454839E5,
251
- -1.13933444367982507207E6, -2.53252307177582951285E6, -2.01889141433532773231E6};
252
-
253
- /* log( sqrt( 2*pi ) ) */
254
- constexpr double LS2PI = 0.91893853320467274178;
255
-
256
- constexpr double MAXLGM = 2.556348e305;
257
-
258
- /* Disable optimizations for this function on 32 bit systems when compiling with GCC.
259
- * We've found that enabling optimizations can result in degraded precision
260
- * for this asymptotic approximation in that case. */
261
- #if defined(__GNUC__) && defined(__i386__)
262
- #pragma GCC push_options
263
- #pragma GCC optimize("00")
264
- #endif
265
- XSF_HOST_DEVICE inline double lgam_large_x(double x) {
266
- double q = (x - 0.5) * std::log(x) - x + LS2PI;
267
- if (x > 1.0e8) {
268
- return (q);
269
- }
270
- double p = 1.0 / (x * x);
271
- p = ((7.9365079365079365079365e-4 * p - 2.7777777777777777777778e-3) * p + 0.0833333333333333333333) / x;
272
- return q + p;
273
- }
274
- #if defined(__GNUC__) && defined(__i386__)
275
- #pragma GCC pop_options
276
- #endif
277
-
278
- XSF_HOST_DEVICE inline double lgam_sgn(double x, int *sign) {
279
- double p, q, u, w, z;
280
- int i;
281
-
282
- *sign = 1;
283
-
284
- if (!std::isfinite(x)) {
285
- return x;
286
- }
287
-
288
- if (x < -34.0) {
289
- q = -x;
290
- w = lgam_sgn(q, sign);
291
- p = std::floor(q);
292
- if (p == q) {
293
- lgsing:
294
- set_error("lgam", SF_ERROR_SINGULAR, NULL);
295
- return (std::numeric_limits<double>::infinity());
296
- }
297
- i = p;
298
- if ((i & 1) == 0) {
299
- *sign = -1;
300
- } else {
301
- *sign = 1;
302
- }
303
- z = q - p;
304
- if (z > 0.5) {
305
- p += 1.0;
306
- z = p - q;
307
- }
308
- z = q * sinpi(z);
309
- if (z == 0.0) {
310
- goto lgsing;
311
- }
312
- /* z = log(M_PI) - log( z ) - w; */
313
- z = LOGPI - std::log(z) - w;
314
- return (z);
315
- }
316
-
317
- if (x < 13.0) {
318
- z = 1.0;
319
- p = 0.0;
320
- u = x;
321
- while (u >= 3.0) {
322
- p -= 1.0;
323
- u = x + p;
324
- z *= u;
325
- }
326
- while (u < 2.0) {
327
- if (u == 0.0) {
328
- goto lgsing;
329
- }
330
- z /= u;
331
- p += 1.0;
332
- u = x + p;
333
- }
334
- if (z < 0.0) {
335
- *sign = -1;
336
- z = -z;
337
- } else {
338
- *sign = 1;
339
- }
340
- if (u == 2.0) {
341
- return (std::log(z));
342
- }
343
- p -= 2.0;
344
- x = x + p;
345
- p = x * polevl(x, gamma_B, 5) / p1evl(x, gamma_C, 6);
346
- return (std::log(z) + p);
347
- }
348
-
349
- if (x > MAXLGM) {
350
- return (*sign * std::numeric_limits<double>::infinity());
351
- }
352
-
353
- if (x >= 1000.0) {
354
- return lgam_large_x(x);
355
- }
356
-
357
- q = (x - 0.5) * std::log(x) - x + LS2PI;
358
- p = 1.0 / (x * x);
359
- return q + polevl(p, gamma_A, 4) / x;
360
- }
361
- } // namespace detail
362
-
363
- /* Logarithm of Gamma function */
364
- XSF_HOST_DEVICE inline double lgam(double x) {
365
- int sign;
366
- return detail::lgam_sgn(x, &sign);
367
- }
368
-
369
- /* Sign of the Gamma function */
370
- XSF_HOST_DEVICE inline double gammasgn(double x) {
371
- double fx;
372
-
373
- if (std::isnan(x)) {
374
- return x;
375
- }
376
- if (x > 0) {
377
- return 1.0;
378
- }
379
- if (x == 0) {
380
- return std::copysign(1.0, x);
381
- }
382
- if (std::isinf(x)) {
383
- // x > 0 case handled, so x must be negative infinity.
384
- return std::numeric_limits<double>::quiet_NaN();
385
- }
386
- fx = std::floor(x);
387
- if (x - fx == 0.0) {
388
- return std::numeric_limits<double>::quiet_NaN();
389
- }
390
- // sign of gamma for x in (-n, -n+1) for positive integer n is (-1)^n.
391
- if (static_cast<int>(fx) % 2) {
392
- return -1.0;
393
- }
394
- return 1.0;
395
- }
396
-
397
- } // namespace cephes
398
- } // namespace xsf