scipy 1.15.3__cp311-cp311-macosx_12_0_arm64.whl → 1.16.0rc1__cp311-cp311-macosx_12_0_arm64.whl

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