scipy 1.15.3__cp312-cp312-macosx_14_0_arm64.whl → 1.16.0__cp312-cp312-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 (632) hide show
  1. scipy/.dylibs/libgcc_s.1.1.dylib +0 -0
  2. scipy/.dylibs/libgfortran.5.dylib +0 -0
  3. scipy/.dylibs/libquadmath.0.dylib +0 -0
  4. scipy/__config__.py +5 -5
  5. scipy/__init__.py +3 -6
  6. scipy/_cyutility.cpython-312-darwin.so +0 -0
  7. scipy/_lib/_array_api.py +486 -161
  8. scipy/_lib/_array_api_compat_vendor.py +9 -0
  9. scipy/_lib/_bunch.py +4 -0
  10. scipy/_lib/_ccallback_c.cpython-312-darwin.so +0 -0
  11. scipy/_lib/_docscrape.py +1 -1
  12. scipy/_lib/_elementwise_iterative_method.py +15 -26
  13. scipy/_lib/_sparse.py +41 -0
  14. scipy/_lib/_test_deprecation_call.cpython-312-darwin.so +0 -0
  15. scipy/_lib/_test_deprecation_def.cpython-312-darwin.so +0 -0
  16. scipy/_lib/_testutils.py +6 -2
  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-darwin.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-darwin.so +0 -0
  97. scipy/cluster/_optimal_leaf_ordering.cpython-312-darwin.so +0 -0
  98. scipy/cluster/_vq.cpython-312-darwin.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 +282 -151
  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/tests/test_basic.py +2 -4
  116. scipy/fft/_pocketfft/tests/test_real_transforms.py +4 -4
  117. scipy/fft/_realtransforms.py +13 -0
  118. scipy/fft/tests/test_basic.py +27 -25
  119. scipy/fft/tests/test_fftlog.py +16 -7
  120. scipy/fft/tests/test_helper.py +18 -34
  121. scipy/fft/tests/test_real_transforms.py +8 -10
  122. scipy/fftpack/convolve.cpython-312-darwin.so +0 -0
  123. scipy/fftpack/tests/test_basic.py +2 -4
  124. scipy/fftpack/tests/test_real_transforms.py +8 -9
  125. scipy/integrate/_bvp.py +9 -3
  126. scipy/integrate/_cubature.py +3 -2
  127. scipy/integrate/_dop.cpython-312-darwin.so +0 -0
  128. scipy/integrate/_lsoda.cpython-312-darwin.so +0 -0
  129. scipy/integrate/_ode.py +9 -2
  130. scipy/integrate/_odepack.cpython-312-darwin.so +0 -0
  131. scipy/integrate/_quad_vec.py +21 -29
  132. scipy/integrate/_quadpack.cpython-312-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 +48 -47
  137. scipy/integrate/_test_odeint_banded.cpython-312-darwin.so +0 -0
  138. scipy/integrate/_vode.cpython-312-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 +56 -48
  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-312-darwin.so +0 -0
  149. scipy/interpolate/_dierckx.cpython-312-darwin.so +0 -0
  150. scipy/interpolate/_fitpack.cpython-312-darwin.so +0 -0
  151. scipy/interpolate/_fitpack2.py +9 -6
  152. scipy/interpolate/_fitpack_impl.py +32 -26
  153. scipy/interpolate/_fitpack_repro.py +23 -19
  154. scipy/interpolate/_interpnd.cpython-312-darwin.so +0 -0
  155. scipy/interpolate/_interpolate.py +30 -12
  156. scipy/interpolate/_ndbspline.py +13 -18
  157. scipy/interpolate/_ndgriddata.py +5 -8
  158. scipy/interpolate/_polyint.py +95 -31
  159. scipy/interpolate/_ppoly.cpython-312-darwin.so +0 -0
  160. scipy/interpolate/_rbf.py +2 -2
  161. scipy/interpolate/_rbfinterp.py +1 -1
  162. scipy/interpolate/_rbfinterp_pythran.cpython-312-darwin.so +0 -0
  163. scipy/interpolate/_rgi.py +31 -26
  164. scipy/interpolate/_rgi_cython.cpython-312-darwin.so +0 -0
  165. scipy/interpolate/dfitpack.py +0 -20
  166. scipy/interpolate/interpnd.py +1 -2
  167. scipy/interpolate/tests/test_bary_rational.py +2 -2
  168. scipy/interpolate/tests/test_bsplines.py +97 -1
  169. scipy/interpolate/tests/test_fitpack2.py +39 -1
  170. scipy/interpolate/tests/test_interpnd.py +32 -20
  171. scipy/interpolate/tests/test_interpolate.py +48 -4
  172. scipy/interpolate/tests/test_rgi.py +2 -1
  173. scipy/io/_fast_matrix_market/__init__.py +2 -0
  174. scipy/io/_harwell_boeing/_fortran_format_parser.py +19 -16
  175. scipy/io/_harwell_boeing/hb.py +7 -11
  176. scipy/io/_idl.py +5 -7
  177. scipy/io/_netcdf.py +15 -5
  178. scipy/io/_test_fortran.cpython-312-darwin.so +0 -0
  179. scipy/io/arff/tests/test_arffread.py +3 -3
  180. scipy/io/matlab/__init__.py +5 -3
  181. scipy/io/matlab/_mio.py +4 -1
  182. scipy/io/matlab/_mio5.py +19 -13
  183. scipy/io/matlab/_mio5_utils.cpython-312-darwin.so +0 -0
  184. scipy/io/matlab/_mio_utils.cpython-312-darwin.so +0 -0
  185. scipy/io/matlab/_miobase.py +4 -1
  186. scipy/io/matlab/_streams.cpython-312-darwin.so +0 -0
  187. scipy/io/matlab/tests/test_mio.py +46 -18
  188. scipy/io/matlab/tests/test_mio_funcs.py +1 -1
  189. scipy/io/tests/test_mmio.py +7 -1
  190. scipy/io/tests/test_wavfile.py +41 -0
  191. scipy/io/wavfile.py +57 -10
  192. scipy/linalg/_basic.py +113 -86
  193. scipy/linalg/_cythonized_array_utils.cpython-312-darwin.so +0 -0
  194. scipy/linalg/_decomp.py +22 -9
  195. scipy/linalg/_decomp_cholesky.py +28 -13
  196. scipy/linalg/_decomp_cossin.py +45 -30
  197. scipy/linalg/_decomp_interpolative.cpython-312-darwin.so +0 -0
  198. scipy/linalg/_decomp_ldl.py +4 -1
  199. scipy/linalg/_decomp_lu.py +18 -6
  200. scipy/linalg/_decomp_lu_cython.cpython-312-darwin.so +0 -0
  201. scipy/linalg/_decomp_polar.py +2 -0
  202. scipy/linalg/_decomp_qr.py +6 -2
  203. scipy/linalg/_decomp_qz.py +3 -0
  204. scipy/linalg/_decomp_schur.py +3 -1
  205. scipy/linalg/_decomp_svd.py +13 -2
  206. scipy/linalg/_decomp_update.cpython-312-darwin.so +0 -0
  207. scipy/linalg/_expm_frechet.py +4 -0
  208. scipy/linalg/_fblas.cpython-312-darwin.so +0 -0
  209. scipy/linalg/_flapack.cpython-312-darwin.so +0 -0
  210. scipy/linalg/_linalg_pythran.cpython-312-darwin.so +0 -0
  211. scipy/linalg/_matfuncs.py +187 -4
  212. scipy/linalg/_matfuncs_expm.cpython-312-darwin.so +0 -0
  213. scipy/linalg/_matfuncs_schur_sqrtm.cpython-312-darwin.so +0 -0
  214. scipy/linalg/_matfuncs_sqrtm.py +1 -99
  215. scipy/linalg/_matfuncs_sqrtm_triu.cpython-312-darwin.so +0 -0
  216. scipy/linalg/_procrustes.py +2 -0
  217. scipy/linalg/_sketches.py +17 -6
  218. scipy/linalg/_solve_toeplitz.cpython-312-darwin.so +0 -0
  219. scipy/linalg/_solvers.py +7 -2
  220. scipy/linalg/_special_matrices.py +26 -36
  221. scipy/linalg/blas.py +35 -24
  222. scipy/linalg/cython_blas.cpython-312-darwin.so +0 -0
  223. scipy/linalg/cython_lapack.cpython-312-darwin.so +0 -0
  224. scipy/linalg/lapack.py +22 -2
  225. scipy/linalg/tests/_cython_examples/meson.build +7 -0
  226. scipy/linalg/tests/test_basic.py +31 -16
  227. scipy/linalg/tests/test_batch.py +588 -0
  228. scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
  229. scipy/linalg/tests/test_decomp.py +40 -3
  230. scipy/linalg/tests/test_decomp_cossin.py +14 -0
  231. scipy/linalg/tests/test_decomp_ldl.py +1 -1
  232. scipy/linalg/tests/test_lapack.py +115 -7
  233. scipy/linalg/tests/test_matfuncs.py +157 -102
  234. scipy/linalg/tests/test_procrustes.py +0 -7
  235. scipy/linalg/tests/test_solve_toeplitz.py +1 -1
  236. scipy/linalg/tests/test_special_matrices.py +1 -5
  237. scipy/ndimage/__init__.py +1 -0
  238. scipy/ndimage/_cytest.cpython-312-darwin.so +0 -0
  239. scipy/ndimage/_delegators.py +8 -2
  240. scipy/ndimage/_filters.py +453 -5
  241. scipy/ndimage/_interpolation.py +36 -6
  242. scipy/ndimage/_measurements.py +4 -2
  243. scipy/ndimage/_morphology.py +5 -0
  244. scipy/ndimage/_nd_image.cpython-312-darwin.so +0 -0
  245. scipy/ndimage/_ni_docstrings.py +5 -1
  246. scipy/ndimage/_ni_label.cpython-312-darwin.so +0 -0
  247. scipy/ndimage/_ni_support.py +1 -5
  248. scipy/ndimage/_rank_filter_1d.cpython-312-darwin.so +0 -0
  249. scipy/ndimage/_support_alternative_backends.py +18 -6
  250. scipy/ndimage/tests/test_filters.py +370 -259
  251. scipy/ndimage/tests/test_fourier.py +7 -9
  252. scipy/ndimage/tests/test_interpolation.py +68 -61
  253. scipy/ndimage/tests/test_measurements.py +18 -35
  254. scipy/ndimage/tests/test_morphology.py +143 -131
  255. scipy/ndimage/tests/test_splines.py +1 -3
  256. scipy/odr/__odrpack.cpython-312-darwin.so +0 -0
  257. scipy/optimize/_basinhopping.py +13 -7
  258. scipy/optimize/_bglu_dense.cpython-312-darwin.so +0 -0
  259. scipy/optimize/_bracket.py +17 -24
  260. scipy/optimize/_chandrupatla.py +9 -10
  261. scipy/optimize/_cobyla_py.py +104 -123
  262. scipy/optimize/_constraints.py +14 -10
  263. scipy/optimize/_differentiable_functions.py +371 -230
  264. scipy/optimize/_differentialevolution.py +4 -3
  265. scipy/optimize/_direct.cpython-312-darwin.so +0 -0
  266. scipy/optimize/_dual_annealing.py +1 -1
  267. scipy/optimize/_elementwise.py +1 -4
  268. scipy/optimize/_group_columns.cpython-312-darwin.so +0 -0
  269. scipy/optimize/_lbfgsb.cpython-312-darwin.so +0 -0
  270. scipy/optimize/_lbfgsb_py.py +80 -24
  271. scipy/optimize/_linprog_doc.py +2 -2
  272. scipy/optimize/_linprog_highs.py +2 -2
  273. scipy/optimize/_linprog_ip.py +25 -10
  274. scipy/optimize/_linprog_util.py +14 -16
  275. scipy/optimize/_lsap.cpython-312-darwin.so +0 -0
  276. scipy/optimize/_lsq/common.py +3 -3
  277. scipy/optimize/_lsq/dogbox.py +16 -2
  278. scipy/optimize/_lsq/givens_elimination.cpython-312-darwin.so +0 -0
  279. scipy/optimize/_lsq/least_squares.py +198 -126
  280. scipy/optimize/_lsq/lsq_linear.py +6 -6
  281. scipy/optimize/_lsq/trf.py +35 -8
  282. scipy/optimize/_milp.py +3 -1
  283. scipy/optimize/_minimize.py +105 -36
  284. scipy/optimize/_minpack.cpython-312-darwin.so +0 -0
  285. scipy/optimize/_minpack_py.py +21 -14
  286. scipy/optimize/_moduleTNC.cpython-312-darwin.so +0 -0
  287. scipy/optimize/_nnls.py +20 -21
  288. scipy/optimize/_nonlin.py +34 -3
  289. scipy/optimize/_numdiff.py +288 -110
  290. scipy/optimize/_optimize.py +86 -48
  291. scipy/optimize/_pava_pybind.cpython-312-darwin.so +0 -0
  292. scipy/optimize/_remove_redundancy.py +5 -5
  293. scipy/optimize/_root_scalar.py +1 -1
  294. scipy/optimize/_shgo.py +6 -0
  295. scipy/optimize/_shgo_lib/_complex.py +1 -1
  296. scipy/optimize/_slsqp_py.py +216 -124
  297. scipy/optimize/_slsqplib.cpython-312-darwin.so +0 -0
  298. scipy/optimize/_spectral.py +1 -1
  299. scipy/optimize/_tnc.py +8 -1
  300. scipy/optimize/_trlib/_trlib.cpython-312-darwin.so +0 -0
  301. scipy/optimize/_trustregion.py +20 -6
  302. scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
  303. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
  304. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
  305. scipy/optimize/_trustregion_constr/projections.py +12 -8
  306. scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
  307. scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
  308. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
  309. scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
  310. scipy/optimize/_trustregion_exact.py +0 -1
  311. scipy/optimize/_zeros.cpython-312-darwin.so +0 -0
  312. scipy/optimize/_zeros_py.py +97 -17
  313. scipy/optimize/cython_optimize/_zeros.cpython-312-darwin.so +0 -0
  314. scipy/optimize/slsqp.py +0 -1
  315. scipy/optimize/tests/test__basinhopping.py +1 -1
  316. scipy/optimize/tests/test__differential_evolution.py +4 -4
  317. scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
  318. scipy/optimize/tests/test__numdiff.py +66 -22
  319. scipy/optimize/tests/test__remove_redundancy.py +2 -2
  320. scipy/optimize/tests/test__shgo.py +9 -1
  321. scipy/optimize/tests/test_bracket.py +36 -46
  322. scipy/optimize/tests/test_chandrupatla.py +133 -135
  323. scipy/optimize/tests/test_cobyla.py +74 -45
  324. scipy/optimize/tests/test_constraints.py +1 -1
  325. scipy/optimize/tests/test_differentiable_functions.py +226 -6
  326. scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
  327. scipy/optimize/tests/test_least_squares.py +125 -13
  328. scipy/optimize/tests/test_linear_assignment.py +3 -3
  329. scipy/optimize/tests/test_linprog.py +3 -3
  330. scipy/optimize/tests/test_lsq_linear.py +6 -6
  331. scipy/optimize/tests/test_minimize_constrained.py +2 -2
  332. scipy/optimize/tests/test_minpack.py +4 -4
  333. scipy/optimize/tests/test_nnls.py +43 -3
  334. scipy/optimize/tests/test_nonlin.py +36 -0
  335. scipy/optimize/tests/test_optimize.py +98 -20
  336. scipy/optimize/tests/test_slsqp.py +36 -4
  337. scipy/optimize/tests/test_zeros.py +34 -1
  338. scipy/signal/__init__.py +12 -23
  339. scipy/signal/_delegators.py +568 -0
  340. scipy/signal/_filter_design.py +459 -241
  341. scipy/signal/_fir_filter_design.py +262 -90
  342. scipy/signal/_lti_conversion.py +3 -2
  343. scipy/signal/_ltisys.py +118 -91
  344. scipy/signal/_max_len_seq_inner.cpython-312-darwin.so +0 -0
  345. scipy/signal/_peak_finding_utils.cpython-312-darwin.so +0 -0
  346. scipy/signal/_polyutils.py +172 -0
  347. scipy/signal/_short_time_fft.py +519 -70
  348. scipy/signal/_signal_api.py +30 -0
  349. scipy/signal/_signaltools.py +719 -399
  350. scipy/signal/_sigtools.cpython-312-darwin.so +0 -0
  351. scipy/signal/_sosfilt.cpython-312-darwin.so +0 -0
  352. scipy/signal/_spectral_py.py +230 -50
  353. scipy/signal/_spline.cpython-312-darwin.so +0 -0
  354. scipy/signal/_spline_filters.py +108 -68
  355. scipy/signal/_support_alternative_backends.py +73 -0
  356. scipy/signal/_upfirdn.py +4 -1
  357. scipy/signal/_upfirdn_apply.cpython-312-darwin.so +0 -0
  358. scipy/signal/_waveforms.py +2 -11
  359. scipy/signal/_wavelets.py +1 -1
  360. scipy/signal/fir_filter_design.py +1 -0
  361. scipy/signal/spline.py +4 -11
  362. scipy/signal/tests/_scipy_spectral_test_shim.py +2 -171
  363. scipy/signal/tests/test_bsplines.py +114 -79
  364. scipy/signal/tests/test_cont2discrete.py +9 -2
  365. scipy/signal/tests/test_filter_design.py +721 -481
  366. scipy/signal/tests/test_fir_filter_design.py +332 -140
  367. scipy/signal/tests/test_savitzky_golay.py +4 -3
  368. scipy/signal/tests/test_short_time_fft.py +221 -3
  369. scipy/signal/tests/test_signaltools.py +2145 -1349
  370. scipy/signal/tests/test_spectral.py +50 -6
  371. scipy/signal/tests/test_splines.py +161 -96
  372. scipy/signal/tests/test_upfirdn.py +84 -50
  373. scipy/signal/tests/test_waveforms.py +20 -0
  374. scipy/signal/tests/test_windows.py +607 -466
  375. scipy/signal/windows/_windows.py +287 -148
  376. scipy/sparse/__init__.py +23 -4
  377. scipy/sparse/_base.py +270 -108
  378. scipy/sparse/_bsr.py +7 -4
  379. scipy/sparse/_compressed.py +59 -231
  380. scipy/sparse/_construct.py +90 -38
  381. scipy/sparse/_coo.py +115 -181
  382. scipy/sparse/_csc.py +4 -4
  383. scipy/sparse/_csparsetools.cpython-312-darwin.so +0 -0
  384. scipy/sparse/_csr.py +2 -2
  385. scipy/sparse/_data.py +48 -48
  386. scipy/sparse/_dia.py +105 -18
  387. scipy/sparse/_dok.py +0 -23
  388. scipy/sparse/_index.py +4 -4
  389. scipy/sparse/_matrix.py +23 -0
  390. scipy/sparse/_sparsetools.cpython-312-darwin.so +0 -0
  391. scipy/sparse/_sputils.py +37 -22
  392. scipy/sparse/base.py +0 -9
  393. scipy/sparse/bsr.py +0 -14
  394. scipy/sparse/compressed.py +0 -23
  395. scipy/sparse/construct.py +0 -6
  396. scipy/sparse/coo.py +0 -14
  397. scipy/sparse/csc.py +0 -3
  398. scipy/sparse/csgraph/_flow.cpython-312-darwin.so +0 -0
  399. scipy/sparse/csgraph/_matching.cpython-312-darwin.so +0 -0
  400. scipy/sparse/csgraph/_min_spanning_tree.cpython-312-darwin.so +0 -0
  401. scipy/sparse/csgraph/_reordering.cpython-312-darwin.so +0 -0
  402. scipy/sparse/csgraph/_shortest_path.cpython-312-darwin.so +0 -0
  403. scipy/sparse/csgraph/_tools.cpython-312-darwin.so +0 -0
  404. scipy/sparse/csgraph/_traversal.cpython-312-darwin.so +0 -0
  405. scipy/sparse/csgraph/tests/test_matching.py +14 -2
  406. scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
  407. scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
  408. scipy/sparse/csr.py +0 -5
  409. scipy/sparse/data.py +1 -6
  410. scipy/sparse/dia.py +0 -7
  411. scipy/sparse/dok.py +0 -10
  412. scipy/sparse/linalg/_dsolve/_superlu.cpython-312-darwin.so +0 -0
  413. scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
  414. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
  415. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-312-darwin.so +0 -0
  416. scipy/sparse/linalg/_eigen/arpack/arpack.py +23 -17
  417. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
  418. scipy/sparse/linalg/_interface.py +17 -18
  419. scipy/sparse/linalg/_isolve/_gcrotmk.py +4 -4
  420. scipy/sparse/linalg/_isolve/iterative.py +51 -45
  421. scipy/sparse/linalg/_isolve/lgmres.py +6 -6
  422. scipy/sparse/linalg/_isolve/minres.py +5 -5
  423. scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
  424. scipy/sparse/linalg/_isolve/utils.py +2 -8
  425. scipy/sparse/linalg/_matfuncs.py +1 -1
  426. scipy/sparse/linalg/_norm.py +1 -1
  427. scipy/sparse/linalg/_propack/_cpropack.cpython-312-darwin.so +0 -0
  428. scipy/sparse/linalg/_propack/_dpropack.cpython-312-darwin.so +0 -0
  429. scipy/sparse/linalg/_propack/_spropack.cpython-312-darwin.so +0 -0
  430. scipy/sparse/linalg/_propack/_zpropack.cpython-312-darwin.so +0 -0
  431. scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
  432. scipy/sparse/linalg/tests/test_pydata_sparse.py +14 -0
  433. scipy/sparse/tests/test_arithmetic1d.py +5 -2
  434. scipy/sparse/tests/test_base.py +214 -42
  435. scipy/sparse/tests/test_common1d.py +7 -7
  436. scipy/sparse/tests/test_construct.py +1 -1
  437. scipy/sparse/tests/test_coo.py +272 -4
  438. scipy/sparse/tests/test_sparsetools.py +5 -0
  439. scipy/sparse/tests/test_sputils.py +36 -7
  440. scipy/spatial/_ckdtree.cpython-312-darwin.so +0 -0
  441. scipy/spatial/_distance_pybind.cpython-312-darwin.so +0 -0
  442. scipy/spatial/_distance_wrap.cpython-312-darwin.so +0 -0
  443. scipy/spatial/_hausdorff.cpython-312-darwin.so +0 -0
  444. scipy/spatial/_qhull.cpython-312-darwin.so +0 -0
  445. scipy/spatial/_voronoi.cpython-312-darwin.so +0 -0
  446. scipy/spatial/distance.py +49 -42
  447. scipy/spatial/tests/test_distance.py +15 -1
  448. scipy/spatial/tests/test_kdtree.py +1 -0
  449. scipy/spatial/tests/test_qhull.py +7 -2
  450. scipy/spatial/transform/__init__.py +5 -3
  451. scipy/spatial/transform/_rigid_transform.cpython-312-darwin.so +0 -0
  452. scipy/spatial/transform/_rotation.cpython-312-darwin.so +0 -0
  453. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  454. scipy/spatial/transform/tests/test_rotation.py +1213 -832
  455. scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
  456. scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
  457. scipy/special/__init__.py +1 -47
  458. scipy/special/_add_newdocs.py +34 -772
  459. scipy/special/_basic.py +22 -25
  460. scipy/special/_comb.cpython-312-darwin.so +0 -0
  461. scipy/special/_ellip_harm_2.cpython-312-darwin.so +0 -0
  462. scipy/special/_gufuncs.cpython-312-darwin.so +0 -0
  463. scipy/special/_logsumexp.py +67 -58
  464. scipy/special/_orthogonal.pyi +1 -1
  465. scipy/special/_specfun.cpython-312-darwin.so +0 -0
  466. scipy/special/_special_ufuncs.cpython-312-darwin.so +0 -0
  467. scipy/special/_spherical_bessel.py +4 -4
  468. scipy/special/_support_alternative_backends.py +212 -119
  469. scipy/special/_test_internal.cpython-312-darwin.so +0 -0
  470. scipy/special/_testutils.py +4 -4
  471. scipy/special/_ufuncs.cpython-312-darwin.so +0 -0
  472. scipy/special/_ufuncs.pyi +1 -0
  473. scipy/special/_ufuncs.pyx +215 -1400
  474. scipy/special/_ufuncs_cxx.cpython-312-darwin.so +0 -0
  475. scipy/special/_ufuncs_cxx.pxd +2 -15
  476. scipy/special/_ufuncs_cxx.pyx +5 -44
  477. scipy/special/_ufuncs_cxx_defs.h +2 -16
  478. scipy/special/_ufuncs_defs.h +0 -8
  479. scipy/special/cython_special.cpython-312-darwin.so +0 -0
  480. scipy/special/cython_special.pxd +1 -1
  481. scipy/special/tests/_cython_examples/meson.build +10 -1
  482. scipy/special/tests/test_basic.py +153 -20
  483. scipy/special/tests/test_boost_ufuncs.py +3 -0
  484. scipy/special/tests/test_cdflib.py +35 -11
  485. scipy/special/tests/test_gammainc.py +16 -0
  486. scipy/special/tests/test_hyp2f1.py +2 -2
  487. scipy/special/tests/test_log1mexp.py +85 -0
  488. scipy/special/tests/test_logsumexp.py +206 -64
  489. scipy/special/tests/test_mpmath.py +1 -0
  490. scipy/special/tests/test_nan_inputs.py +1 -1
  491. scipy/special/tests/test_orthogonal.py +17 -18
  492. scipy/special/tests/test_sf_error.py +3 -2
  493. scipy/special/tests/test_sph_harm.py +6 -7
  494. scipy/special/tests/test_support_alternative_backends.py +211 -76
  495. scipy/stats/__init__.py +4 -1
  496. scipy/stats/_ansari_swilk_statistics.cpython-312-darwin.so +0 -0
  497. scipy/stats/_axis_nan_policy.py +5 -12
  498. scipy/stats/_biasedurn.cpython-312-darwin.so +0 -0
  499. scipy/stats/_continued_fraction.py +387 -0
  500. scipy/stats/_continuous_distns.py +277 -310
  501. scipy/stats/_correlation.py +1 -1
  502. scipy/stats/_covariance.py +6 -3
  503. scipy/stats/_discrete_distns.py +39 -32
  504. scipy/stats/_distn_infrastructure.py +39 -12
  505. scipy/stats/_distribution_infrastructure.py +920 -238
  506. scipy/stats/_entropy.py +9 -10
  507. scipy/{_lib → stats}/_finite_differences.py +1 -1
  508. scipy/stats/_hypotests.py +83 -50
  509. scipy/stats/_kde.py +53 -49
  510. scipy/stats/_ksstats.py +1 -1
  511. scipy/stats/_levy_stable/__init__.py +7 -15
  512. scipy/stats/_levy_stable/levyst.cpython-312-darwin.so +0 -0
  513. scipy/stats/_morestats.py +118 -73
  514. scipy/stats/_mstats_basic.py +13 -17
  515. scipy/stats/_mstats_extras.py +8 -8
  516. scipy/stats/_multivariate.py +89 -113
  517. scipy/stats/_new_distributions.py +97 -20
  518. scipy/stats/_page_trend_test.py +12 -5
  519. scipy/stats/_probability_distribution.py +265 -43
  520. scipy/stats/_qmc.py +14 -9
  521. scipy/stats/_qmc_cy.cpython-312-darwin.so +0 -0
  522. scipy/stats/_qmvnt.py +16 -95
  523. scipy/stats/_qmvnt_cy.cpython-312-darwin.so +0 -0
  524. scipy/stats/_quantile.py +335 -0
  525. scipy/stats/_rcont/rcont.cpython-312-darwin.so +0 -0
  526. scipy/stats/_resampling.py +5 -30
  527. scipy/stats/_sampling.py +1 -1
  528. scipy/stats/_sobol.cpython-312-darwin.so +0 -0
  529. scipy/stats/_stats.cpython-312-darwin.so +0 -0
  530. scipy/stats/_stats_mstats_common.py +21 -2
  531. scipy/stats/_stats_py.py +551 -477
  532. scipy/stats/_stats_pythran.cpython-312-darwin.so +0 -0
  533. scipy/stats/_unuran/unuran_wrapper.cpython-312-darwin.so +0 -0
  534. scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
  535. scipy/stats/_variation.py +6 -8
  536. scipy/stats/_wilcoxon.py +13 -7
  537. scipy/stats/tests/common_tests.py +6 -4
  538. scipy/stats/tests/test_axis_nan_policy.py +62 -24
  539. scipy/stats/tests/test_continued_fraction.py +173 -0
  540. scipy/stats/tests/test_continuous.py +379 -60
  541. scipy/stats/tests/test_continuous_basic.py +18 -12
  542. scipy/stats/tests/test_discrete_basic.py +14 -8
  543. scipy/stats/tests/test_discrete_distns.py +16 -16
  544. scipy/stats/tests/test_distributions.py +95 -75
  545. scipy/stats/tests/test_entropy.py +40 -48
  546. scipy/stats/tests/test_fit.py +4 -3
  547. scipy/stats/tests/test_hypotests.py +153 -24
  548. scipy/stats/tests/test_kdeoth.py +109 -41
  549. scipy/stats/tests/test_marray.py +289 -0
  550. scipy/stats/tests/test_morestats.py +81 -49
  551. scipy/stats/tests/test_mstats_basic.py +3 -3
  552. scipy/stats/tests/test_multivariate.py +434 -83
  553. scipy/stats/tests/test_qmc.py +13 -10
  554. scipy/stats/tests/test_quantile.py +199 -0
  555. scipy/stats/tests/test_rank.py +119 -112
  556. scipy/stats/tests/test_resampling.py +47 -56
  557. scipy/stats/tests/test_sampling.py +9 -4
  558. scipy/stats/tests/test_stats.py +799 -939
  559. scipy/stats/tests/test_variation.py +8 -6
  560. scipy/version.py +2 -2
  561. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/LICENSE.txt +4 -4
  562. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/METADATA +11 -11
  563. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/RECORD +564 -571
  564. scipy-1.16.0.dist-info/WHEEL +6 -0
  565. scipy/_lib/array_api_extra/_funcs.py +0 -484
  566. scipy/_lib/array_api_extra/_typing.py +0 -8
  567. scipy/interpolate/_bspl.cpython-312-darwin.so +0 -0
  568. scipy/optimize/_cobyla.cpython-312-darwin.so +0 -0
  569. scipy/optimize/_cython_nnls.cpython-312-darwin.so +0 -0
  570. scipy/optimize/_slsqp.cpython-312-darwin.so +0 -0
  571. scipy/spatial/qhull_src/COPYING.txt +0 -38
  572. scipy/special/libsf_error_state.dylib +0 -0
  573. scipy/special/tests/test_log_softmax.py +0 -109
  574. scipy/special/tests/test_xsf_cuda.py +0 -114
  575. scipy/special/xsf/binom.h +0 -89
  576. scipy/special/xsf/cdflib.h +0 -100
  577. scipy/special/xsf/cephes/airy.h +0 -307
  578. scipy/special/xsf/cephes/besselpoly.h +0 -51
  579. scipy/special/xsf/cephes/beta.h +0 -257
  580. scipy/special/xsf/cephes/cbrt.h +0 -131
  581. scipy/special/xsf/cephes/chbevl.h +0 -85
  582. scipy/special/xsf/cephes/chdtr.h +0 -193
  583. scipy/special/xsf/cephes/const.h +0 -87
  584. scipy/special/xsf/cephes/ellie.h +0 -293
  585. scipy/special/xsf/cephes/ellik.h +0 -251
  586. scipy/special/xsf/cephes/ellpe.h +0 -107
  587. scipy/special/xsf/cephes/ellpk.h +0 -117
  588. scipy/special/xsf/cephes/expn.h +0 -260
  589. scipy/special/xsf/cephes/gamma.h +0 -398
  590. scipy/special/xsf/cephes/hyp2f1.h +0 -596
  591. scipy/special/xsf/cephes/hyperg.h +0 -361
  592. scipy/special/xsf/cephes/i0.h +0 -149
  593. scipy/special/xsf/cephes/i1.h +0 -158
  594. scipy/special/xsf/cephes/igam.h +0 -421
  595. scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
  596. scipy/special/xsf/cephes/igami.h +0 -313
  597. scipy/special/xsf/cephes/j0.h +0 -225
  598. scipy/special/xsf/cephes/j1.h +0 -198
  599. scipy/special/xsf/cephes/jv.h +0 -715
  600. scipy/special/xsf/cephes/k0.h +0 -164
  601. scipy/special/xsf/cephes/k1.h +0 -163
  602. scipy/special/xsf/cephes/kn.h +0 -243
  603. scipy/special/xsf/cephes/lanczos.h +0 -112
  604. scipy/special/xsf/cephes/ndtr.h +0 -275
  605. scipy/special/xsf/cephes/poch.h +0 -85
  606. scipy/special/xsf/cephes/polevl.h +0 -167
  607. scipy/special/xsf/cephes/psi.h +0 -194
  608. scipy/special/xsf/cephes/rgamma.h +0 -111
  609. scipy/special/xsf/cephes/scipy_iv.h +0 -811
  610. scipy/special/xsf/cephes/shichi.h +0 -248
  611. scipy/special/xsf/cephes/sici.h +0 -224
  612. scipy/special/xsf/cephes/sindg.h +0 -221
  613. scipy/special/xsf/cephes/tandg.h +0 -139
  614. scipy/special/xsf/cephes/trig.h +0 -58
  615. scipy/special/xsf/cephes/unity.h +0 -186
  616. scipy/special/xsf/cephes/zeta.h +0 -172
  617. scipy/special/xsf/config.h +0 -304
  618. scipy/special/xsf/digamma.h +0 -205
  619. scipy/special/xsf/error.h +0 -57
  620. scipy/special/xsf/evalpoly.h +0 -47
  621. scipy/special/xsf/expint.h +0 -266
  622. scipy/special/xsf/hyp2f1.h +0 -694
  623. scipy/special/xsf/iv_ratio.h +0 -173
  624. scipy/special/xsf/lambertw.h +0 -150
  625. scipy/special/xsf/loggamma.h +0 -163
  626. scipy/special/xsf/sici.h +0 -200
  627. scipy/special/xsf/tools.h +0 -427
  628. scipy/special/xsf/trig.h +0 -164
  629. scipy/special/xsf/wright_bessel.h +0 -843
  630. scipy/special/xsf/zlog1.h +0 -35
  631. scipy/stats/_mvn.cpython-312-darwin.so +0 -0
  632. scipy-1.15.3.dist-info/WHEEL +0 -4
@@ -83,9 +83,10 @@ def compare_coeffs_to_alt(window_length, order):
83
83
  for pos in [None] + list(range(window_length)):
84
84
  h1 = savgol_coeffs(window_length, order, pos=pos, use='dot')
85
85
  h2 = alt_sg_coeffs(window_length, order, pos=pos)
86
- xp_assert_close(h1, h2, atol=1e-10,
87
- err_msg=("window_length = %d, order = %d, pos = %s" %
88
- (window_length, order, pos)))
86
+ xp_assert_close(
87
+ h1, h2, atol=1e-10,
88
+ err_msg=f"window_length = {window_length}, order = {order}, pos = {pos}"
89
+ )
89
90
 
90
91
 
91
92
  def test_sg_coeffs_compare():
@@ -26,11 +26,11 @@ import pytest
26
26
  from scipy._lib._array_api import xp_assert_close, xp_assert_equal
27
27
  from scipy.fft import fftshift
28
28
  from scipy.stats import norm as normal_distribution # type: ignore
29
- from scipy.signal import get_window, welch, stft, istft, spectrogram
29
+ from scipy.signal import check_COLA, get_window, welch, stft, istft, spectrogram
30
30
 
31
31
  from scipy.signal._short_time_fft import FFT_MODE_TYPE, \
32
- _calc_dual_canonical_window, ShortTimeFFT, PAD_TYPE
33
- from scipy.signal.windows import gaussian
32
+ _calc_dual_canonical_window, closest_STFT_dual_window, ShortTimeFFT, PAD_TYPE
33
+ from scipy.signal.windows import blackman, gaussian, hamming, nuttall, triang
34
34
 
35
35
 
36
36
  def test__calc_dual_canonical_window_roundtrip():
@@ -59,6 +59,132 @@ def test__calc_dual_canonical_window_exceptions():
59
59
  with pytest.raises(ValueError, match="Parameter 'win' cannot be of int.*"):
60
60
  _calc_dual_canonical_window(np.ones(4, dtype=int), 1)
61
61
 
62
+ def test_closest_STFT_dual_window_exceptions():
63
+ """Raise all exceptions in `closest_STFT_dual_window`."""
64
+ with pytest.raises(ValueError, match="Parameters `win` and `desired_dual` are.*"):
65
+ closest_STFT_dual_window(np.ones(4), 2, np.ones(5))
66
+ with pytest.raises(ValueError, match="Parameters `win` and `desired_dual` are.*"):
67
+ closest_STFT_dual_window(np.ones((4, 1)), 2, np.ones(4))
68
+ with pytest.raises(ValueError, match="Parameter win must have finite entries!"):
69
+ closest_STFT_dual_window(np.ones(4)*np.nan, 2, np.ones(4))
70
+ with pytest.raises(ValueError, match="Parameter desired_dual must have finite.*"):
71
+ closest_STFT_dual_window(np.ones(4), 2, np.ones(4)*np.nan)
72
+ with pytest.raises(ValueError, match="Parameter hop=20 is not an integer.*"):
73
+ closest_STFT_dual_window(np.ones(4), 20, np.ones(4))
74
+ with pytest.raises(ValueError, match="Parameter hop=2.0 is not an integer.*"):
75
+ # noinspection PyTypeChecker
76
+ closest_STFT_dual_window(np.ones(4), 2., np.ones(4))
77
+
78
+ with pytest.raises(ValueError, match="Unable to calculate scaled closest dual.*"):
79
+ closest_STFT_dual_window(np.ones(4), 2, np.zeros(4), scaled=True)
80
+
81
+
82
+ @pytest.mark.parametrize("scaled", (True, False))
83
+ @pytest.mark.parametrize('sym_win', (False, True))
84
+ @pytest.mark.parametrize('hop', (8, 9))
85
+ @pytest.mark.parametrize('m', (16, 17))
86
+ @pytest.mark.parametrize('win_name', ('hann', 'hamming'))
87
+ def test_closest_STFT_dual_window_roundtrip(win_name, m, hop, sym_win, scaled):
88
+ """Do roundtrip, i.e., compare dual of dual windows.
89
+
90
+ The default for parameter `desired_dual` is also verified.
91
+ """
92
+ win = get_window(win_name, m, not sym_win)
93
+ d1, s1 = closest_STFT_dual_window(win, hop, np.ones_like(win), scaled=scaled)
94
+ d2, s2 = closest_STFT_dual_window(win, hop, scaled=scaled) # equals d1, s1
95
+ d3, s3 = closest_STFT_dual_window(d1, hop, win * s1, scaled=True) # roundtrip
96
+
97
+ # Validate default for parameter `desired_dual` works (hard coded => assert ok):
98
+ xp_assert_equal(d2, d1, err_msg="Default for parameter `desired_dual` is not ok!")
99
+ assert s2 == s1, "Default for parameter `desired_dual` is not ok!"
100
+
101
+ res = np.finfo(win.dtype).resolution * 5
102
+ xp_assert_close(s1*s3, 1., atol=res, err_msg="Invalid Scale factors")
103
+ xp_assert_close(d3, win, atol=res, err_msg="Roundtrip failed!")
104
+
105
+ if scaled: # check that scaling factor is correct:
106
+ d3, _ = closest_STFT_dual_window(win, hop, np.ones(m) * s1, scaled=False)
107
+ xp_assert_close(d3, d1, atol=res, err_msg="Roundtrip failed!")
108
+
109
+
110
+ @pytest.mark.parametrize('scaled', (False, True))
111
+ def test_closest_STFT_dual_window_STFT_roundtrip(scaled):
112
+ """STFT Roundtrip correctness of closest dual window. """
113
+ np.random.seed(5613830)
114
+ n, m_num, hop = 15, 7, 3
115
+ w, desires_dual = hamming(m_num), triang(m_num)
116
+ d, _ = closest_STFT_dual_window(w, hop, desires_dual, scaled=scaled)
117
+
118
+ SFT = ShortTimeFFT(w, hop=hop, dual_win=d, fs=1, scale_to=None, phase_shift=None)
119
+ x = 10 * np.random.randn(n)
120
+ Sx = SFT.stft(x)
121
+ y = SFT.istft(Sx, 0, n)
122
+
123
+ atol = np.finfo(w.dtype).resolution * 10
124
+ xp_assert_close(y, x, atol=atol, err_msg="Invalid closest window")
125
+
126
+
127
+ @pytest.mark.parametrize('scaled', (False, True))
128
+ def test_closest_STFT_dual_window_STFT_roundtrip_complex(scaled):
129
+ """STFT Roundtrip correctness of closest dual window with complex values. """
130
+ np.random.seed(34905436)
131
+ n, m_num, hop = 15, 7, 3
132
+ win = 1j*hamming(m_num) + nuttall(m_num)
133
+ desires_dual = 1j*triang(m_num) + blackman(m_num)
134
+ dual, s = closest_STFT_dual_window(win, hop, desires_dual, scaled=scaled)
135
+
136
+ SFT = ShortTimeFFT(win, hop=hop, dual_win=dual, fs=1, fft_mode='twosided',
137
+ scale_to=None, phase_shift=None)
138
+ x = 10 * np.random.randn(n) + 10j * np.random.randn(n)
139
+ Sx = SFT.stft(x)
140
+ y = SFT.istft(Sx, 0, n)
141
+
142
+ atol = np.finfo(win.dtype).resolution * 10
143
+ xp_assert_close(y, x, atol=atol, err_msg=f"Invalid complex closest window ({s=})")
144
+
145
+
146
+ @pytest.mark.parametrize("win_name, nperseg, noverlap, scale_fac", ([
147
+ ('boxcar', 16, 8, 1/2),
148
+ ('boxcar', 18, 12, 1/3),
149
+ ('boxcar', 16, 12, 1/4),
150
+ ('bartlett', 16, 8, 1.),
151
+ ('bartlett', 16, 12, 1/2),
152
+ ('bartlett', 30, 25, 1/3),
153
+ ('hann', 16, 8, 1.),
154
+ ('hann', 18, 12, 2/3),
155
+ ('hann', 16, 12, 1/2),
156
+ ('blackman', 9, 6, 50/63),
157
+ ('boxcar', 8, 7, 1/8)])) # hop = 1
158
+ def test_closest_STFT_dual_window_cola(win_name, nperseg, noverlap, scale_fac):
159
+ """Test if `closest_STFT_dual_window` generalizes `check_COLA`.
160
+
161
+ The parameters were taken from the `check_COLA` documentation.
162
+ Note that `check_COLA` only guarantees the existence of a dual window with constant
163
+ values but not that those values are unity (which is clear, when investigating the
164
+ 'boxcar' examples). The values for `scale_fac` were determined empirically.
165
+ """
166
+ desired_dual = get_window(win_name, nperseg, fftbins=True)
167
+ assert check_COLA(desired_dual, nperseg, noverlap), "COLA cond. violated!"
168
+
169
+ win = np.ones(nperseg) # check scaled window:
170
+ d_s, s = closest_STFT_dual_window(win, nperseg-noverlap, desired_dual, scaled=True)
171
+
172
+ res = np.finfo(desired_dual.dtype).resolution
173
+ rel_tol_d = max(abs(d_s))*res*3
174
+ xp_assert_close(s, scale_fac, atol=res*10,
175
+ err_msg=f"Scale factor off by {s/scale_fac}")
176
+ xp_assert_close(d_s, desired_dual*scale_fac, atol=res*10, rtol=rel_tol_d,
177
+ err_msg="Calculated incorrect scaled window!")
178
+
179
+ # check unscaled window:
180
+ d_u, u = closest_STFT_dual_window(win * scale_fac, nperseg - noverlap,
181
+ desired_dual, scaled=False)
182
+
183
+ # this should be hard-coded not computed, so no need for allclose
184
+ assert u == 1., "Scaling factor not 1 for parameter `scaled=True`!"
185
+ xp_assert_close(d_u, desired_dual, atol=res*10, rtol=rel_tol_d,
186
+ err_msg="Calculated incorrect unscaled window!")
187
+
62
188
 
63
189
  def test_invalid_initializer_parameters():
64
190
  """Verify that exceptions get raised on invalid parameters when
@@ -180,6 +306,7 @@ def test_exceptions_fft_mode_complex_win(m: FFT_MODE_TYPE):
180
306
  def test_invalid_fft_mode_RuntimeError():
181
307
  """Ensure exception gets raised when property `fft_mode` is invalid. """
182
308
  SFT = ShortTimeFFT(np.ones(8), hop=4, fs=1)
309
+ # noinspection PyTypeChecker
183
310
  SFT._fft_mode = 'invalid_typ'
184
311
 
185
312
  with pytest.raises(RuntimeError):
@@ -222,6 +349,78 @@ def test_from_window(win_params, Nx: int):
222
349
  assert v2 == v0, f"SFT2.{n_}={v2} does not equal SFT0.{n_}={v0}"
223
350
 
224
351
 
352
+ def test_from_win_equals_dual_exceptions():
353
+ """Raise all occurring exceptions in `ShortTimeFFT.from_closest_win_equals_dual`.
354
+ """
355
+ with pytest.raises(ValueError, match="Parameter desired_win is not 1d, but.*"):
356
+ ShortTimeFFT.from_win_equals_dual(np.ones((3, 4)), hop=1, fs=1)
357
+ with pytest.raises(ValueError, match="Parameter desired_win cannot be of int.*"):
358
+ ShortTimeFFT.from_win_equals_dual(np.ones(4, dtype=int), hop=1, fs=1)
359
+ with pytest.raises(ValueError, match="Parameter desired_win is not 1d, but.*"):
360
+ ShortTimeFFT.from_win_equals_dual(np.array([]), hop=1, fs=1)
361
+ with pytest.raises(ValueError, match="Parameter desired_win must have finite.*"):
362
+ ShortTimeFFT.from_win_equals_dual(np.ones(3) * np.inf, hop=1, fs=1)
363
+ with pytest.raises(ValueError, match="Parameter hop=0 is not an integer .*"):
364
+ ShortTimeFFT.from_win_equals_dual(np.ones(4), hop=0, fs=1)
365
+ with pytest.raises(ValueError, match="Parameter hop=5 is not an integer .*"):
366
+ ShortTimeFFT.from_win_equals_dual(np.ones(4), hop=5, fs=1)
367
+
368
+ with pytest.raises(ValueError, match="P.+ desired_win does not have valid.*"):
369
+ w = np.array([1, 0, 1, 0, 1], dtype=float)
370
+ ShortTimeFFT.from_win_equals_dual(w, hop=2, fs=1)
371
+ with pytest.raises(ValueError, match="Parameter scale_to='invalid' not in.*"):
372
+ # noinspection PyTypeChecker
373
+ ShortTimeFFT.from_win_equals_dual(w, hop=2, fs=1, scale_to='invalid')
374
+
375
+ @pytest.mark.parametrize('fft_bins', (True, False))
376
+ @pytest.mark.parametrize('m, hop', [(16, 8), (16, 7), (17, 8), (17, 9), (16, 16)])
377
+ def test_from_win_equals_dual_params(m, hop, fft_bins):
378
+ """Test windows parameterizations for `ShortTimeFFT.from_closest_win_equals_dual`.
379
+
380
+ The flattop window is used since it also has negative values.
381
+ """
382
+ desired_win = get_window('flattop', m, fftbins=fft_bins)
383
+ SFT0 = ShortTimeFFT.from_win_equals_dual(desired_win, hop, fs=1)
384
+ xp_assert_close(SFT0.dual_win, SFT0.win, err_msg="win must equals dual window!")
385
+
386
+ SFT1 = ShortTimeFFT(SFT0.win, hop, fs=1)
387
+ xp_assert_close(SFT1.dual_win, SFT0.win, err_msg="dual win isn't canonical win!")
388
+
389
+
390
+ @pytest.mark.parametrize('fft_bins', (True, False))
391
+ @pytest.mark.parametrize('m, hop', [(16, 8), (16, 7), (17, 8), (17, 9), (16, 16)])
392
+ @pytest.mark.parametrize('scale_to', (None, 'unitary'))
393
+ def test_from_win_equals_dual_roundtrip(m, hop, fft_bins, scale_to):
394
+ """Testing roundtrip verifies that the dual window is correct.
395
+ """
396
+ desired_win = get_window('flattop', m, fftbins=fft_bins)
397
+ SFT0 = ShortTimeFFT.from_win_equals_dual(desired_win, hop, fs=1)
398
+
399
+ x = np.cos(np.arange(2*m)**2)
400
+ x1 = SFT0.istft(SFT0.stft(x), 0, len(x))
401
+ xp_assert_close(x1, x, err_msg="Roundtrip for win equaling its dual failed!")
402
+
403
+
404
+ def test_from_win_equals_dual_unitary():
405
+ """Check that STFT can be unitary mapping. """
406
+ m, hop = 8, 4
407
+ des_win = get_window('hann', m)
408
+ SFT = ShortTimeFFT.from_win_equals_dual(des_win, hop, 1, fft_mode='twosided',
409
+ scale_to='unitary')
410
+ # Orthogonal signals:
411
+ x, y = np.tile([-1, -1, 1, 1], 4), np.tile([1, -1, -1, 1], 4)
412
+ Sxx, Sxy = SFT.spectrogram(x), SFT.spectrogram(x, y)
413
+
414
+ atol = np.finfo(Sxx.dtype).resolution
415
+ assert sum(x * y) == 0
416
+ xp_assert_close(np.sum(Sxx), np.sum(x ** 2, dtype=Sxx.dtype), atol=atol,
417
+ err_msg="Energies do not match!")
418
+ xp_assert_close(np.sum(Sxy), 0.0j, atol=atol,
419
+ err_msg="STFT scalar product of Sx and Sy not 0!")
420
+ xp_assert_close(SFT.dual_win, SFT.win*SFT.m_num, atol=atol,
421
+ err_msg="Wrong factor for dual_win/win!")
422
+
423
+
225
424
  def test_dual_win_roundtrip():
226
425
  """Verify the duality of `win` and `dual_win`.
227
426
 
@@ -516,6 +715,25 @@ def test_minimal_length_signal(m_num):
516
715
  SFT.istft(Sx[:, :-1], k1=n)
517
716
 
518
717
 
718
+ def test_compare_stft_detrend():
719
+ """Test the detrending in `ShortTimeFFT.stft_detrend()`. """
720
+ SFT = ShortTimeFFT(np.ones(4), 4, fs=1)
721
+ x0 = np.zeros(4) # signal without trend
722
+ x1 = x0 + 3 # signal with constant trend
723
+ x2 = x0 + np.arange(len(x0)) # signal with linear trend
724
+
725
+ kw = dict(k_offset=2, p1=1) # we want only one slice
726
+ Sx0 = SFT.stft(x0, **kw) # no trend
727
+ Sx1 = SFT.stft_detrend(x1, detr='constant', **kw)
728
+ Sx2 = SFT.stft_detrend(x2, detr='linear', **kw)
729
+ Sx3 = SFT.stft_detrend(x1, detr=lambda x: x - np.mean(x), **kw)
730
+
731
+ atol = np.finfo(Sx0.dtype).resolution * 5 # needed to compare with array of zeros
732
+ xp_assert_close(Sx1, Sx0, atol=atol, err_msg="Constant detrending failed!")
733
+ xp_assert_close(Sx0, Sx2, atol=atol, err_msg="Linear detrending failed!")
734
+ xp_assert_close(Sx0, Sx3, atol=atol, err_msg="Detrending using a function failed!")
735
+
736
+
519
737
  def test_tutorial_stft_sliding_win():
520
738
  """Verify example in "Sliding Windows" subsection from the "User Guide".
521
739