scipy 1.16.1__cp314-cp314-musllinux_1_2_x86_64.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 (1420) hide show
  1. scipy/__config__.py +161 -0
  2. scipy/__init__.py +138 -0
  3. scipy/_cyutility.cpython-314-x86_64-linux-musl.so +0 -0
  4. scipy/_distributor_init.py +18 -0
  5. scipy/_lib/__init__.py +14 -0
  6. scipy/_lib/_array_api.py +931 -0
  7. scipy/_lib/_array_api_compat_vendor.py +9 -0
  8. scipy/_lib/_array_api_no_0d.py +103 -0
  9. scipy/_lib/_bunch.py +229 -0
  10. scipy/_lib/_ccallback.py +251 -0
  11. scipy/_lib/_ccallback_c.cpython-314-x86_64-linux-musl.so +0 -0
  12. scipy/_lib/_disjoint_set.py +254 -0
  13. scipy/_lib/_docscrape.py +761 -0
  14. scipy/_lib/_elementwise_iterative_method.py +346 -0
  15. scipy/_lib/_fpumode.cpython-314-x86_64-linux-musl.so +0 -0
  16. scipy/_lib/_gcutils.py +105 -0
  17. scipy/_lib/_pep440.py +487 -0
  18. scipy/_lib/_sparse.py +41 -0
  19. scipy/_lib/_test_ccallback.cpython-314-x86_64-linux-musl.so +0 -0
  20. scipy/_lib/_test_deprecation_call.cpython-314-x86_64-linux-musl.so +0 -0
  21. scipy/_lib/_test_deprecation_def.cpython-314-x86_64-linux-musl.so +0 -0
  22. scipy/_lib/_testutils.py +373 -0
  23. scipy/_lib/_threadsafety.py +58 -0
  24. scipy/_lib/_tmpdirs.py +86 -0
  25. scipy/_lib/_uarray/LICENSE +29 -0
  26. scipy/_lib/_uarray/__init__.py +116 -0
  27. scipy/_lib/_uarray/_backend.py +707 -0
  28. scipy/_lib/_uarray/_uarray.cpython-314-x86_64-linux-musl.so +0 -0
  29. scipy/_lib/_util.py +1283 -0
  30. scipy/_lib/array_api_compat/__init__.py +22 -0
  31. scipy/_lib/array_api_compat/_internal.py +59 -0
  32. scipy/_lib/array_api_compat/common/__init__.py +1 -0
  33. scipy/_lib/array_api_compat/common/_aliases.py +727 -0
  34. scipy/_lib/array_api_compat/common/_fft.py +213 -0
  35. scipy/_lib/array_api_compat/common/_helpers.py +1058 -0
  36. scipy/_lib/array_api_compat/common/_linalg.py +232 -0
  37. scipy/_lib/array_api_compat/common/_typing.py +192 -0
  38. scipy/_lib/array_api_compat/cupy/__init__.py +13 -0
  39. scipy/_lib/array_api_compat/cupy/_aliases.py +156 -0
  40. scipy/_lib/array_api_compat/cupy/_info.py +336 -0
  41. scipy/_lib/array_api_compat/cupy/_typing.py +31 -0
  42. scipy/_lib/array_api_compat/cupy/fft.py +36 -0
  43. scipy/_lib/array_api_compat/cupy/linalg.py +49 -0
  44. scipy/_lib/array_api_compat/dask/__init__.py +0 -0
  45. scipy/_lib/array_api_compat/dask/array/__init__.py +12 -0
  46. scipy/_lib/array_api_compat/dask/array/_aliases.py +376 -0
  47. scipy/_lib/array_api_compat/dask/array/_info.py +416 -0
  48. scipy/_lib/array_api_compat/dask/array/fft.py +21 -0
  49. scipy/_lib/array_api_compat/dask/array/linalg.py +72 -0
  50. scipy/_lib/array_api_compat/numpy/__init__.py +28 -0
  51. scipy/_lib/array_api_compat/numpy/_aliases.py +190 -0
  52. scipy/_lib/array_api_compat/numpy/_info.py +366 -0
  53. scipy/_lib/array_api_compat/numpy/_typing.py +30 -0
  54. scipy/_lib/array_api_compat/numpy/fft.py +35 -0
  55. scipy/_lib/array_api_compat/numpy/linalg.py +143 -0
  56. scipy/_lib/array_api_compat/torch/__init__.py +22 -0
  57. scipy/_lib/array_api_compat/torch/_aliases.py +855 -0
  58. scipy/_lib/array_api_compat/torch/_info.py +369 -0
  59. scipy/_lib/array_api_compat/torch/_typing.py +3 -0
  60. scipy/_lib/array_api_compat/torch/fft.py +85 -0
  61. scipy/_lib/array_api_compat/torch/linalg.py +121 -0
  62. scipy/_lib/array_api_extra/__init__.py +38 -0
  63. scipy/_lib/array_api_extra/_delegation.py +171 -0
  64. scipy/_lib/array_api_extra/_lib/__init__.py +1 -0
  65. scipy/_lib/array_api_extra/_lib/_at.py +463 -0
  66. scipy/_lib/array_api_extra/_lib/_backends.py +46 -0
  67. scipy/_lib/array_api_extra/_lib/_funcs.py +937 -0
  68. scipy/_lib/array_api_extra/_lib/_lazy.py +357 -0
  69. scipy/_lib/array_api_extra/_lib/_testing.py +278 -0
  70. scipy/_lib/array_api_extra/_lib/_utils/__init__.py +1 -0
  71. scipy/_lib/array_api_extra/_lib/_utils/_compat.py +74 -0
  72. scipy/_lib/array_api_extra/_lib/_utils/_compat.pyi +45 -0
  73. scipy/_lib/array_api_extra/_lib/_utils/_helpers.py +559 -0
  74. scipy/_lib/array_api_extra/_lib/_utils/_typing.py +10 -0
  75. scipy/_lib/array_api_extra/_lib/_utils/_typing.pyi +105 -0
  76. scipy/_lib/array_api_extra/testing.py +359 -0
  77. scipy/_lib/cobyqa/__init__.py +20 -0
  78. scipy/_lib/cobyqa/framework.py +1240 -0
  79. scipy/_lib/cobyqa/main.py +1506 -0
  80. scipy/_lib/cobyqa/models.py +1529 -0
  81. scipy/_lib/cobyqa/problem.py +1296 -0
  82. scipy/_lib/cobyqa/settings.py +132 -0
  83. scipy/_lib/cobyqa/subsolvers/__init__.py +14 -0
  84. scipy/_lib/cobyqa/subsolvers/geometry.py +387 -0
  85. scipy/_lib/cobyqa/subsolvers/optim.py +1203 -0
  86. scipy/_lib/cobyqa/utils/__init__.py +18 -0
  87. scipy/_lib/cobyqa/utils/exceptions.py +22 -0
  88. scipy/_lib/cobyqa/utils/math.py +77 -0
  89. scipy/_lib/cobyqa/utils/versions.py +67 -0
  90. scipy/_lib/decorator.py +399 -0
  91. scipy/_lib/deprecation.py +274 -0
  92. scipy/_lib/doccer.py +366 -0
  93. scipy/_lib/messagestream.cpython-314-x86_64-linux-musl.so +0 -0
  94. scipy/_lib/pyprima/__init__.py +212 -0
  95. scipy/_lib/pyprima/cobyla/__init__.py +0 -0
  96. scipy/_lib/pyprima/cobyla/cobyla.py +559 -0
  97. scipy/_lib/pyprima/cobyla/cobylb.py +714 -0
  98. scipy/_lib/pyprima/cobyla/geometry.py +226 -0
  99. scipy/_lib/pyprima/cobyla/initialize.py +215 -0
  100. scipy/_lib/pyprima/cobyla/trustregion.py +492 -0
  101. scipy/_lib/pyprima/cobyla/update.py +289 -0
  102. scipy/_lib/pyprima/common/__init__.py +0 -0
  103. scipy/_lib/pyprima/common/_bounds.py +34 -0
  104. scipy/_lib/pyprima/common/_linear_constraints.py +46 -0
  105. scipy/_lib/pyprima/common/_nonlinear_constraints.py +54 -0
  106. scipy/_lib/pyprima/common/_project.py +173 -0
  107. scipy/_lib/pyprima/common/checkbreak.py +93 -0
  108. scipy/_lib/pyprima/common/consts.py +47 -0
  109. scipy/_lib/pyprima/common/evaluate.py +99 -0
  110. scipy/_lib/pyprima/common/history.py +38 -0
  111. scipy/_lib/pyprima/common/infos.py +30 -0
  112. scipy/_lib/pyprima/common/linalg.py +435 -0
  113. scipy/_lib/pyprima/common/message.py +290 -0
  114. scipy/_lib/pyprima/common/powalg.py +131 -0
  115. scipy/_lib/pyprima/common/preproc.py +277 -0
  116. scipy/_lib/pyprima/common/present.py +5 -0
  117. scipy/_lib/pyprima/common/ratio.py +54 -0
  118. scipy/_lib/pyprima/common/redrho.py +47 -0
  119. scipy/_lib/pyprima/common/selectx.py +296 -0
  120. scipy/_lib/tests/__init__.py +0 -0
  121. scipy/_lib/tests/test__gcutils.py +110 -0
  122. scipy/_lib/tests/test__pep440.py +67 -0
  123. scipy/_lib/tests/test__testutils.py +32 -0
  124. scipy/_lib/tests/test__threadsafety.py +51 -0
  125. scipy/_lib/tests/test__util.py +641 -0
  126. scipy/_lib/tests/test_array_api.py +322 -0
  127. scipy/_lib/tests/test_bunch.py +169 -0
  128. scipy/_lib/tests/test_ccallback.py +196 -0
  129. scipy/_lib/tests/test_config.py +45 -0
  130. scipy/_lib/tests/test_deprecation.py +10 -0
  131. scipy/_lib/tests/test_doccer.py +143 -0
  132. scipy/_lib/tests/test_import_cycles.py +18 -0
  133. scipy/_lib/tests/test_public_api.py +482 -0
  134. scipy/_lib/tests/test_scipy_version.py +28 -0
  135. scipy/_lib/tests/test_tmpdirs.py +48 -0
  136. scipy/_lib/tests/test_warnings.py +137 -0
  137. scipy/_lib/uarray.py +31 -0
  138. scipy/cluster/__init__.py +31 -0
  139. scipy/cluster/_hierarchy.cpython-314-x86_64-linux-musl.so +0 -0
  140. scipy/cluster/_optimal_leaf_ordering.cpython-314-x86_64-linux-musl.so +0 -0
  141. scipy/cluster/_vq.cpython-314-x86_64-linux-musl.so +0 -0
  142. scipy/cluster/hierarchy.py +4348 -0
  143. scipy/cluster/tests/__init__.py +0 -0
  144. scipy/cluster/tests/hierarchy_test_data.py +145 -0
  145. scipy/cluster/tests/test_disjoint_set.py +202 -0
  146. scipy/cluster/tests/test_hierarchy.py +1238 -0
  147. scipy/cluster/tests/test_vq.py +434 -0
  148. scipy/cluster/vq.py +832 -0
  149. scipy/conftest.py +683 -0
  150. scipy/constants/__init__.py +358 -0
  151. scipy/constants/_codata.py +2266 -0
  152. scipy/constants/_constants.py +369 -0
  153. scipy/constants/codata.py +21 -0
  154. scipy/constants/constants.py +53 -0
  155. scipy/constants/tests/__init__.py +0 -0
  156. scipy/constants/tests/test_codata.py +78 -0
  157. scipy/constants/tests/test_constants.py +83 -0
  158. scipy/datasets/__init__.py +90 -0
  159. scipy/datasets/_download_all.py +71 -0
  160. scipy/datasets/_fetchers.py +225 -0
  161. scipy/datasets/_registry.py +26 -0
  162. scipy/datasets/_utils.py +81 -0
  163. scipy/datasets/tests/__init__.py +0 -0
  164. scipy/datasets/tests/test_data.py +128 -0
  165. scipy/differentiate/__init__.py +27 -0
  166. scipy/differentiate/_differentiate.py +1129 -0
  167. scipy/differentiate/tests/__init__.py +0 -0
  168. scipy/differentiate/tests/test_differentiate.py +694 -0
  169. scipy/fft/__init__.py +114 -0
  170. scipy/fft/_backend.py +196 -0
  171. scipy/fft/_basic.py +1650 -0
  172. scipy/fft/_basic_backend.py +197 -0
  173. scipy/fft/_debug_backends.py +22 -0
  174. scipy/fft/_fftlog.py +223 -0
  175. scipy/fft/_fftlog_backend.py +200 -0
  176. scipy/fft/_helper.py +348 -0
  177. scipy/fft/_pocketfft/LICENSE.md +25 -0
  178. scipy/fft/_pocketfft/__init__.py +9 -0
  179. scipy/fft/_pocketfft/basic.py +251 -0
  180. scipy/fft/_pocketfft/helper.py +249 -0
  181. scipy/fft/_pocketfft/pypocketfft.cpython-314-x86_64-linux-musl.so +0 -0
  182. scipy/fft/_pocketfft/realtransforms.py +109 -0
  183. scipy/fft/_pocketfft/tests/__init__.py +0 -0
  184. scipy/fft/_pocketfft/tests/test_basic.py +1011 -0
  185. scipy/fft/_pocketfft/tests/test_real_transforms.py +505 -0
  186. scipy/fft/_realtransforms.py +706 -0
  187. scipy/fft/_realtransforms_backend.py +63 -0
  188. scipy/fft/tests/__init__.py +0 -0
  189. scipy/fft/tests/mock_backend.py +96 -0
  190. scipy/fft/tests/test_backend.py +98 -0
  191. scipy/fft/tests/test_basic.py +504 -0
  192. scipy/fft/tests/test_fftlog.py +215 -0
  193. scipy/fft/tests/test_helper.py +558 -0
  194. scipy/fft/tests/test_multithreading.py +84 -0
  195. scipy/fft/tests/test_real_transforms.py +247 -0
  196. scipy/fftpack/__init__.py +103 -0
  197. scipy/fftpack/_basic.py +428 -0
  198. scipy/fftpack/_helper.py +115 -0
  199. scipy/fftpack/_pseudo_diffs.py +554 -0
  200. scipy/fftpack/_realtransforms.py +598 -0
  201. scipy/fftpack/basic.py +20 -0
  202. scipy/fftpack/convolve.cpython-314-x86_64-linux-musl.so +0 -0
  203. scipy/fftpack/helper.py +19 -0
  204. scipy/fftpack/pseudo_diffs.py +22 -0
  205. scipy/fftpack/realtransforms.py +19 -0
  206. scipy/fftpack/tests/__init__.py +0 -0
  207. scipy/fftpack/tests/fftw_double_ref.npz +0 -0
  208. scipy/fftpack/tests/fftw_longdouble_ref.npz +0 -0
  209. scipy/fftpack/tests/fftw_single_ref.npz +0 -0
  210. scipy/fftpack/tests/test.npz +0 -0
  211. scipy/fftpack/tests/test_basic.py +877 -0
  212. scipy/fftpack/tests/test_helper.py +54 -0
  213. scipy/fftpack/tests/test_import.py +33 -0
  214. scipy/fftpack/tests/test_pseudo_diffs.py +388 -0
  215. scipy/fftpack/tests/test_real_transforms.py +836 -0
  216. scipy/integrate/__init__.py +122 -0
  217. scipy/integrate/_bvp.py +1160 -0
  218. scipy/integrate/_cubature.py +729 -0
  219. scipy/integrate/_dop.cpython-314-x86_64-linux-musl.so +0 -0
  220. scipy/integrate/_ivp/__init__.py +8 -0
  221. scipy/integrate/_ivp/base.py +290 -0
  222. scipy/integrate/_ivp/bdf.py +478 -0
  223. scipy/integrate/_ivp/common.py +451 -0
  224. scipy/integrate/_ivp/dop853_coefficients.py +193 -0
  225. scipy/integrate/_ivp/ivp.py +755 -0
  226. scipy/integrate/_ivp/lsoda.py +224 -0
  227. scipy/integrate/_ivp/radau.py +572 -0
  228. scipy/integrate/_ivp/rk.py +601 -0
  229. scipy/integrate/_ivp/tests/__init__.py +0 -0
  230. scipy/integrate/_ivp/tests/test_ivp.py +1287 -0
  231. scipy/integrate/_ivp/tests/test_rk.py +37 -0
  232. scipy/integrate/_lebedev.py +5450 -0
  233. scipy/integrate/_lsoda.cpython-314-x86_64-linux-musl.so +0 -0
  234. scipy/integrate/_ode.py +1395 -0
  235. scipy/integrate/_odepack.cpython-314-x86_64-linux-musl.so +0 -0
  236. scipy/integrate/_odepack_py.py +273 -0
  237. scipy/integrate/_quad_vec.py +674 -0
  238. scipy/integrate/_quadpack.cpython-314-x86_64-linux-musl.so +0 -0
  239. scipy/integrate/_quadpack_py.py +1283 -0
  240. scipy/integrate/_quadrature.py +1336 -0
  241. scipy/integrate/_rules/__init__.py +12 -0
  242. scipy/integrate/_rules/_base.py +518 -0
  243. scipy/integrate/_rules/_gauss_kronrod.py +202 -0
  244. scipy/integrate/_rules/_gauss_legendre.py +62 -0
  245. scipy/integrate/_rules/_genz_malik.py +210 -0
  246. scipy/integrate/_tanhsinh.py +1385 -0
  247. scipy/integrate/_test_multivariate.cpython-314-x86_64-linux-musl.so +0 -0
  248. scipy/integrate/_test_odeint_banded.cpython-314-x86_64-linux-musl.so +0 -0
  249. scipy/integrate/_vode.cpython-314-x86_64-linux-musl.so +0 -0
  250. scipy/integrate/dop.py +15 -0
  251. scipy/integrate/lsoda.py +15 -0
  252. scipy/integrate/odepack.py +17 -0
  253. scipy/integrate/quadpack.py +23 -0
  254. scipy/integrate/tests/__init__.py +0 -0
  255. scipy/integrate/tests/test__quad_vec.py +211 -0
  256. scipy/integrate/tests/test_banded_ode_solvers.py +305 -0
  257. scipy/integrate/tests/test_bvp.py +714 -0
  258. scipy/integrate/tests/test_cubature.py +1375 -0
  259. scipy/integrate/tests/test_integrate.py +840 -0
  260. scipy/integrate/tests/test_odeint_jac.py +74 -0
  261. scipy/integrate/tests/test_quadpack.py +680 -0
  262. scipy/integrate/tests/test_quadrature.py +730 -0
  263. scipy/integrate/tests/test_tanhsinh.py +1171 -0
  264. scipy/integrate/vode.py +15 -0
  265. scipy/interpolate/__init__.py +228 -0
  266. scipy/interpolate/_bary_rational.py +715 -0
  267. scipy/interpolate/_bsplines.py +2469 -0
  268. scipy/interpolate/_cubic.py +973 -0
  269. scipy/interpolate/_dfitpack.cpython-314-x86_64-linux-musl.so +0 -0
  270. scipy/interpolate/_dierckx.cpython-314-x86_64-linux-musl.so +0 -0
  271. scipy/interpolate/_fitpack.cpython-314-x86_64-linux-musl.so +0 -0
  272. scipy/interpolate/_fitpack2.py +2397 -0
  273. scipy/interpolate/_fitpack_impl.py +811 -0
  274. scipy/interpolate/_fitpack_py.py +898 -0
  275. scipy/interpolate/_fitpack_repro.py +996 -0
  276. scipy/interpolate/_interpnd.cpython-314-x86_64-linux-musl.so +0 -0
  277. scipy/interpolate/_interpolate.py +2266 -0
  278. scipy/interpolate/_ndbspline.py +415 -0
  279. scipy/interpolate/_ndgriddata.py +329 -0
  280. scipy/interpolate/_pade.py +67 -0
  281. scipy/interpolate/_polyint.py +1025 -0
  282. scipy/interpolate/_ppoly.cpython-314-x86_64-linux-musl.so +0 -0
  283. scipy/interpolate/_rbf.py +290 -0
  284. scipy/interpolate/_rbfinterp.py +550 -0
  285. scipy/interpolate/_rbfinterp_pythran.cpython-314-x86_64-linux-musl.so +0 -0
  286. scipy/interpolate/_rgi.py +764 -0
  287. scipy/interpolate/_rgi_cython.cpython-314-x86_64-linux-musl.so +0 -0
  288. scipy/interpolate/dfitpack.py +24 -0
  289. scipy/interpolate/fitpack.py +31 -0
  290. scipy/interpolate/fitpack2.py +29 -0
  291. scipy/interpolate/interpnd.py +24 -0
  292. scipy/interpolate/interpolate.py +30 -0
  293. scipy/interpolate/ndgriddata.py +23 -0
  294. scipy/interpolate/polyint.py +24 -0
  295. scipy/interpolate/rbf.py +18 -0
  296. scipy/interpolate/tests/__init__.py +0 -0
  297. scipy/interpolate/tests/data/bug-1310.npz +0 -0
  298. scipy/interpolate/tests/data/estimate_gradients_hang.npy +0 -0
  299. scipy/interpolate/tests/data/gcvspl.npz +0 -0
  300. scipy/interpolate/tests/test_bary_rational.py +368 -0
  301. scipy/interpolate/tests/test_bsplines.py +3754 -0
  302. scipy/interpolate/tests/test_fitpack.py +519 -0
  303. scipy/interpolate/tests/test_fitpack2.py +1431 -0
  304. scipy/interpolate/tests/test_gil.py +64 -0
  305. scipy/interpolate/tests/test_interpnd.py +452 -0
  306. scipy/interpolate/tests/test_interpolate.py +2630 -0
  307. scipy/interpolate/tests/test_ndgriddata.py +308 -0
  308. scipy/interpolate/tests/test_pade.py +107 -0
  309. scipy/interpolate/tests/test_polyint.py +972 -0
  310. scipy/interpolate/tests/test_rbf.py +246 -0
  311. scipy/interpolate/tests/test_rbfinterp.py +534 -0
  312. scipy/interpolate/tests/test_rgi.py +1151 -0
  313. scipy/io/__init__.py +116 -0
  314. scipy/io/_fast_matrix_market/__init__.py +600 -0
  315. scipy/io/_fast_matrix_market/_fmm_core.cpython-314-x86_64-linux-musl.so +0 -0
  316. scipy/io/_fortran.py +354 -0
  317. scipy/io/_harwell_boeing/__init__.py +7 -0
  318. scipy/io/_harwell_boeing/_fortran_format_parser.py +316 -0
  319. scipy/io/_harwell_boeing/hb.py +571 -0
  320. scipy/io/_harwell_boeing/tests/__init__.py +0 -0
  321. scipy/io/_harwell_boeing/tests/test_fortran_format.py +74 -0
  322. scipy/io/_harwell_boeing/tests/test_hb.py +70 -0
  323. scipy/io/_idl.py +917 -0
  324. scipy/io/_mmio.py +968 -0
  325. scipy/io/_netcdf.py +1104 -0
  326. scipy/io/_test_fortran.cpython-314-x86_64-linux-musl.so +0 -0
  327. scipy/io/arff/__init__.py +28 -0
  328. scipy/io/arff/_arffread.py +873 -0
  329. scipy/io/arff/arffread.py +19 -0
  330. scipy/io/arff/tests/__init__.py +0 -0
  331. scipy/io/arff/tests/data/iris.arff +225 -0
  332. scipy/io/arff/tests/data/missing.arff +8 -0
  333. scipy/io/arff/tests/data/nodata.arff +11 -0
  334. scipy/io/arff/tests/data/quoted_nominal.arff +13 -0
  335. scipy/io/arff/tests/data/quoted_nominal_spaces.arff +13 -0
  336. scipy/io/arff/tests/data/test1.arff +10 -0
  337. scipy/io/arff/tests/data/test10.arff +8 -0
  338. scipy/io/arff/tests/data/test11.arff +11 -0
  339. scipy/io/arff/tests/data/test2.arff +15 -0
  340. scipy/io/arff/tests/data/test3.arff +6 -0
  341. scipy/io/arff/tests/data/test4.arff +11 -0
  342. scipy/io/arff/tests/data/test5.arff +26 -0
  343. scipy/io/arff/tests/data/test6.arff +12 -0
  344. scipy/io/arff/tests/data/test7.arff +15 -0
  345. scipy/io/arff/tests/data/test8.arff +12 -0
  346. scipy/io/arff/tests/data/test9.arff +14 -0
  347. scipy/io/arff/tests/test_arffread.py +421 -0
  348. scipy/io/harwell_boeing.py +17 -0
  349. scipy/io/idl.py +17 -0
  350. scipy/io/matlab/__init__.py +66 -0
  351. scipy/io/matlab/_byteordercodes.py +75 -0
  352. scipy/io/matlab/_mio.py +375 -0
  353. scipy/io/matlab/_mio4.py +632 -0
  354. scipy/io/matlab/_mio5.py +901 -0
  355. scipy/io/matlab/_mio5_params.py +281 -0
  356. scipy/io/matlab/_mio5_utils.cpython-314-x86_64-linux-musl.so +0 -0
  357. scipy/io/matlab/_mio_utils.cpython-314-x86_64-linux-musl.so +0 -0
  358. scipy/io/matlab/_miobase.py +435 -0
  359. scipy/io/matlab/_streams.cpython-314-x86_64-linux-musl.so +0 -0
  360. scipy/io/matlab/byteordercodes.py +17 -0
  361. scipy/io/matlab/mio.py +16 -0
  362. scipy/io/matlab/mio4.py +17 -0
  363. scipy/io/matlab/mio5.py +19 -0
  364. scipy/io/matlab/mio5_params.py +18 -0
  365. scipy/io/matlab/mio5_utils.py +17 -0
  366. scipy/io/matlab/mio_utils.py +17 -0
  367. scipy/io/matlab/miobase.py +16 -0
  368. scipy/io/matlab/streams.py +16 -0
  369. scipy/io/matlab/tests/__init__.py +0 -0
  370. scipy/io/matlab/tests/data/bad_miuint32.mat +0 -0
  371. scipy/io/matlab/tests/data/bad_miutf8_array_name.mat +0 -0
  372. scipy/io/matlab/tests/data/big_endian.mat +0 -0
  373. scipy/io/matlab/tests/data/broken_utf8.mat +0 -0
  374. scipy/io/matlab/tests/data/corrupted_zlib_checksum.mat +0 -0
  375. scipy/io/matlab/tests/data/corrupted_zlib_data.mat +0 -0
  376. scipy/io/matlab/tests/data/debigged_m4.mat +0 -0
  377. scipy/io/matlab/tests/data/japanese_utf8.txt +5 -0
  378. scipy/io/matlab/tests/data/little_endian.mat +0 -0
  379. scipy/io/matlab/tests/data/logical_sparse.mat +0 -0
  380. scipy/io/matlab/tests/data/malformed1.mat +0 -0
  381. scipy/io/matlab/tests/data/miuint32_for_miint32.mat +0 -0
  382. scipy/io/matlab/tests/data/miutf8_array_name.mat +0 -0
  383. scipy/io/matlab/tests/data/nasty_duplicate_fieldnames.mat +0 -0
  384. scipy/io/matlab/tests/data/one_by_zero_char.mat +0 -0
  385. scipy/io/matlab/tests/data/parabola.mat +0 -0
  386. scipy/io/matlab/tests/data/single_empty_string.mat +0 -0
  387. scipy/io/matlab/tests/data/some_functions.mat +0 -0
  388. scipy/io/matlab/tests/data/sqr.mat +0 -0
  389. scipy/io/matlab/tests/data/test3dmatrix_6.1_SOL2.mat +0 -0
  390. scipy/io/matlab/tests/data/test3dmatrix_6.5.1_GLNX86.mat +0 -0
  391. scipy/io/matlab/tests/data/test3dmatrix_7.1_GLNX86.mat +0 -0
  392. scipy/io/matlab/tests/data/test3dmatrix_7.4_GLNX86.mat +0 -0
  393. scipy/io/matlab/tests/data/test_empty_struct.mat +0 -0
  394. scipy/io/matlab/tests/data/test_mat4_le_floats.mat +0 -0
  395. scipy/io/matlab/tests/data/test_skip_variable.mat +0 -0
  396. scipy/io/matlab/tests/data/testbool_8_WIN64.mat +0 -0
  397. scipy/io/matlab/tests/data/testcell_6.1_SOL2.mat +0 -0
  398. scipy/io/matlab/tests/data/testcell_6.5.1_GLNX86.mat +0 -0
  399. scipy/io/matlab/tests/data/testcell_7.1_GLNX86.mat +0 -0
  400. scipy/io/matlab/tests/data/testcell_7.4_GLNX86.mat +0 -0
  401. scipy/io/matlab/tests/data/testcellnest_6.1_SOL2.mat +0 -0
  402. scipy/io/matlab/tests/data/testcellnest_6.5.1_GLNX86.mat +0 -0
  403. scipy/io/matlab/tests/data/testcellnest_7.1_GLNX86.mat +0 -0
  404. scipy/io/matlab/tests/data/testcellnest_7.4_GLNX86.mat +0 -0
  405. scipy/io/matlab/tests/data/testcomplex_4.2c_SOL2.mat +0 -0
  406. scipy/io/matlab/tests/data/testcomplex_6.1_SOL2.mat +0 -0
  407. scipy/io/matlab/tests/data/testcomplex_6.5.1_GLNX86.mat +0 -0
  408. scipy/io/matlab/tests/data/testcomplex_7.1_GLNX86.mat +0 -0
  409. scipy/io/matlab/tests/data/testcomplex_7.4_GLNX86.mat +0 -0
  410. scipy/io/matlab/tests/data/testdouble_4.2c_SOL2.mat +0 -0
  411. scipy/io/matlab/tests/data/testdouble_6.1_SOL2.mat +0 -0
  412. scipy/io/matlab/tests/data/testdouble_6.5.1_GLNX86.mat +0 -0
  413. scipy/io/matlab/tests/data/testdouble_7.1_GLNX86.mat +0 -0
  414. scipy/io/matlab/tests/data/testdouble_7.4_GLNX86.mat +0 -0
  415. scipy/io/matlab/tests/data/testemptycell_5.3_SOL2.mat +0 -0
  416. scipy/io/matlab/tests/data/testemptycell_6.5.1_GLNX86.mat +0 -0
  417. scipy/io/matlab/tests/data/testemptycell_7.1_GLNX86.mat +0 -0
  418. scipy/io/matlab/tests/data/testemptycell_7.4_GLNX86.mat +0 -0
  419. scipy/io/matlab/tests/data/testfunc_7.4_GLNX86.mat +0 -0
  420. scipy/io/matlab/tests/data/testhdf5_7.4_GLNX86.mat +0 -0
  421. scipy/io/matlab/tests/data/testmatrix_4.2c_SOL2.mat +0 -0
  422. scipy/io/matlab/tests/data/testmatrix_6.1_SOL2.mat +0 -0
  423. scipy/io/matlab/tests/data/testmatrix_6.5.1_GLNX86.mat +0 -0
  424. scipy/io/matlab/tests/data/testmatrix_7.1_GLNX86.mat +0 -0
  425. scipy/io/matlab/tests/data/testmatrix_7.4_GLNX86.mat +0 -0
  426. scipy/io/matlab/tests/data/testminus_4.2c_SOL2.mat +0 -0
  427. scipy/io/matlab/tests/data/testminus_6.1_SOL2.mat +0 -0
  428. scipy/io/matlab/tests/data/testminus_6.5.1_GLNX86.mat +0 -0
  429. scipy/io/matlab/tests/data/testminus_7.1_GLNX86.mat +0 -0
  430. scipy/io/matlab/tests/data/testminus_7.4_GLNX86.mat +0 -0
  431. scipy/io/matlab/tests/data/testmulti_4.2c_SOL2.mat +0 -0
  432. scipy/io/matlab/tests/data/testmulti_7.1_GLNX86.mat +0 -0
  433. scipy/io/matlab/tests/data/testmulti_7.4_GLNX86.mat +0 -0
  434. scipy/io/matlab/tests/data/testobject_6.1_SOL2.mat +0 -0
  435. scipy/io/matlab/tests/data/testobject_6.5.1_GLNX86.mat +0 -0
  436. scipy/io/matlab/tests/data/testobject_7.1_GLNX86.mat +0 -0
  437. scipy/io/matlab/tests/data/testobject_7.4_GLNX86.mat +0 -0
  438. scipy/io/matlab/tests/data/testonechar_4.2c_SOL2.mat +0 -0
  439. scipy/io/matlab/tests/data/testonechar_6.1_SOL2.mat +0 -0
  440. scipy/io/matlab/tests/data/testonechar_6.5.1_GLNX86.mat +0 -0
  441. scipy/io/matlab/tests/data/testonechar_7.1_GLNX86.mat +0 -0
  442. scipy/io/matlab/tests/data/testonechar_7.4_GLNX86.mat +0 -0
  443. scipy/io/matlab/tests/data/testscalarcell_7.4_GLNX86.mat +0 -0
  444. scipy/io/matlab/tests/data/testsimplecell.mat +0 -0
  445. scipy/io/matlab/tests/data/testsparse_4.2c_SOL2.mat +0 -0
  446. scipy/io/matlab/tests/data/testsparse_6.1_SOL2.mat +0 -0
  447. scipy/io/matlab/tests/data/testsparse_6.5.1_GLNX86.mat +0 -0
  448. scipy/io/matlab/tests/data/testsparse_7.1_GLNX86.mat +0 -0
  449. scipy/io/matlab/tests/data/testsparse_7.4_GLNX86.mat +0 -0
  450. scipy/io/matlab/tests/data/testsparsecomplex_4.2c_SOL2.mat +0 -0
  451. scipy/io/matlab/tests/data/testsparsecomplex_6.1_SOL2.mat +0 -0
  452. scipy/io/matlab/tests/data/testsparsecomplex_6.5.1_GLNX86.mat +0 -0
  453. scipy/io/matlab/tests/data/testsparsecomplex_7.1_GLNX86.mat +0 -0
  454. scipy/io/matlab/tests/data/testsparsecomplex_7.4_GLNX86.mat +0 -0
  455. scipy/io/matlab/tests/data/testsparsefloat_7.4_GLNX86.mat +0 -0
  456. scipy/io/matlab/tests/data/teststring_4.2c_SOL2.mat +0 -0
  457. scipy/io/matlab/tests/data/teststring_6.1_SOL2.mat +0 -0
  458. scipy/io/matlab/tests/data/teststring_6.5.1_GLNX86.mat +0 -0
  459. scipy/io/matlab/tests/data/teststring_7.1_GLNX86.mat +0 -0
  460. scipy/io/matlab/tests/data/teststring_7.4_GLNX86.mat +0 -0
  461. scipy/io/matlab/tests/data/teststringarray_4.2c_SOL2.mat +0 -0
  462. scipy/io/matlab/tests/data/teststringarray_6.1_SOL2.mat +0 -0
  463. scipy/io/matlab/tests/data/teststringarray_6.5.1_GLNX86.mat +0 -0
  464. scipy/io/matlab/tests/data/teststringarray_7.1_GLNX86.mat +0 -0
  465. scipy/io/matlab/tests/data/teststringarray_7.4_GLNX86.mat +0 -0
  466. scipy/io/matlab/tests/data/teststruct_6.1_SOL2.mat +0 -0
  467. scipy/io/matlab/tests/data/teststruct_6.5.1_GLNX86.mat +0 -0
  468. scipy/io/matlab/tests/data/teststruct_7.1_GLNX86.mat +0 -0
  469. scipy/io/matlab/tests/data/teststruct_7.4_GLNX86.mat +0 -0
  470. scipy/io/matlab/tests/data/teststructarr_6.1_SOL2.mat +0 -0
  471. scipy/io/matlab/tests/data/teststructarr_6.5.1_GLNX86.mat +0 -0
  472. scipy/io/matlab/tests/data/teststructarr_7.1_GLNX86.mat +0 -0
  473. scipy/io/matlab/tests/data/teststructarr_7.4_GLNX86.mat +0 -0
  474. scipy/io/matlab/tests/data/teststructnest_6.1_SOL2.mat +0 -0
  475. scipy/io/matlab/tests/data/teststructnest_6.5.1_GLNX86.mat +0 -0
  476. scipy/io/matlab/tests/data/teststructnest_7.1_GLNX86.mat +0 -0
  477. scipy/io/matlab/tests/data/teststructnest_7.4_GLNX86.mat +0 -0
  478. scipy/io/matlab/tests/data/testunicode_7.1_GLNX86.mat +0 -0
  479. scipy/io/matlab/tests/data/testunicode_7.4_GLNX86.mat +0 -0
  480. scipy/io/matlab/tests/data/testvec_4_GLNX86.mat +0 -0
  481. scipy/io/matlab/tests/test_byteordercodes.py +29 -0
  482. scipy/io/matlab/tests/test_mio.py +1399 -0
  483. scipy/io/matlab/tests/test_mio5_utils.py +179 -0
  484. scipy/io/matlab/tests/test_mio_funcs.py +51 -0
  485. scipy/io/matlab/tests/test_mio_utils.py +45 -0
  486. scipy/io/matlab/tests/test_miobase.py +32 -0
  487. scipy/io/matlab/tests/test_pathological.py +33 -0
  488. scipy/io/matlab/tests/test_streams.py +241 -0
  489. scipy/io/mmio.py +17 -0
  490. scipy/io/netcdf.py +17 -0
  491. scipy/io/tests/__init__.py +0 -0
  492. scipy/io/tests/data/Transparent Busy.ani +0 -0
  493. scipy/io/tests/data/array_float32_1d.sav +0 -0
  494. scipy/io/tests/data/array_float32_2d.sav +0 -0
  495. scipy/io/tests/data/array_float32_3d.sav +0 -0
  496. scipy/io/tests/data/array_float32_4d.sav +0 -0
  497. scipy/io/tests/data/array_float32_5d.sav +0 -0
  498. scipy/io/tests/data/array_float32_6d.sav +0 -0
  499. scipy/io/tests/data/array_float32_7d.sav +0 -0
  500. scipy/io/tests/data/array_float32_8d.sav +0 -0
  501. scipy/io/tests/data/array_float32_pointer_1d.sav +0 -0
  502. scipy/io/tests/data/array_float32_pointer_2d.sav +0 -0
  503. scipy/io/tests/data/array_float32_pointer_3d.sav +0 -0
  504. scipy/io/tests/data/array_float32_pointer_4d.sav +0 -0
  505. scipy/io/tests/data/array_float32_pointer_5d.sav +0 -0
  506. scipy/io/tests/data/array_float32_pointer_6d.sav +0 -0
  507. scipy/io/tests/data/array_float32_pointer_7d.sav +0 -0
  508. scipy/io/tests/data/array_float32_pointer_8d.sav +0 -0
  509. scipy/io/tests/data/example_1.nc +0 -0
  510. scipy/io/tests/data/example_2.nc +0 -0
  511. scipy/io/tests/data/example_3_maskedvals.nc +0 -0
  512. scipy/io/tests/data/fortran-3x3d-2i.dat +0 -0
  513. scipy/io/tests/data/fortran-mixed.dat +0 -0
  514. scipy/io/tests/data/fortran-sf8-11x1x10.dat +0 -0
  515. scipy/io/tests/data/fortran-sf8-15x10x22.dat +0 -0
  516. scipy/io/tests/data/fortran-sf8-1x1x1.dat +0 -0
  517. scipy/io/tests/data/fortran-sf8-1x1x5.dat +0 -0
  518. scipy/io/tests/data/fortran-sf8-1x1x7.dat +0 -0
  519. scipy/io/tests/data/fortran-sf8-1x3x5.dat +0 -0
  520. scipy/io/tests/data/fortran-si4-11x1x10.dat +0 -0
  521. scipy/io/tests/data/fortran-si4-15x10x22.dat +0 -0
  522. scipy/io/tests/data/fortran-si4-1x1x1.dat +0 -0
  523. scipy/io/tests/data/fortran-si4-1x1x5.dat +0 -0
  524. scipy/io/tests/data/fortran-si4-1x1x7.dat +0 -0
  525. scipy/io/tests/data/fortran-si4-1x3x5.dat +0 -0
  526. scipy/io/tests/data/invalid_pointer.sav +0 -0
  527. scipy/io/tests/data/null_pointer.sav +0 -0
  528. scipy/io/tests/data/scalar_byte.sav +0 -0
  529. scipy/io/tests/data/scalar_byte_descr.sav +0 -0
  530. scipy/io/tests/data/scalar_complex32.sav +0 -0
  531. scipy/io/tests/data/scalar_complex64.sav +0 -0
  532. scipy/io/tests/data/scalar_float32.sav +0 -0
  533. scipy/io/tests/data/scalar_float64.sav +0 -0
  534. scipy/io/tests/data/scalar_heap_pointer.sav +0 -0
  535. scipy/io/tests/data/scalar_int16.sav +0 -0
  536. scipy/io/tests/data/scalar_int32.sav +0 -0
  537. scipy/io/tests/data/scalar_int64.sav +0 -0
  538. scipy/io/tests/data/scalar_string.sav +0 -0
  539. scipy/io/tests/data/scalar_uint16.sav +0 -0
  540. scipy/io/tests/data/scalar_uint32.sav +0 -0
  541. scipy/io/tests/data/scalar_uint64.sav +0 -0
  542. scipy/io/tests/data/struct_arrays.sav +0 -0
  543. scipy/io/tests/data/struct_arrays_byte_idl80.sav +0 -0
  544. scipy/io/tests/data/struct_arrays_replicated.sav +0 -0
  545. scipy/io/tests/data/struct_arrays_replicated_3d.sav +0 -0
  546. scipy/io/tests/data/struct_inherit.sav +0 -0
  547. scipy/io/tests/data/struct_pointer_arrays.sav +0 -0
  548. scipy/io/tests/data/struct_pointer_arrays_replicated.sav +0 -0
  549. scipy/io/tests/data/struct_pointer_arrays_replicated_3d.sav +0 -0
  550. scipy/io/tests/data/struct_pointers.sav +0 -0
  551. scipy/io/tests/data/struct_pointers_replicated.sav +0 -0
  552. scipy/io/tests/data/struct_pointers_replicated_3d.sav +0 -0
  553. scipy/io/tests/data/struct_scalars.sav +0 -0
  554. scipy/io/tests/data/struct_scalars_replicated.sav +0 -0
  555. scipy/io/tests/data/struct_scalars_replicated_3d.sav +0 -0
  556. scipy/io/tests/data/test-1234Hz-le-1ch-10S-20bit-extra.wav +0 -0
  557. scipy/io/tests/data/test-44100Hz-2ch-32bit-float-be.wav +0 -0
  558. scipy/io/tests/data/test-44100Hz-2ch-32bit-float-le.wav +0 -0
  559. scipy/io/tests/data/test-44100Hz-be-1ch-4bytes.wav +0 -0
  560. scipy/io/tests/data/test-44100Hz-le-1ch-4bytes-early-eof-no-data.wav +0 -0
  561. scipy/io/tests/data/test-44100Hz-le-1ch-4bytes-early-eof.wav +0 -0
  562. scipy/io/tests/data/test-44100Hz-le-1ch-4bytes-incomplete-chunk.wav +0 -0
  563. scipy/io/tests/data/test-44100Hz-le-1ch-4bytes-rf64.wav +0 -0
  564. scipy/io/tests/data/test-44100Hz-le-1ch-4bytes.wav +0 -0
  565. scipy/io/tests/data/test-48000Hz-2ch-64bit-float-le-wavex.wav +0 -0
  566. scipy/io/tests/data/test-8000Hz-be-3ch-5S-24bit.wav +0 -0
  567. scipy/io/tests/data/test-8000Hz-le-1ch-1byte-ulaw.wav +0 -0
  568. scipy/io/tests/data/test-8000Hz-le-2ch-1byteu.wav +0 -0
  569. scipy/io/tests/data/test-8000Hz-le-3ch-5S-24bit-inconsistent.wav +0 -0
  570. scipy/io/tests/data/test-8000Hz-le-3ch-5S-24bit-rf64.wav +0 -0
  571. scipy/io/tests/data/test-8000Hz-le-3ch-5S-24bit.wav +0 -0
  572. scipy/io/tests/data/test-8000Hz-le-3ch-5S-36bit.wav +0 -0
  573. scipy/io/tests/data/test-8000Hz-le-3ch-5S-45bit.wav +0 -0
  574. scipy/io/tests/data/test-8000Hz-le-3ch-5S-53bit.wav +0 -0
  575. scipy/io/tests/data/test-8000Hz-le-3ch-5S-64bit.wav +0 -0
  576. scipy/io/tests/data/test-8000Hz-le-4ch-9S-12bit.wav +0 -0
  577. scipy/io/tests/data/test-8000Hz-le-5ch-9S-5bit.wav +0 -0
  578. scipy/io/tests/data/various_compressed.sav +0 -0
  579. scipy/io/tests/test_fortran.py +264 -0
  580. scipy/io/tests/test_idl.py +483 -0
  581. scipy/io/tests/test_mmio.py +831 -0
  582. scipy/io/tests/test_netcdf.py +550 -0
  583. scipy/io/tests/test_paths.py +93 -0
  584. scipy/io/tests/test_wavfile.py +501 -0
  585. scipy/io/wavfile.py +938 -0
  586. scipy/linalg/__init__.pxd +1 -0
  587. scipy/linalg/__init__.py +236 -0
  588. scipy/linalg/_basic.py +2146 -0
  589. scipy/linalg/_blas_subroutines.h +164 -0
  590. scipy/linalg/_cythonized_array_utils.cpython-314-x86_64-linux-musl.so +0 -0
  591. scipy/linalg/_cythonized_array_utils.pxd +40 -0
  592. scipy/linalg/_cythonized_array_utils.pyi +16 -0
  593. scipy/linalg/_decomp.py +1645 -0
  594. scipy/linalg/_decomp_cholesky.py +413 -0
  595. scipy/linalg/_decomp_cossin.py +236 -0
  596. scipy/linalg/_decomp_interpolative.cpython-314-x86_64-linux-musl.so +0 -0
  597. scipy/linalg/_decomp_ldl.py +356 -0
  598. scipy/linalg/_decomp_lu.py +401 -0
  599. scipy/linalg/_decomp_lu_cython.cpython-314-x86_64-linux-musl.so +0 -0
  600. scipy/linalg/_decomp_lu_cython.pyi +6 -0
  601. scipy/linalg/_decomp_polar.py +113 -0
  602. scipy/linalg/_decomp_qr.py +494 -0
  603. scipy/linalg/_decomp_qz.py +452 -0
  604. scipy/linalg/_decomp_schur.py +336 -0
  605. scipy/linalg/_decomp_svd.py +545 -0
  606. scipy/linalg/_decomp_update.cpython-314-x86_64-linux-musl.so +0 -0
  607. scipy/linalg/_expm_frechet.py +417 -0
  608. scipy/linalg/_fblas.cpython-314-x86_64-linux-musl.so +0 -0
  609. scipy/linalg/_flapack.cpython-314-x86_64-linux-musl.so +0 -0
  610. scipy/linalg/_lapack_subroutines.h +1521 -0
  611. scipy/linalg/_linalg_pythran.cpython-314-x86_64-linux-musl.so +0 -0
  612. scipy/linalg/_matfuncs.py +1050 -0
  613. scipy/linalg/_matfuncs_expm.cpython-314-x86_64-linux-musl.so +0 -0
  614. scipy/linalg/_matfuncs_expm.pyi +6 -0
  615. scipy/linalg/_matfuncs_inv_ssq.py +886 -0
  616. scipy/linalg/_matfuncs_schur_sqrtm.cpython-314-x86_64-linux-musl.so +0 -0
  617. scipy/linalg/_matfuncs_sqrtm.py +107 -0
  618. scipy/linalg/_matfuncs_sqrtm_triu.cpython-314-x86_64-linux-musl.so +0 -0
  619. scipy/linalg/_misc.py +191 -0
  620. scipy/linalg/_procrustes.py +113 -0
  621. scipy/linalg/_sketches.py +189 -0
  622. scipy/linalg/_solve_toeplitz.cpython-314-x86_64-linux-musl.so +0 -0
  623. scipy/linalg/_solvers.py +862 -0
  624. scipy/linalg/_special_matrices.py +1322 -0
  625. scipy/linalg/_testutils.py +65 -0
  626. scipy/linalg/basic.py +23 -0
  627. scipy/linalg/blas.py +495 -0
  628. scipy/linalg/cython_blas.cpython-314-x86_64-linux-musl.so +0 -0
  629. scipy/linalg/cython_blas.pxd +169 -0
  630. scipy/linalg/cython_blas.pyx +1432 -0
  631. scipy/linalg/cython_lapack.cpython-314-x86_64-linux-musl.so +0 -0
  632. scipy/linalg/cython_lapack.pxd +1528 -0
  633. scipy/linalg/cython_lapack.pyx +12045 -0
  634. scipy/linalg/decomp.py +23 -0
  635. scipy/linalg/decomp_cholesky.py +21 -0
  636. scipy/linalg/decomp_lu.py +21 -0
  637. scipy/linalg/decomp_qr.py +20 -0
  638. scipy/linalg/decomp_schur.py +21 -0
  639. scipy/linalg/decomp_svd.py +21 -0
  640. scipy/linalg/interpolative.py +989 -0
  641. scipy/linalg/lapack.py +1081 -0
  642. scipy/linalg/matfuncs.py +23 -0
  643. scipy/linalg/misc.py +21 -0
  644. scipy/linalg/special_matrices.py +22 -0
  645. scipy/linalg/tests/__init__.py +0 -0
  646. scipy/linalg/tests/_cython_examples/extending.pyx +23 -0
  647. scipy/linalg/tests/_cython_examples/meson.build +34 -0
  648. scipy/linalg/tests/data/carex_15_data.npz +0 -0
  649. scipy/linalg/tests/data/carex_18_data.npz +0 -0
  650. scipy/linalg/tests/data/carex_19_data.npz +0 -0
  651. scipy/linalg/tests/data/carex_20_data.npz +0 -0
  652. scipy/linalg/tests/data/carex_6_data.npz +0 -0
  653. scipy/linalg/tests/data/gendare_20170120_data.npz +0 -0
  654. scipy/linalg/tests/test_basic.py +2074 -0
  655. scipy/linalg/tests/test_batch.py +588 -0
  656. scipy/linalg/tests/test_blas.py +1127 -0
  657. scipy/linalg/tests/test_cython_blas.py +118 -0
  658. scipy/linalg/tests/test_cython_lapack.py +22 -0
  659. scipy/linalg/tests/test_cythonized_array_utils.py +130 -0
  660. scipy/linalg/tests/test_decomp.py +3189 -0
  661. scipy/linalg/tests/test_decomp_cholesky.py +268 -0
  662. scipy/linalg/tests/test_decomp_cossin.py +314 -0
  663. scipy/linalg/tests/test_decomp_ldl.py +137 -0
  664. scipy/linalg/tests/test_decomp_lu.py +308 -0
  665. scipy/linalg/tests/test_decomp_polar.py +110 -0
  666. scipy/linalg/tests/test_decomp_update.py +1701 -0
  667. scipy/linalg/tests/test_extending.py +46 -0
  668. scipy/linalg/tests/test_fblas.py +607 -0
  669. scipy/linalg/tests/test_interpolative.py +232 -0
  670. scipy/linalg/tests/test_lapack.py +3616 -0
  671. scipy/linalg/tests/test_matfuncs.py +1125 -0
  672. scipy/linalg/tests/test_matmul_toeplitz.py +136 -0
  673. scipy/linalg/tests/test_procrustes.py +214 -0
  674. scipy/linalg/tests/test_sketches.py +118 -0
  675. scipy/linalg/tests/test_solve_toeplitz.py +150 -0
  676. scipy/linalg/tests/test_solvers.py +844 -0
  677. scipy/linalg/tests/test_special_matrices.py +636 -0
  678. scipy/misc/__init__.py +6 -0
  679. scipy/misc/common.py +6 -0
  680. scipy/misc/doccer.py +6 -0
  681. scipy/ndimage/__init__.py +174 -0
  682. scipy/ndimage/_ctest.cpython-314-x86_64-linux-musl.so +0 -0
  683. scipy/ndimage/_cytest.cpython-314-x86_64-linux-musl.so +0 -0
  684. scipy/ndimage/_delegators.py +303 -0
  685. scipy/ndimage/_filters.py +2422 -0
  686. scipy/ndimage/_fourier.py +306 -0
  687. scipy/ndimage/_interpolation.py +1033 -0
  688. scipy/ndimage/_measurements.py +1689 -0
  689. scipy/ndimage/_morphology.py +2634 -0
  690. scipy/ndimage/_nd_image.cpython-314-x86_64-linux-musl.so +0 -0
  691. scipy/ndimage/_ndimage_api.py +16 -0
  692. scipy/ndimage/_ni_docstrings.py +214 -0
  693. scipy/ndimage/_ni_label.cpython-314-x86_64-linux-musl.so +0 -0
  694. scipy/ndimage/_ni_support.py +139 -0
  695. scipy/ndimage/_rank_filter_1d.cpython-314-x86_64-linux-musl.so +0 -0
  696. scipy/ndimage/_support_alternative_backends.py +84 -0
  697. scipy/ndimage/filters.py +27 -0
  698. scipy/ndimage/fourier.py +21 -0
  699. scipy/ndimage/interpolation.py +22 -0
  700. scipy/ndimage/measurements.py +24 -0
  701. scipy/ndimage/morphology.py +27 -0
  702. scipy/ndimage/tests/__init__.py +12 -0
  703. scipy/ndimage/tests/data/label_inputs.txt +21 -0
  704. scipy/ndimage/tests/data/label_results.txt +294 -0
  705. scipy/ndimage/tests/data/label_strels.txt +42 -0
  706. scipy/ndimage/tests/dots.png +0 -0
  707. scipy/ndimage/tests/test_c_api.py +102 -0
  708. scipy/ndimage/tests/test_datatypes.py +67 -0
  709. scipy/ndimage/tests/test_filters.py +3083 -0
  710. scipy/ndimage/tests/test_fourier.py +187 -0
  711. scipy/ndimage/tests/test_interpolation.py +1491 -0
  712. scipy/ndimage/tests/test_measurements.py +1592 -0
  713. scipy/ndimage/tests/test_morphology.py +2950 -0
  714. scipy/ndimage/tests/test_ni_support.py +78 -0
  715. scipy/ndimage/tests/test_splines.py +70 -0
  716. scipy/odr/__init__.py +131 -0
  717. scipy/odr/__odrpack.cpython-314-x86_64-linux-musl.so +0 -0
  718. scipy/odr/_add_newdocs.py +34 -0
  719. scipy/odr/_models.py +315 -0
  720. scipy/odr/_odrpack.py +1154 -0
  721. scipy/odr/models.py +20 -0
  722. scipy/odr/odrpack.py +21 -0
  723. scipy/odr/tests/__init__.py +0 -0
  724. scipy/odr/tests/test_odr.py +607 -0
  725. scipy/optimize/__init__.pxd +1 -0
  726. scipy/optimize/__init__.py +460 -0
  727. scipy/optimize/_basinhopping.py +741 -0
  728. scipy/optimize/_bglu_dense.cpython-314-x86_64-linux-musl.so +0 -0
  729. scipy/optimize/_bracket.py +706 -0
  730. scipy/optimize/_chandrupatla.py +551 -0
  731. scipy/optimize/_cobyla_py.py +297 -0
  732. scipy/optimize/_cobyqa_py.py +72 -0
  733. scipy/optimize/_constraints.py +598 -0
  734. scipy/optimize/_dcsrch.py +728 -0
  735. scipy/optimize/_differentiable_functions.py +835 -0
  736. scipy/optimize/_differentialevolution.py +1970 -0
  737. scipy/optimize/_direct.cpython-314-x86_64-linux-musl.so +0 -0
  738. scipy/optimize/_direct_py.py +280 -0
  739. scipy/optimize/_dual_annealing.py +732 -0
  740. scipy/optimize/_elementwise.py +798 -0
  741. scipy/optimize/_group_columns.cpython-314-x86_64-linux-musl.so +0 -0
  742. scipy/optimize/_hessian_update_strategy.py +479 -0
  743. scipy/optimize/_highspy/__init__.py +0 -0
  744. scipy/optimize/_highspy/_core.cpython-314-x86_64-linux-musl.so +0 -0
  745. scipy/optimize/_highspy/_highs_options.cpython-314-x86_64-linux-musl.so +0 -0
  746. scipy/optimize/_highspy/_highs_wrapper.py +338 -0
  747. scipy/optimize/_isotonic.py +157 -0
  748. scipy/optimize/_lbfgsb.cpython-314-x86_64-linux-musl.so +0 -0
  749. scipy/optimize/_lbfgsb_py.py +634 -0
  750. scipy/optimize/_linesearch.py +896 -0
  751. scipy/optimize/_linprog.py +733 -0
  752. scipy/optimize/_linprog_doc.py +1434 -0
  753. scipy/optimize/_linprog_highs.py +422 -0
  754. scipy/optimize/_linprog_ip.py +1141 -0
  755. scipy/optimize/_linprog_rs.py +572 -0
  756. scipy/optimize/_linprog_simplex.py +663 -0
  757. scipy/optimize/_linprog_util.py +1521 -0
  758. scipy/optimize/_lsap.cpython-314-x86_64-linux-musl.so +0 -0
  759. scipy/optimize/_lsq/__init__.py +5 -0
  760. scipy/optimize/_lsq/bvls.py +183 -0
  761. scipy/optimize/_lsq/common.py +731 -0
  762. scipy/optimize/_lsq/dogbox.py +345 -0
  763. scipy/optimize/_lsq/givens_elimination.cpython-314-x86_64-linux-musl.so +0 -0
  764. scipy/optimize/_lsq/least_squares.py +1044 -0
  765. scipy/optimize/_lsq/lsq_linear.py +361 -0
  766. scipy/optimize/_lsq/trf.py +587 -0
  767. scipy/optimize/_lsq/trf_linear.py +249 -0
  768. scipy/optimize/_milp.py +394 -0
  769. scipy/optimize/_minimize.py +1199 -0
  770. scipy/optimize/_minpack.cpython-314-x86_64-linux-musl.so +0 -0
  771. scipy/optimize/_minpack_py.py +1178 -0
  772. scipy/optimize/_moduleTNC.cpython-314-x86_64-linux-musl.so +0 -0
  773. scipy/optimize/_nnls.py +96 -0
  774. scipy/optimize/_nonlin.py +1634 -0
  775. scipy/optimize/_numdiff.py +963 -0
  776. scipy/optimize/_optimize.py +4169 -0
  777. scipy/optimize/_pava_pybind.cpython-314-x86_64-linux-musl.so +0 -0
  778. scipy/optimize/_qap.py +760 -0
  779. scipy/optimize/_remove_redundancy.py +522 -0
  780. scipy/optimize/_root.py +732 -0
  781. scipy/optimize/_root_scalar.py +538 -0
  782. scipy/optimize/_shgo.py +1606 -0
  783. scipy/optimize/_shgo_lib/__init__.py +0 -0
  784. scipy/optimize/_shgo_lib/_complex.py +1225 -0
  785. scipy/optimize/_shgo_lib/_vertex.py +460 -0
  786. scipy/optimize/_slsqp_py.py +603 -0
  787. scipy/optimize/_slsqplib.cpython-314-x86_64-linux-musl.so +0 -0
  788. scipy/optimize/_spectral.py +260 -0
  789. scipy/optimize/_tnc.py +438 -0
  790. scipy/optimize/_trlib/__init__.py +12 -0
  791. scipy/optimize/_trlib/_trlib.cpython-314-x86_64-linux-musl.so +0 -0
  792. scipy/optimize/_trustregion.py +318 -0
  793. scipy/optimize/_trustregion_constr/__init__.py +6 -0
  794. scipy/optimize/_trustregion_constr/canonical_constraint.py +390 -0
  795. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +231 -0
  796. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +584 -0
  797. scipy/optimize/_trustregion_constr/projections.py +411 -0
  798. scipy/optimize/_trustregion_constr/qp_subproblem.py +637 -0
  799. scipy/optimize/_trustregion_constr/report.py +49 -0
  800. scipy/optimize/_trustregion_constr/tests/__init__.py +0 -0
  801. scipy/optimize/_trustregion_constr/tests/test_canonical_constraint.py +296 -0
  802. scipy/optimize/_trustregion_constr/tests/test_nested_minimize.py +39 -0
  803. scipy/optimize/_trustregion_constr/tests/test_projections.py +214 -0
  804. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +645 -0
  805. scipy/optimize/_trustregion_constr/tests/test_report.py +34 -0
  806. scipy/optimize/_trustregion_constr/tr_interior_point.py +361 -0
  807. scipy/optimize/_trustregion_dogleg.py +122 -0
  808. scipy/optimize/_trustregion_exact.py +437 -0
  809. scipy/optimize/_trustregion_krylov.py +65 -0
  810. scipy/optimize/_trustregion_ncg.py +126 -0
  811. scipy/optimize/_tstutils.py +972 -0
  812. scipy/optimize/_zeros.cpython-314-x86_64-linux-musl.so +0 -0
  813. scipy/optimize/_zeros_py.py +1475 -0
  814. scipy/optimize/cobyla.py +19 -0
  815. scipy/optimize/cython_optimize/__init__.py +133 -0
  816. scipy/optimize/cython_optimize/_zeros.cpython-314-x86_64-linux-musl.so +0 -0
  817. scipy/optimize/cython_optimize/_zeros.pxd +33 -0
  818. scipy/optimize/cython_optimize/c_zeros.pxd +26 -0
  819. scipy/optimize/cython_optimize.pxd +11 -0
  820. scipy/optimize/elementwise.py +38 -0
  821. scipy/optimize/lbfgsb.py +23 -0
  822. scipy/optimize/linesearch.py +18 -0
  823. scipy/optimize/minpack.py +27 -0
  824. scipy/optimize/minpack2.py +17 -0
  825. scipy/optimize/moduleTNC.py +19 -0
  826. scipy/optimize/nonlin.py +29 -0
  827. scipy/optimize/optimize.py +40 -0
  828. scipy/optimize/slsqp.py +22 -0
  829. scipy/optimize/tests/__init__.py +0 -0
  830. scipy/optimize/tests/_cython_examples/extending.pyx +43 -0
  831. scipy/optimize/tests/_cython_examples/meson.build +32 -0
  832. scipy/optimize/tests/test__basinhopping.py +535 -0
  833. scipy/optimize/tests/test__differential_evolution.py +1703 -0
  834. scipy/optimize/tests/test__dual_annealing.py +416 -0
  835. scipy/optimize/tests/test__linprog_clean_inputs.py +312 -0
  836. scipy/optimize/tests/test__numdiff.py +885 -0
  837. scipy/optimize/tests/test__remove_redundancy.py +228 -0
  838. scipy/optimize/tests/test__root.py +124 -0
  839. scipy/optimize/tests/test__shgo.py +1164 -0
  840. scipy/optimize/tests/test__spectral.py +226 -0
  841. scipy/optimize/tests/test_bracket.py +896 -0
  842. scipy/optimize/tests/test_chandrupatla.py +982 -0
  843. scipy/optimize/tests/test_cobyla.py +195 -0
  844. scipy/optimize/tests/test_cobyqa.py +252 -0
  845. scipy/optimize/tests/test_constraint_conversion.py +286 -0
  846. scipy/optimize/tests/test_constraints.py +255 -0
  847. scipy/optimize/tests/test_cython_optimize.py +92 -0
  848. scipy/optimize/tests/test_differentiable_functions.py +1025 -0
  849. scipy/optimize/tests/test_direct.py +321 -0
  850. scipy/optimize/tests/test_extending.py +28 -0
  851. scipy/optimize/tests/test_hessian_update_strategy.py +300 -0
  852. scipy/optimize/tests/test_isotonic_regression.py +167 -0
  853. scipy/optimize/tests/test_lbfgsb_hessinv.py +65 -0
  854. scipy/optimize/tests/test_lbfgsb_setulb.py +122 -0
  855. scipy/optimize/tests/test_least_squares.py +986 -0
  856. scipy/optimize/tests/test_linear_assignment.py +116 -0
  857. scipy/optimize/tests/test_linesearch.py +328 -0
  858. scipy/optimize/tests/test_linprog.py +2577 -0
  859. scipy/optimize/tests/test_lsq_common.py +297 -0
  860. scipy/optimize/tests/test_lsq_linear.py +287 -0
  861. scipy/optimize/tests/test_milp.py +459 -0
  862. scipy/optimize/tests/test_minimize_constrained.py +845 -0
  863. scipy/optimize/tests/test_minpack.py +1194 -0
  864. scipy/optimize/tests/test_nnls.py +469 -0
  865. scipy/optimize/tests/test_nonlin.py +572 -0
  866. scipy/optimize/tests/test_optimize.py +3335 -0
  867. scipy/optimize/tests/test_quadratic_assignment.py +455 -0
  868. scipy/optimize/tests/test_regression.py +40 -0
  869. scipy/optimize/tests/test_slsqp.py +645 -0
  870. scipy/optimize/tests/test_tnc.py +345 -0
  871. scipy/optimize/tests/test_trustregion.py +110 -0
  872. scipy/optimize/tests/test_trustregion_exact.py +351 -0
  873. scipy/optimize/tests/test_trustregion_krylov.py +170 -0
  874. scipy/optimize/tests/test_zeros.py +998 -0
  875. scipy/optimize/tnc.py +22 -0
  876. scipy/optimize/zeros.py +26 -0
  877. scipy/signal/__init__.py +316 -0
  878. scipy/signal/_arraytools.py +264 -0
  879. scipy/signal/_czt.py +575 -0
  880. scipy/signal/_delegators.py +568 -0
  881. scipy/signal/_filter_design.py +5893 -0
  882. scipy/signal/_fir_filter_design.py +1458 -0
  883. scipy/signal/_lti_conversion.py +534 -0
  884. scipy/signal/_ltisys.py +3546 -0
  885. scipy/signal/_max_len_seq.py +139 -0
  886. scipy/signal/_max_len_seq_inner.cpython-314-x86_64-linux-musl.so +0 -0
  887. scipy/signal/_peak_finding.py +1310 -0
  888. scipy/signal/_peak_finding_utils.cpython-314-x86_64-linux-musl.so +0 -0
  889. scipy/signal/_polyutils.py +172 -0
  890. scipy/signal/_savitzky_golay.py +357 -0
  891. scipy/signal/_short_time_fft.py +2187 -0
  892. scipy/signal/_signal_api.py +30 -0
  893. scipy/signal/_signaltools.py +5309 -0
  894. scipy/signal/_sigtools.cpython-314-x86_64-linux-musl.so +0 -0
  895. scipy/signal/_sosfilt.cpython-314-x86_64-linux-musl.so +0 -0
  896. scipy/signal/_spectral_py.py +2471 -0
  897. scipy/signal/_spline.cpython-314-x86_64-linux-musl.so +0 -0
  898. scipy/signal/_spline.pyi +34 -0
  899. scipy/signal/_spline_filters.py +848 -0
  900. scipy/signal/_support_alternative_backends.py +73 -0
  901. scipy/signal/_upfirdn.py +219 -0
  902. scipy/signal/_upfirdn_apply.cpython-314-x86_64-linux-musl.so +0 -0
  903. scipy/signal/_waveforms.py +687 -0
  904. scipy/signal/_wavelets.py +29 -0
  905. scipy/signal/bsplines.py +21 -0
  906. scipy/signal/filter_design.py +28 -0
  907. scipy/signal/fir_filter_design.py +21 -0
  908. scipy/signal/lti_conversion.py +20 -0
  909. scipy/signal/ltisys.py +25 -0
  910. scipy/signal/signaltools.py +27 -0
  911. scipy/signal/spectral.py +21 -0
  912. scipy/signal/spline.py +18 -0
  913. scipy/signal/tests/__init__.py +0 -0
  914. scipy/signal/tests/_scipy_spectral_test_shim.py +311 -0
  915. scipy/signal/tests/mpsig.py +122 -0
  916. scipy/signal/tests/test_array_tools.py +111 -0
  917. scipy/signal/tests/test_bsplines.py +365 -0
  918. scipy/signal/tests/test_cont2discrete.py +424 -0
  919. scipy/signal/tests/test_czt.py +221 -0
  920. scipy/signal/tests/test_dltisys.py +599 -0
  921. scipy/signal/tests/test_filter_design.py +4744 -0
  922. scipy/signal/tests/test_fir_filter_design.py +851 -0
  923. scipy/signal/tests/test_ltisys.py +1225 -0
  924. scipy/signal/tests/test_max_len_seq.py +71 -0
  925. scipy/signal/tests/test_peak_finding.py +915 -0
  926. scipy/signal/tests/test_result_type.py +51 -0
  927. scipy/signal/tests/test_savitzky_golay.py +363 -0
  928. scipy/signal/tests/test_short_time_fft.py +1098 -0
  929. scipy/signal/tests/test_signaltools.py +4729 -0
  930. scipy/signal/tests/test_spectral.py +2103 -0
  931. scipy/signal/tests/test_splines.py +427 -0
  932. scipy/signal/tests/test_upfirdn.py +322 -0
  933. scipy/signal/tests/test_waveforms.py +400 -0
  934. scipy/signal/tests/test_wavelets.py +59 -0
  935. scipy/signal/tests/test_windows.py +987 -0
  936. scipy/signal/waveforms.py +20 -0
  937. scipy/signal/wavelets.py +17 -0
  938. scipy/signal/windows/__init__.py +52 -0
  939. scipy/signal/windows/_windows.py +2513 -0
  940. scipy/signal/windows/windows.py +23 -0
  941. scipy/sparse/__init__.py +350 -0
  942. scipy/sparse/_base.py +1613 -0
  943. scipy/sparse/_bsr.py +880 -0
  944. scipy/sparse/_compressed.py +1328 -0
  945. scipy/sparse/_construct.py +1454 -0
  946. scipy/sparse/_coo.py +1581 -0
  947. scipy/sparse/_csc.py +367 -0
  948. scipy/sparse/_csparsetools.cpython-314-x86_64-linux-musl.so +0 -0
  949. scipy/sparse/_csr.py +558 -0
  950. scipy/sparse/_data.py +569 -0
  951. scipy/sparse/_dia.py +677 -0
  952. scipy/sparse/_dok.py +669 -0
  953. scipy/sparse/_extract.py +178 -0
  954. scipy/sparse/_index.py +444 -0
  955. scipy/sparse/_lil.py +632 -0
  956. scipy/sparse/_matrix.py +169 -0
  957. scipy/sparse/_matrix_io.py +167 -0
  958. scipy/sparse/_sparsetools.cpython-314-x86_64-linux-musl.so +0 -0
  959. scipy/sparse/_spfuncs.py +76 -0
  960. scipy/sparse/_sputils.py +632 -0
  961. scipy/sparse/base.py +24 -0
  962. scipy/sparse/bsr.py +22 -0
  963. scipy/sparse/compressed.py +20 -0
  964. scipy/sparse/construct.py +38 -0
  965. scipy/sparse/coo.py +23 -0
  966. scipy/sparse/csc.py +22 -0
  967. scipy/sparse/csgraph/__init__.py +210 -0
  968. scipy/sparse/csgraph/_flow.cpython-314-x86_64-linux-musl.so +0 -0
  969. scipy/sparse/csgraph/_laplacian.py +563 -0
  970. scipy/sparse/csgraph/_matching.cpython-314-x86_64-linux-musl.so +0 -0
  971. scipy/sparse/csgraph/_min_spanning_tree.cpython-314-x86_64-linux-musl.so +0 -0
  972. scipy/sparse/csgraph/_reordering.cpython-314-x86_64-linux-musl.so +0 -0
  973. scipy/sparse/csgraph/_shortest_path.cpython-314-x86_64-linux-musl.so +0 -0
  974. scipy/sparse/csgraph/_tools.cpython-314-x86_64-linux-musl.so +0 -0
  975. scipy/sparse/csgraph/_traversal.cpython-314-x86_64-linux-musl.so +0 -0
  976. scipy/sparse/csgraph/_validation.py +66 -0
  977. scipy/sparse/csgraph/tests/__init__.py +0 -0
  978. scipy/sparse/csgraph/tests/test_connected_components.py +119 -0
  979. scipy/sparse/csgraph/tests/test_conversions.py +61 -0
  980. scipy/sparse/csgraph/tests/test_flow.py +209 -0
  981. scipy/sparse/csgraph/tests/test_graph_laplacian.py +368 -0
  982. scipy/sparse/csgraph/tests/test_matching.py +307 -0
  983. scipy/sparse/csgraph/tests/test_pydata_sparse.py +197 -0
  984. scipy/sparse/csgraph/tests/test_reordering.py +70 -0
  985. scipy/sparse/csgraph/tests/test_shortest_path.py +540 -0
  986. scipy/sparse/csgraph/tests/test_spanning_tree.py +66 -0
  987. scipy/sparse/csgraph/tests/test_traversal.py +148 -0
  988. scipy/sparse/csr.py +22 -0
  989. scipy/sparse/data.py +18 -0
  990. scipy/sparse/dia.py +22 -0
  991. scipy/sparse/dok.py +22 -0
  992. scipy/sparse/extract.py +23 -0
  993. scipy/sparse/lil.py +22 -0
  994. scipy/sparse/linalg/__init__.py +148 -0
  995. scipy/sparse/linalg/_dsolve/__init__.py +71 -0
  996. scipy/sparse/linalg/_dsolve/_add_newdocs.py +147 -0
  997. scipy/sparse/linalg/_dsolve/_superlu.cpython-314-x86_64-linux-musl.so +0 -0
  998. scipy/sparse/linalg/_dsolve/linsolve.py +882 -0
  999. scipy/sparse/linalg/_dsolve/tests/__init__.py +0 -0
  1000. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +928 -0
  1001. scipy/sparse/linalg/_eigen/__init__.py +22 -0
  1002. scipy/sparse/linalg/_eigen/_svds.py +540 -0
  1003. scipy/sparse/linalg/_eigen/_svds_doc.py +382 -0
  1004. scipy/sparse/linalg/_eigen/arpack/COPYING +45 -0
  1005. scipy/sparse/linalg/_eigen/arpack/__init__.py +20 -0
  1006. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-314-x86_64-linux-musl.so +0 -0
  1007. scipy/sparse/linalg/_eigen/arpack/arpack.py +1706 -0
  1008. scipy/sparse/linalg/_eigen/arpack/tests/__init__.py +0 -0
  1009. scipy/sparse/linalg/_eigen/arpack/tests/test_arpack.py +717 -0
  1010. scipy/sparse/linalg/_eigen/lobpcg/__init__.py +16 -0
  1011. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +1110 -0
  1012. scipy/sparse/linalg/_eigen/lobpcg/tests/__init__.py +0 -0
  1013. scipy/sparse/linalg/_eigen/lobpcg/tests/test_lobpcg.py +725 -0
  1014. scipy/sparse/linalg/_eigen/tests/__init__.py +0 -0
  1015. scipy/sparse/linalg/_eigen/tests/test_svds.py +886 -0
  1016. scipy/sparse/linalg/_expm_multiply.py +816 -0
  1017. scipy/sparse/linalg/_interface.py +920 -0
  1018. scipy/sparse/linalg/_isolve/__init__.py +20 -0
  1019. scipy/sparse/linalg/_isolve/_gcrotmk.py +503 -0
  1020. scipy/sparse/linalg/_isolve/iterative.py +1051 -0
  1021. scipy/sparse/linalg/_isolve/lgmres.py +230 -0
  1022. scipy/sparse/linalg/_isolve/lsmr.py +486 -0
  1023. scipy/sparse/linalg/_isolve/lsqr.py +589 -0
  1024. scipy/sparse/linalg/_isolve/minres.py +372 -0
  1025. scipy/sparse/linalg/_isolve/tests/__init__.py +0 -0
  1026. scipy/sparse/linalg/_isolve/tests/test_gcrotmk.py +183 -0
  1027. scipy/sparse/linalg/_isolve/tests/test_iterative.py +809 -0
  1028. scipy/sparse/linalg/_isolve/tests/test_lgmres.py +225 -0
  1029. scipy/sparse/linalg/_isolve/tests/test_lsmr.py +185 -0
  1030. scipy/sparse/linalg/_isolve/tests/test_lsqr.py +120 -0
  1031. scipy/sparse/linalg/_isolve/tests/test_minres.py +97 -0
  1032. scipy/sparse/linalg/_isolve/tests/test_utils.py +9 -0
  1033. scipy/sparse/linalg/_isolve/tfqmr.py +179 -0
  1034. scipy/sparse/linalg/_isolve/utils.py +121 -0
  1035. scipy/sparse/linalg/_matfuncs.py +940 -0
  1036. scipy/sparse/linalg/_norm.py +195 -0
  1037. scipy/sparse/linalg/_onenormest.py +467 -0
  1038. scipy/sparse/linalg/_propack/_cpropack.cpython-314-x86_64-linux-musl.so +0 -0
  1039. scipy/sparse/linalg/_propack/_dpropack.cpython-314-x86_64-linux-musl.so +0 -0
  1040. scipy/sparse/linalg/_propack/_spropack.cpython-314-x86_64-linux-musl.so +0 -0
  1041. scipy/sparse/linalg/_propack/_zpropack.cpython-314-x86_64-linux-musl.so +0 -0
  1042. scipy/sparse/linalg/_special_sparse_arrays.py +949 -0
  1043. scipy/sparse/linalg/_svdp.py +309 -0
  1044. scipy/sparse/linalg/dsolve.py +22 -0
  1045. scipy/sparse/linalg/eigen.py +21 -0
  1046. scipy/sparse/linalg/interface.py +20 -0
  1047. scipy/sparse/linalg/isolve.py +22 -0
  1048. scipy/sparse/linalg/matfuncs.py +18 -0
  1049. scipy/sparse/linalg/tests/__init__.py +0 -0
  1050. scipy/sparse/linalg/tests/propack_test_data.npz +0 -0
  1051. scipy/sparse/linalg/tests/test_expm_multiply.py +367 -0
  1052. scipy/sparse/linalg/tests/test_interface.py +561 -0
  1053. scipy/sparse/linalg/tests/test_matfuncs.py +592 -0
  1054. scipy/sparse/linalg/tests/test_norm.py +154 -0
  1055. scipy/sparse/linalg/tests/test_onenormest.py +252 -0
  1056. scipy/sparse/linalg/tests/test_propack.py +165 -0
  1057. scipy/sparse/linalg/tests/test_pydata_sparse.py +272 -0
  1058. scipy/sparse/linalg/tests/test_special_sparse_arrays.py +337 -0
  1059. scipy/sparse/sparsetools.py +17 -0
  1060. scipy/sparse/spfuncs.py +17 -0
  1061. scipy/sparse/sputils.py +17 -0
  1062. scipy/sparse/tests/__init__.py +0 -0
  1063. scipy/sparse/tests/data/csc_py2.npz +0 -0
  1064. scipy/sparse/tests/data/csc_py3.npz +0 -0
  1065. scipy/sparse/tests/test_arithmetic1d.py +341 -0
  1066. scipy/sparse/tests/test_array_api.py +561 -0
  1067. scipy/sparse/tests/test_base.py +5870 -0
  1068. scipy/sparse/tests/test_common1d.py +447 -0
  1069. scipy/sparse/tests/test_construct.py +872 -0
  1070. scipy/sparse/tests/test_coo.py +1119 -0
  1071. scipy/sparse/tests/test_csc.py +98 -0
  1072. scipy/sparse/tests/test_csr.py +214 -0
  1073. scipy/sparse/tests/test_dok.py +209 -0
  1074. scipy/sparse/tests/test_extract.py +51 -0
  1075. scipy/sparse/tests/test_indexing1d.py +603 -0
  1076. scipy/sparse/tests/test_matrix_io.py +109 -0
  1077. scipy/sparse/tests/test_minmax1d.py +128 -0
  1078. scipy/sparse/tests/test_sparsetools.py +344 -0
  1079. scipy/sparse/tests/test_spfuncs.py +97 -0
  1080. scipy/sparse/tests/test_sputils.py +424 -0
  1081. scipy/spatial/__init__.py +129 -0
  1082. scipy/spatial/_ckdtree.cpython-314-x86_64-linux-musl.so +0 -0
  1083. scipy/spatial/_distance_pybind.cpython-314-x86_64-linux-musl.so +0 -0
  1084. scipy/spatial/_distance_wrap.cpython-314-x86_64-linux-musl.so +0 -0
  1085. scipy/spatial/_geometric_slerp.py +238 -0
  1086. scipy/spatial/_hausdorff.cpython-314-x86_64-linux-musl.so +0 -0
  1087. scipy/spatial/_kdtree.py +920 -0
  1088. scipy/spatial/_plotutils.py +274 -0
  1089. scipy/spatial/_procrustes.py +132 -0
  1090. scipy/spatial/_qhull.cpython-314-x86_64-linux-musl.so +0 -0
  1091. scipy/spatial/_qhull.pyi +213 -0
  1092. scipy/spatial/_spherical_voronoi.py +341 -0
  1093. scipy/spatial/_voronoi.cpython-314-x86_64-linux-musl.so +0 -0
  1094. scipy/spatial/_voronoi.pyi +4 -0
  1095. scipy/spatial/ckdtree.py +18 -0
  1096. scipy/spatial/distance.py +3147 -0
  1097. scipy/spatial/distance.pyi +210 -0
  1098. scipy/spatial/kdtree.py +25 -0
  1099. scipy/spatial/qhull.py +25 -0
  1100. scipy/spatial/tests/__init__.py +0 -0
  1101. scipy/spatial/tests/data/cdist-X1.txt +10 -0
  1102. scipy/spatial/tests/data/cdist-X2.txt +20 -0
  1103. scipy/spatial/tests/data/degenerate_pointset.npz +0 -0
  1104. scipy/spatial/tests/data/iris.txt +150 -0
  1105. scipy/spatial/tests/data/pdist-boolean-inp.txt +20 -0
  1106. scipy/spatial/tests/data/pdist-chebyshev-ml-iris.txt +1 -0
  1107. scipy/spatial/tests/data/pdist-chebyshev-ml.txt +1 -0
  1108. scipy/spatial/tests/data/pdist-cityblock-ml-iris.txt +1 -0
  1109. scipy/spatial/tests/data/pdist-cityblock-ml.txt +1 -0
  1110. scipy/spatial/tests/data/pdist-correlation-ml-iris.txt +1 -0
  1111. scipy/spatial/tests/data/pdist-correlation-ml.txt +1 -0
  1112. scipy/spatial/tests/data/pdist-cosine-ml-iris.txt +1 -0
  1113. scipy/spatial/tests/data/pdist-cosine-ml.txt +1 -0
  1114. scipy/spatial/tests/data/pdist-double-inp.txt +20 -0
  1115. scipy/spatial/tests/data/pdist-euclidean-ml-iris.txt +1 -0
  1116. scipy/spatial/tests/data/pdist-euclidean-ml.txt +1 -0
  1117. scipy/spatial/tests/data/pdist-hamming-ml.txt +1 -0
  1118. scipy/spatial/tests/data/pdist-jaccard-ml.txt +1 -0
  1119. scipy/spatial/tests/data/pdist-jensenshannon-ml-iris.txt +1 -0
  1120. scipy/spatial/tests/data/pdist-jensenshannon-ml.txt +1 -0
  1121. scipy/spatial/tests/data/pdist-minkowski-3.2-ml-iris.txt +1 -0
  1122. scipy/spatial/tests/data/pdist-minkowski-3.2-ml.txt +1 -0
  1123. scipy/spatial/tests/data/pdist-minkowski-5.8-ml-iris.txt +1 -0
  1124. scipy/spatial/tests/data/pdist-seuclidean-ml-iris.txt +1 -0
  1125. scipy/spatial/tests/data/pdist-seuclidean-ml.txt +1 -0
  1126. scipy/spatial/tests/data/pdist-spearman-ml.txt +1 -0
  1127. scipy/spatial/tests/data/random-bool-data.txt +100 -0
  1128. scipy/spatial/tests/data/random-double-data.txt +100 -0
  1129. scipy/spatial/tests/data/random-int-data.txt +100 -0
  1130. scipy/spatial/tests/data/random-uint-data.txt +100 -0
  1131. scipy/spatial/tests/data/selfdual-4d-polytope.txt +27 -0
  1132. scipy/spatial/tests/test__plotutils.py +91 -0
  1133. scipy/spatial/tests/test__procrustes.py +116 -0
  1134. scipy/spatial/tests/test_distance.py +2388 -0
  1135. scipy/spatial/tests/test_hausdorff.py +199 -0
  1136. scipy/spatial/tests/test_kdtree.py +1536 -0
  1137. scipy/spatial/tests/test_qhull.py +1313 -0
  1138. scipy/spatial/tests/test_slerp.py +417 -0
  1139. scipy/spatial/tests/test_spherical_voronoi.py +358 -0
  1140. scipy/spatial/transform/__init__.py +31 -0
  1141. scipy/spatial/transform/_rigid_transform.cpython-314-x86_64-linux-musl.so +0 -0
  1142. scipy/spatial/transform/_rotation.cpython-314-x86_64-linux-musl.so +0 -0
  1143. scipy/spatial/transform/_rotation_groups.py +140 -0
  1144. scipy/spatial/transform/_rotation_spline.py +460 -0
  1145. scipy/spatial/transform/rotation.py +21 -0
  1146. scipy/spatial/transform/tests/__init__.py +0 -0
  1147. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  1148. scipy/spatial/transform/tests/test_rotation.py +2569 -0
  1149. scipy/spatial/transform/tests/test_rotation_groups.py +169 -0
  1150. scipy/spatial/transform/tests/test_rotation_spline.py +183 -0
  1151. scipy/special/__init__.pxd +1 -0
  1152. scipy/special/__init__.py +841 -0
  1153. scipy/special/_add_newdocs.py +9961 -0
  1154. scipy/special/_basic.py +3576 -0
  1155. scipy/special/_comb.cpython-314-x86_64-linux-musl.so +0 -0
  1156. scipy/special/_ellip_harm.py +214 -0
  1157. scipy/special/_ellip_harm_2.cpython-314-x86_64-linux-musl.so +0 -0
  1158. scipy/special/_gufuncs.cpython-314-x86_64-linux-musl.so +0 -0
  1159. scipy/special/_input_validation.py +17 -0
  1160. scipy/special/_lambertw.py +149 -0
  1161. scipy/special/_logsumexp.py +426 -0
  1162. scipy/special/_mptestutils.py +453 -0
  1163. scipy/special/_multiufuncs.py +610 -0
  1164. scipy/special/_orthogonal.py +2592 -0
  1165. scipy/special/_orthogonal.pyi +330 -0
  1166. scipy/special/_precompute/__init__.py +0 -0
  1167. scipy/special/_precompute/cosine_cdf.py +17 -0
  1168. scipy/special/_precompute/expn_asy.py +54 -0
  1169. scipy/special/_precompute/gammainc_asy.py +116 -0
  1170. scipy/special/_precompute/gammainc_data.py +124 -0
  1171. scipy/special/_precompute/hyp2f1_data.py +484 -0
  1172. scipy/special/_precompute/lambertw.py +68 -0
  1173. scipy/special/_precompute/loggamma.py +43 -0
  1174. scipy/special/_precompute/struve_convergence.py +131 -0
  1175. scipy/special/_precompute/utils.py +38 -0
  1176. scipy/special/_precompute/wright_bessel.py +342 -0
  1177. scipy/special/_precompute/wright_bessel_data.py +152 -0
  1178. scipy/special/_precompute/wrightomega.py +41 -0
  1179. scipy/special/_precompute/zetac.py +27 -0
  1180. scipy/special/_sf_error.py +15 -0
  1181. scipy/special/_specfun.cpython-314-x86_64-linux-musl.so +0 -0
  1182. scipy/special/_special_ufuncs.cpython-314-x86_64-linux-musl.so +0 -0
  1183. scipy/special/_spfun_stats.py +106 -0
  1184. scipy/special/_spherical_bessel.py +397 -0
  1185. scipy/special/_support_alternative_backends.py +295 -0
  1186. scipy/special/_test_internal.cpython-314-x86_64-linux-musl.so +0 -0
  1187. scipy/special/_test_internal.pyi +9 -0
  1188. scipy/special/_testutils.py +321 -0
  1189. scipy/special/_ufuncs.cpython-314-x86_64-linux-musl.so +0 -0
  1190. scipy/special/_ufuncs.pyi +522 -0
  1191. scipy/special/_ufuncs.pyx +13173 -0
  1192. scipy/special/_ufuncs_cxx.cpython-314-x86_64-linux-musl.so +0 -0
  1193. scipy/special/_ufuncs_cxx.pxd +142 -0
  1194. scipy/special/_ufuncs_cxx.pyx +427 -0
  1195. scipy/special/_ufuncs_cxx_defs.h +147 -0
  1196. scipy/special/_ufuncs_defs.h +57 -0
  1197. scipy/special/add_newdocs.py +15 -0
  1198. scipy/special/basic.py +87 -0
  1199. scipy/special/cython_special.cpython-314-x86_64-linux-musl.so +0 -0
  1200. scipy/special/cython_special.pxd +259 -0
  1201. scipy/special/cython_special.pyi +3 -0
  1202. scipy/special/orthogonal.py +45 -0
  1203. scipy/special/sf_error.py +20 -0
  1204. scipy/special/specfun.py +24 -0
  1205. scipy/special/spfun_stats.py +17 -0
  1206. scipy/special/tests/__init__.py +0 -0
  1207. scipy/special/tests/_cython_examples/extending.pyx +12 -0
  1208. scipy/special/tests/_cython_examples/meson.build +34 -0
  1209. scipy/special/tests/data/__init__.py +0 -0
  1210. scipy/special/tests/data/boost.npz +0 -0
  1211. scipy/special/tests/data/gsl.npz +0 -0
  1212. scipy/special/tests/data/local.npz +0 -0
  1213. scipy/special/tests/test_basic.py +4815 -0
  1214. scipy/special/tests/test_bdtr.py +112 -0
  1215. scipy/special/tests/test_boost_ufuncs.py +64 -0
  1216. scipy/special/tests/test_boxcox.py +125 -0
  1217. scipy/special/tests/test_cdflib.py +712 -0
  1218. scipy/special/tests/test_cdft_asymptotic.py +49 -0
  1219. scipy/special/tests/test_cephes_intp_cast.py +29 -0
  1220. scipy/special/tests/test_cosine_distr.py +83 -0
  1221. scipy/special/tests/test_cython_special.py +363 -0
  1222. scipy/special/tests/test_data.py +719 -0
  1223. scipy/special/tests/test_dd.py +42 -0
  1224. scipy/special/tests/test_digamma.py +45 -0
  1225. scipy/special/tests/test_ellip_harm.py +278 -0
  1226. scipy/special/tests/test_erfinv.py +89 -0
  1227. scipy/special/tests/test_exponential_integrals.py +118 -0
  1228. scipy/special/tests/test_extending.py +28 -0
  1229. scipy/special/tests/test_faddeeva.py +85 -0
  1230. scipy/special/tests/test_gamma.py +12 -0
  1231. scipy/special/tests/test_gammainc.py +152 -0
  1232. scipy/special/tests/test_hyp2f1.py +2566 -0
  1233. scipy/special/tests/test_hypergeometric.py +234 -0
  1234. scipy/special/tests/test_iv_ratio.py +249 -0
  1235. scipy/special/tests/test_kolmogorov.py +491 -0
  1236. scipy/special/tests/test_lambertw.py +109 -0
  1237. scipy/special/tests/test_legendre.py +1518 -0
  1238. scipy/special/tests/test_log1mexp.py +85 -0
  1239. scipy/special/tests/test_loggamma.py +70 -0
  1240. scipy/special/tests/test_logit.py +162 -0
  1241. scipy/special/tests/test_logsumexp.py +469 -0
  1242. scipy/special/tests/test_mpmath.py +2293 -0
  1243. scipy/special/tests/test_nan_inputs.py +65 -0
  1244. scipy/special/tests/test_ndtr.py +77 -0
  1245. scipy/special/tests/test_ndtri_exp.py +94 -0
  1246. scipy/special/tests/test_orthogonal.py +821 -0
  1247. scipy/special/tests/test_orthogonal_eval.py +275 -0
  1248. scipy/special/tests/test_owens_t.py +53 -0
  1249. scipy/special/tests/test_pcf.py +24 -0
  1250. scipy/special/tests/test_pdtr.py +48 -0
  1251. scipy/special/tests/test_powm1.py +65 -0
  1252. scipy/special/tests/test_precompute_expn_asy.py +24 -0
  1253. scipy/special/tests/test_precompute_gammainc.py +108 -0
  1254. scipy/special/tests/test_precompute_utils.py +36 -0
  1255. scipy/special/tests/test_round.py +18 -0
  1256. scipy/special/tests/test_sf_error.py +146 -0
  1257. scipy/special/tests/test_sici.py +36 -0
  1258. scipy/special/tests/test_specfun.py +48 -0
  1259. scipy/special/tests/test_spence.py +32 -0
  1260. scipy/special/tests/test_spfun_stats.py +61 -0
  1261. scipy/special/tests/test_sph_harm.py +85 -0
  1262. scipy/special/tests/test_spherical_bessel.py +400 -0
  1263. scipy/special/tests/test_support_alternative_backends.py +248 -0
  1264. scipy/special/tests/test_trig.py +72 -0
  1265. scipy/special/tests/test_ufunc_signatures.py +46 -0
  1266. scipy/special/tests/test_wright_bessel.py +205 -0
  1267. scipy/special/tests/test_wrightomega.py +117 -0
  1268. scipy/special/tests/test_zeta.py +301 -0
  1269. scipy/stats/__init__.py +670 -0
  1270. scipy/stats/_ansari_swilk_statistics.cpython-314-x86_64-linux-musl.so +0 -0
  1271. scipy/stats/_axis_nan_policy.py +692 -0
  1272. scipy/stats/_biasedurn.cpython-314-x86_64-linux-musl.so +0 -0
  1273. scipy/stats/_biasedurn.pxd +27 -0
  1274. scipy/stats/_binned_statistic.py +795 -0
  1275. scipy/stats/_binomtest.py +375 -0
  1276. scipy/stats/_bws_test.py +177 -0
  1277. scipy/stats/_censored_data.py +459 -0
  1278. scipy/stats/_common.py +5 -0
  1279. scipy/stats/_constants.py +42 -0
  1280. scipy/stats/_continued_fraction.py +387 -0
  1281. scipy/stats/_continuous_distns.py +12486 -0
  1282. scipy/stats/_correlation.py +210 -0
  1283. scipy/stats/_covariance.py +636 -0
  1284. scipy/stats/_crosstab.py +204 -0
  1285. scipy/stats/_discrete_distns.py +2098 -0
  1286. scipy/stats/_distn_infrastructure.py +4201 -0
  1287. scipy/stats/_distr_params.py +299 -0
  1288. scipy/stats/_distribution_infrastructure.py +5750 -0
  1289. scipy/stats/_entropy.py +428 -0
  1290. scipy/stats/_finite_differences.py +145 -0
  1291. scipy/stats/_fit.py +1351 -0
  1292. scipy/stats/_hypotests.py +2060 -0
  1293. scipy/stats/_kde.py +732 -0
  1294. scipy/stats/_ksstats.py +600 -0
  1295. scipy/stats/_levy_stable/__init__.py +1231 -0
  1296. scipy/stats/_levy_stable/levyst.cpython-314-x86_64-linux-musl.so +0 -0
  1297. scipy/stats/_mannwhitneyu.py +492 -0
  1298. scipy/stats/_mgc.py +550 -0
  1299. scipy/stats/_morestats.py +4626 -0
  1300. scipy/stats/_mstats_basic.py +3658 -0
  1301. scipy/stats/_mstats_extras.py +521 -0
  1302. scipy/stats/_multicomp.py +449 -0
  1303. scipy/stats/_multivariate.py +7281 -0
  1304. scipy/stats/_new_distributions.py +452 -0
  1305. scipy/stats/_odds_ratio.py +466 -0
  1306. scipy/stats/_page_trend_test.py +486 -0
  1307. scipy/stats/_probability_distribution.py +1964 -0
  1308. scipy/stats/_qmc.py +2956 -0
  1309. scipy/stats/_qmc_cy.cpython-314-x86_64-linux-musl.so +0 -0
  1310. scipy/stats/_qmc_cy.pyi +54 -0
  1311. scipy/stats/_qmvnt.py +454 -0
  1312. scipy/stats/_qmvnt_cy.cpython-314-x86_64-linux-musl.so +0 -0
  1313. scipy/stats/_quantile.py +335 -0
  1314. scipy/stats/_rcont/__init__.py +4 -0
  1315. scipy/stats/_rcont/rcont.cpython-314-x86_64-linux-musl.so +0 -0
  1316. scipy/stats/_relative_risk.py +263 -0
  1317. scipy/stats/_resampling.py +2352 -0
  1318. scipy/stats/_result_classes.py +40 -0
  1319. scipy/stats/_sampling.py +1314 -0
  1320. scipy/stats/_sensitivity_analysis.py +713 -0
  1321. scipy/stats/_sobol.cpython-314-x86_64-linux-musl.so +0 -0
  1322. scipy/stats/_sobol.pyi +54 -0
  1323. scipy/stats/_sobol_direction_numbers.npz +0 -0
  1324. scipy/stats/_stats.cpython-314-x86_64-linux-musl.so +0 -0
  1325. scipy/stats/_stats.pxd +10 -0
  1326. scipy/stats/_stats_mstats_common.py +322 -0
  1327. scipy/stats/_stats_py.py +11089 -0
  1328. scipy/stats/_stats_pythran.cpython-314-x86_64-linux-musl.so +0 -0
  1329. scipy/stats/_survival.py +683 -0
  1330. scipy/stats/_tukeylambda_stats.py +199 -0
  1331. scipy/stats/_unuran/__init__.py +0 -0
  1332. scipy/stats/_unuran/unuran_wrapper.cpython-314-x86_64-linux-musl.so +0 -0
  1333. scipy/stats/_unuran/unuran_wrapper.pyi +179 -0
  1334. scipy/stats/_variation.py +126 -0
  1335. scipy/stats/_warnings_errors.py +38 -0
  1336. scipy/stats/_wilcoxon.py +265 -0
  1337. scipy/stats/biasedurn.py +16 -0
  1338. scipy/stats/contingency.py +521 -0
  1339. scipy/stats/distributions.py +24 -0
  1340. scipy/stats/kde.py +18 -0
  1341. scipy/stats/morestats.py +27 -0
  1342. scipy/stats/mstats.py +140 -0
  1343. scipy/stats/mstats_basic.py +42 -0
  1344. scipy/stats/mstats_extras.py +25 -0
  1345. scipy/stats/mvn.py +17 -0
  1346. scipy/stats/qmc.py +236 -0
  1347. scipy/stats/sampling.py +73 -0
  1348. scipy/stats/stats.py +41 -0
  1349. scipy/stats/tests/__init__.py +0 -0
  1350. scipy/stats/tests/common_tests.py +356 -0
  1351. scipy/stats/tests/data/_mvt.py +171 -0
  1352. scipy/stats/tests/data/fisher_exact_results_from_r.py +607 -0
  1353. scipy/stats/tests/data/jf_skew_t_gamlss_pdf_data.npy +0 -0
  1354. scipy/stats/tests/data/levy_stable/stable-Z1-cdf-sample-data.npy +0 -0
  1355. scipy/stats/tests/data/levy_stable/stable-Z1-pdf-sample-data.npy +0 -0
  1356. scipy/stats/tests/data/levy_stable/stable-loc-scale-sample-data.npy +0 -0
  1357. scipy/stats/tests/data/nist_anova/AtmWtAg.dat +108 -0
  1358. scipy/stats/tests/data/nist_anova/SiRstv.dat +85 -0
  1359. scipy/stats/tests/data/nist_anova/SmLs01.dat +249 -0
  1360. scipy/stats/tests/data/nist_anova/SmLs02.dat +1869 -0
  1361. scipy/stats/tests/data/nist_anova/SmLs03.dat +18069 -0
  1362. scipy/stats/tests/data/nist_anova/SmLs04.dat +249 -0
  1363. scipy/stats/tests/data/nist_anova/SmLs05.dat +1869 -0
  1364. scipy/stats/tests/data/nist_anova/SmLs06.dat +18069 -0
  1365. scipy/stats/tests/data/nist_anova/SmLs07.dat +249 -0
  1366. scipy/stats/tests/data/nist_anova/SmLs08.dat +1869 -0
  1367. scipy/stats/tests/data/nist_anova/SmLs09.dat +18069 -0
  1368. scipy/stats/tests/data/nist_linregress/Norris.dat +97 -0
  1369. scipy/stats/tests/data/rel_breitwigner_pdf_sample_data_ROOT.npy +0 -0
  1370. scipy/stats/tests/data/studentized_range_mpmath_ref.json +1499 -0
  1371. scipy/stats/tests/test_axis_nan_policy.py +1388 -0
  1372. scipy/stats/tests/test_binned_statistic.py +568 -0
  1373. scipy/stats/tests/test_censored_data.py +152 -0
  1374. scipy/stats/tests/test_contingency.py +294 -0
  1375. scipy/stats/tests/test_continued_fraction.py +173 -0
  1376. scipy/stats/tests/test_continuous.py +2198 -0
  1377. scipy/stats/tests/test_continuous_basic.py +1053 -0
  1378. scipy/stats/tests/test_continuous_fit_censored.py +683 -0
  1379. scipy/stats/tests/test_correlation.py +80 -0
  1380. scipy/stats/tests/test_crosstab.py +115 -0
  1381. scipy/stats/tests/test_discrete_basic.py +580 -0
  1382. scipy/stats/tests/test_discrete_distns.py +700 -0
  1383. scipy/stats/tests/test_distributions.py +10413 -0
  1384. scipy/stats/tests/test_entropy.py +322 -0
  1385. scipy/stats/tests/test_fast_gen_inversion.py +435 -0
  1386. scipy/stats/tests/test_fit.py +1090 -0
  1387. scipy/stats/tests/test_hypotests.py +1991 -0
  1388. scipy/stats/tests/test_kdeoth.py +676 -0
  1389. scipy/stats/tests/test_marray.py +289 -0
  1390. scipy/stats/tests/test_mgc.py +217 -0
  1391. scipy/stats/tests/test_morestats.py +3259 -0
  1392. scipy/stats/tests/test_mstats_basic.py +2071 -0
  1393. scipy/stats/tests/test_mstats_extras.py +172 -0
  1394. scipy/stats/tests/test_multicomp.py +405 -0
  1395. scipy/stats/tests/test_multivariate.py +4381 -0
  1396. scipy/stats/tests/test_odds_ratio.py +148 -0
  1397. scipy/stats/tests/test_qmc.py +1492 -0
  1398. scipy/stats/tests/test_quantile.py +199 -0
  1399. scipy/stats/tests/test_rank.py +345 -0
  1400. scipy/stats/tests/test_relative_risk.py +95 -0
  1401. scipy/stats/tests/test_resampling.py +2000 -0
  1402. scipy/stats/tests/test_sampling.py +1450 -0
  1403. scipy/stats/tests/test_sensitivity_analysis.py +310 -0
  1404. scipy/stats/tests/test_stats.py +9707 -0
  1405. scipy/stats/tests/test_survival.py +466 -0
  1406. scipy/stats/tests/test_tukeylambda_stats.py +85 -0
  1407. scipy/stats/tests/test_variation.py +216 -0
  1408. scipy/version.py +12 -0
  1409. scipy-1.16.1.dist-info/LICENSE.txt +934 -0
  1410. scipy-1.16.1.dist-info/METADATA +1083 -0
  1411. scipy-1.16.1.dist-info/RECORD +1420 -0
  1412. scipy-1.16.1.dist-info/WHEEL +5 -0
  1413. scipy.libs/libgcc_s-0cd532bd.so.1 +0 -0
  1414. scipy.libs/libgcc_s-a3a07607-e69b4851.so.1 +0 -0
  1415. scipy.libs/libgfortran-2c33b284.so.5.0.0 +0 -0
  1416. scipy.libs/libgfortran-e686bd2c-8cec572a.so.5.0.0 +0 -0
  1417. scipy.libs/libquadmath-9b5eedf9-101a4297.so.0.0.0 +0 -0
  1418. scipy.libs/libquadmath-bb76a5fc.so.0.0.0 +0 -0
  1419. scipy.libs/libscipy_openblas-e00df7a9.so +0 -0
  1420. scipy.libs/libstdc++-5d72f927.so.6.0.33 +0 -0
scipy/signal/_czt.py ADDED
@@ -0,0 +1,575 @@
1
+ # This program is public domain
2
+ # Authors: Paul Kienzle, Nadav Horesh
3
+ """
4
+ Chirp z-transform.
5
+
6
+ We provide two interfaces to the chirp z-transform: an object interface
7
+ which precalculates part of the transform and can be applied efficiently
8
+ to many different data sets, and a functional interface which is applied
9
+ only to the given data set.
10
+
11
+ Transforms
12
+ ----------
13
+
14
+ CZT : callable (x, axis=-1) -> array
15
+ Define a chirp z-transform that can be applied to different signals.
16
+ ZoomFFT : callable (x, axis=-1) -> array
17
+ Define a Fourier transform on a range of frequencies.
18
+
19
+ Functions
20
+ ---------
21
+
22
+ czt : array
23
+ Compute the chirp z-transform for a signal.
24
+ zoom_fft : array
25
+ Compute the Fourier transform on a range of frequencies.
26
+ """
27
+
28
+ import cmath
29
+ import numbers
30
+ import numpy as np
31
+ from numpy import pi, arange
32
+ from scipy.fft import fft, ifft, next_fast_len
33
+
34
+ __all__ = ['czt', 'zoom_fft', 'CZT', 'ZoomFFT', 'czt_points']
35
+
36
+
37
+ def _validate_sizes(n, m):
38
+ if n < 1 or not isinstance(n, numbers.Integral):
39
+ raise ValueError('Invalid number of CZT data '
40
+ f'points ({n}) specified. '
41
+ 'n must be positive and integer type.')
42
+
43
+ if m is None:
44
+ m = n
45
+ elif m < 1 or not isinstance(m, numbers.Integral):
46
+ raise ValueError('Invalid number of CZT output '
47
+ f'points ({m}) specified. '
48
+ 'm must be positive and integer type.')
49
+
50
+ return m
51
+
52
+
53
+ def czt_points(m, w=None, a=1+0j):
54
+ """
55
+ Return the points at which the chirp z-transform is computed.
56
+
57
+ Parameters
58
+ ----------
59
+ m : int
60
+ The number of points desired.
61
+ w : complex, optional
62
+ The ratio between points in each step.
63
+ Defaults to equally spaced points around the entire unit circle.
64
+ a : complex, optional
65
+ The starting point in the complex plane. Default is 1+0j.
66
+
67
+ Returns
68
+ -------
69
+ out : ndarray
70
+ The points in the Z plane at which `CZT` samples the z-transform,
71
+ when called with arguments `m`, `w`, and `a`, as complex numbers.
72
+
73
+ See Also
74
+ --------
75
+ CZT : Class that creates a callable chirp z-transform function.
76
+ czt : Convenience function for quickly calculating CZT.
77
+
78
+ Examples
79
+ --------
80
+ Plot the points of a 16-point FFT:
81
+
82
+ >>> import numpy as np
83
+ >>> from scipy.signal import czt_points
84
+ >>> points = czt_points(16)
85
+ >>> import matplotlib.pyplot as plt
86
+ >>> plt.plot(points.real, points.imag, 'o')
87
+ >>> plt.gca().add_patch(plt.Circle((0,0), radius=1, fill=False, alpha=.3))
88
+ >>> plt.axis('equal')
89
+ >>> plt.show()
90
+
91
+ and a 91-point logarithmic spiral that crosses the unit circle:
92
+
93
+ >>> m, w, a = 91, 0.995*np.exp(-1j*np.pi*.05), 0.8*np.exp(1j*np.pi/6)
94
+ >>> points = czt_points(m, w, a)
95
+ >>> plt.plot(points.real, points.imag, 'o')
96
+ >>> plt.gca().add_patch(plt.Circle((0,0), radius=1, fill=False, alpha=.3))
97
+ >>> plt.axis('equal')
98
+ >>> plt.show()
99
+ """
100
+ m = _validate_sizes(1, m)
101
+
102
+ k = arange(m)
103
+
104
+ a = 1.0 * a # at least float
105
+
106
+ if w is None:
107
+ # Nothing specified, default to FFT
108
+ return a * np.exp(2j * pi * k / m)
109
+ else:
110
+ # w specified
111
+ w = 1.0 * w # at least float
112
+ return a * w**-k
113
+
114
+
115
+ class CZT:
116
+ """
117
+ Create a callable chirp z-transform function.
118
+
119
+ Transform to compute the frequency response around a spiral.
120
+ Objects of this class are callables which can compute the
121
+ chirp z-transform on their inputs. This object precalculates the constant
122
+ chirps used in the given transform.
123
+
124
+ Parameters
125
+ ----------
126
+ n : int
127
+ The size of the signal.
128
+ m : int, optional
129
+ The number of output points desired. Default is `n`.
130
+ w : complex, optional
131
+ The ratio between points in each step. This must be precise or the
132
+ accumulated error will degrade the tail of the output sequence.
133
+ Defaults to equally spaced points around the entire unit circle.
134
+ a : complex, optional
135
+ The starting point in the complex plane. Default is 1+0j.
136
+
137
+ Returns
138
+ -------
139
+ f : CZT
140
+ Callable object ``f(x, axis=-1)`` for computing the chirp z-transform
141
+ on `x`.
142
+
143
+ See Also
144
+ --------
145
+ czt : Convenience function for quickly calculating CZT.
146
+ ZoomFFT : Class that creates a callable partial FFT function.
147
+
148
+ Notes
149
+ -----
150
+ The defaults are chosen such that ``f(x)`` is equivalent to
151
+ ``fft.fft(x)`` and, if ``m > len(x)``, that ``f(x, m)`` is equivalent to
152
+ ``fft.fft(x, m)``.
153
+
154
+ If `w` does not lie on the unit circle, then the transform will be
155
+ around a spiral with exponentially-increasing radius. Regardless,
156
+ angle will increase linearly.
157
+
158
+ For transforms that do lie on the unit circle, accuracy is better when
159
+ using `ZoomFFT`, since any numerical error in `w` is
160
+ accumulated for long data lengths, drifting away from the unit circle.
161
+
162
+ The chirp z-transform can be faster than an equivalent FFT with
163
+ zero padding. Try it with your own array sizes to see.
164
+
165
+ However, the chirp z-transform is considerably less precise than the
166
+ equivalent zero-padded FFT.
167
+
168
+ As this CZT is implemented using the Bluestein algorithm, it can compute
169
+ large prime-length Fourier transforms in O(N log N) time, rather than the
170
+ O(N**2) time required by the direct DFT calculation. (`scipy.fft` also
171
+ uses Bluestein's algorithm'.)
172
+
173
+ (The name "chirp z-transform" comes from the use of a chirp in the
174
+ Bluestein algorithm. It does not decompose signals into chirps, like
175
+ other transforms with "chirp" in the name.)
176
+
177
+ References
178
+ ----------
179
+ .. [1] Leo I. Bluestein, "A linear filtering approach to the computation
180
+ of the discrete Fourier transform," Northeast Electronics Research
181
+ and Engineering Meeting Record 10, 218-219 (1968).
182
+ .. [2] Rabiner, Schafer, and Rader, "The chirp z-transform algorithm and
183
+ its application," Bell Syst. Tech. J. 48, 1249-1292 (1969).
184
+
185
+ Examples
186
+ --------
187
+ Compute multiple prime-length FFTs:
188
+
189
+ >>> from scipy.signal import CZT
190
+ >>> import numpy as np
191
+ >>> a = np.random.rand(7)
192
+ >>> b = np.random.rand(7)
193
+ >>> c = np.random.rand(7)
194
+ >>> czt_7 = CZT(n=7)
195
+ >>> A = czt_7(a)
196
+ >>> B = czt_7(b)
197
+ >>> C = czt_7(c)
198
+
199
+ Display the points at which the FFT is calculated:
200
+
201
+ >>> czt_7.points()
202
+ array([ 1.00000000+0.j , 0.62348980+0.78183148j,
203
+ -0.22252093+0.97492791j, -0.90096887+0.43388374j,
204
+ -0.90096887-0.43388374j, -0.22252093-0.97492791j,
205
+ 0.62348980-0.78183148j])
206
+ >>> import matplotlib.pyplot as plt
207
+ >>> plt.plot(czt_7.points().real, czt_7.points().imag, 'o')
208
+ >>> plt.gca().add_patch(plt.Circle((0,0), radius=1, fill=False, alpha=.3))
209
+ >>> plt.axis('equal')
210
+ >>> plt.show()
211
+ """
212
+
213
+ def __init__(self, n, m=None, w=None, a=1+0j):
214
+ m = _validate_sizes(n, m)
215
+
216
+ k = arange(max(m, n), dtype=np.min_scalar_type(-max(m, n)**2))
217
+
218
+ if w is None:
219
+ # Nothing specified, default to FFT-like
220
+ w = cmath.exp(-2j*pi/m)
221
+ wk2 = np.exp(-(1j * pi * ((k**2) % (2*m))) / m)
222
+ else:
223
+ # w specified
224
+ wk2 = w**(k**2/2.)
225
+
226
+ a = 1.0 * a # at least float
227
+
228
+ self.w, self.a = w, a
229
+ self.m, self.n = m, n
230
+
231
+ nfft = next_fast_len(n + m - 1)
232
+ self._Awk2 = a**-k[:n] * wk2[:n]
233
+ self._nfft = nfft
234
+ self._Fwk2 = fft(1/np.hstack((wk2[n-1:0:-1], wk2[:m])), nfft)
235
+ self._wk2 = wk2[:m]
236
+ self._yidx = slice(n-1, n+m-1)
237
+
238
+ def __call__(self, x, *, axis=-1):
239
+ """
240
+ Calculate the chirp z-transform of a signal.
241
+
242
+ Parameters
243
+ ----------
244
+ x : array
245
+ The signal to transform.
246
+ axis : int, optional
247
+ Axis over which to compute the FFT. If not given, the last axis is
248
+ used.
249
+
250
+ Returns
251
+ -------
252
+ out : ndarray
253
+ An array of the same dimensions as `x`, but with the length of the
254
+ transformed axis set to `m`.
255
+ """
256
+ x = np.asarray(x)
257
+ if x.shape[axis] != self.n:
258
+ raise ValueError(f"CZT defined for length {self.n}, not "
259
+ f"{x.shape[axis]}")
260
+ # Calculate transpose coordinates, to allow operation on any given axis
261
+ trnsp = np.arange(x.ndim)
262
+ trnsp[[axis, -1]] = [-1, axis]
263
+ x = x.transpose(*trnsp)
264
+ y = ifft(self._Fwk2 * fft(x*self._Awk2, self._nfft))
265
+ y = y[..., self._yidx] * self._wk2
266
+ return y.transpose(*trnsp)
267
+
268
+ def points(self):
269
+ """
270
+ Return the points at which the chirp z-transform is computed.
271
+ """
272
+ return czt_points(self.m, self.w, self.a)
273
+
274
+
275
+ class ZoomFFT(CZT):
276
+ """
277
+ Create a callable zoom FFT transform function.
278
+
279
+ This is a specialization of the chirp z-transform (`CZT`) for a set of
280
+ equally-spaced frequencies around the unit circle, used to calculate a
281
+ section of the FFT more efficiently than calculating the entire FFT and
282
+ truncating.
283
+
284
+ Parameters
285
+ ----------
286
+ n : int
287
+ The size of the signal.
288
+ fn : array_like
289
+ A length-2 sequence [`f1`, `f2`] giving the frequency range, or a
290
+ scalar, for which the range [0, `fn`] is assumed.
291
+ m : int, optional
292
+ The number of points to evaluate. Default is `n`.
293
+ fs : float, optional
294
+ The sampling frequency. If ``fs=10`` represented 10 kHz, for example,
295
+ then `f1` and `f2` would also be given in kHz.
296
+ The default sampling frequency is 2, so `f1` and `f2` should be
297
+ in the range [0, 1] to keep the transform below the Nyquist
298
+ frequency.
299
+ endpoint : bool, optional
300
+ If True, `f2` is the last sample. Otherwise, it is not included.
301
+ Default is False.
302
+
303
+ Returns
304
+ -------
305
+ f : ZoomFFT
306
+ Callable object ``f(x, axis=-1)`` for computing the zoom FFT on `x`.
307
+
308
+ See Also
309
+ --------
310
+ zoom_fft : Convenience function for calculating a zoom FFT.
311
+
312
+ Notes
313
+ -----
314
+ The defaults are chosen such that ``f(x, 2)`` is equivalent to
315
+ ``fft.fft(x)`` and, if ``m > len(x)``, that ``f(x, 2, m)`` is equivalent to
316
+ ``fft.fft(x, m)``.
317
+
318
+ Sampling frequency is 1/dt, the time step between samples in the
319
+ signal `x`. The unit circle corresponds to frequencies from 0 up
320
+ to the sampling frequency. The default sampling frequency of 2
321
+ means that `f1`, `f2` values up to the Nyquist frequency are in the
322
+ range [0, 1). For `f1`, `f2` values expressed in radians, a sampling
323
+ frequency of 2*pi should be used.
324
+
325
+ Remember that a zoom FFT can only interpolate the points of the existing
326
+ FFT. It cannot help to resolve two separate nearby frequencies.
327
+ Frequency resolution can only be increased by increasing acquisition
328
+ time.
329
+
330
+ These functions are implemented using Bluestein's algorithm (as is
331
+ `scipy.fft`). [2]_
332
+
333
+ References
334
+ ----------
335
+ .. [1] Steve Alan Shilling, "A study of the chirp z-transform and its
336
+ applications", pg 29 (1970)
337
+ https://krex.k-state.edu/dspace/bitstream/handle/2097/7844/LD2668R41972S43.pdf
338
+ .. [2] Leo I. Bluestein, "A linear filtering approach to the computation
339
+ of the discrete Fourier transform," Northeast Electronics Research
340
+ and Engineering Meeting Record 10, 218-219 (1968).
341
+
342
+ Examples
343
+ --------
344
+ To plot the transform results use something like the following:
345
+
346
+ >>> import numpy as np
347
+ >>> from scipy.signal import ZoomFFT
348
+ >>> t = np.linspace(0, 1, 1021)
349
+ >>> x = np.cos(2*np.pi*15*t) + np.sin(2*np.pi*17*t)
350
+ >>> f1, f2 = 5, 27
351
+ >>> transform = ZoomFFT(len(x), [f1, f2], len(x), fs=1021)
352
+ >>> X = transform(x)
353
+ >>> f = np.linspace(f1, f2, len(x))
354
+ >>> import matplotlib.pyplot as plt
355
+ >>> plt.plot(f, 20*np.log10(np.abs(X)))
356
+ >>> plt.show()
357
+ """
358
+
359
+ def __init__(self, n, fn, m=None, *, fs=2, endpoint=False):
360
+ m = _validate_sizes(n, m)
361
+
362
+ k = arange(max(m, n), dtype=np.min_scalar_type(-max(m, n)**2))
363
+
364
+ if np.size(fn) == 2:
365
+ f1, f2 = fn
366
+ elif np.size(fn) == 1:
367
+ f1, f2 = 0.0, fn
368
+ else:
369
+ raise ValueError('fn must be a scalar or 2-length sequence')
370
+
371
+ self.f1, self.f2, self.fs = f1, f2, fs
372
+
373
+ if endpoint:
374
+ scale = ((f2 - f1) * m) / (fs * (m - 1))
375
+ else:
376
+ scale = (f2 - f1) / fs
377
+ a = cmath.exp(2j * pi * f1/fs)
378
+ wk2 = np.exp(-(1j * pi * scale * k**2) / m)
379
+
380
+ self.w = cmath.exp(-2j*pi/m * scale)
381
+ self.a = a
382
+ self.m, self.n = m, n
383
+
384
+ ak = np.exp(-2j * pi * f1/fs * k[:n])
385
+ self._Awk2 = ak * wk2[:n]
386
+
387
+ nfft = next_fast_len(n + m - 1)
388
+ self._nfft = nfft
389
+ self._Fwk2 = fft(1/np.hstack((wk2[n-1:0:-1], wk2[:m])), nfft)
390
+ self._wk2 = wk2[:m]
391
+ self._yidx = slice(n-1, n+m-1)
392
+
393
+
394
+ def czt(x, m=None, w=None, a=1+0j, *, axis=-1):
395
+ """
396
+ Compute the frequency response around a spiral in the Z plane.
397
+
398
+ Parameters
399
+ ----------
400
+ x : array
401
+ The signal to transform.
402
+ m : int, optional
403
+ The number of output points desired. Default is the length of the
404
+ input data.
405
+ w : complex, optional
406
+ The ratio between points in each step. This must be precise or the
407
+ accumulated error will degrade the tail of the output sequence.
408
+ Defaults to equally spaced points around the entire unit circle.
409
+ a : complex, optional
410
+ The starting point in the complex plane. Default is 1+0j.
411
+ axis : int, optional
412
+ Axis over which to compute the FFT. If not given, the last axis is
413
+ used.
414
+
415
+ Returns
416
+ -------
417
+ out : ndarray
418
+ An array of the same dimensions as `x`, but with the length of the
419
+ transformed axis set to `m`.
420
+
421
+ See Also
422
+ --------
423
+ CZT : Class that creates a callable chirp z-transform function.
424
+ zoom_fft : Convenience function for partial FFT calculations.
425
+
426
+ Notes
427
+ -----
428
+ The defaults are chosen such that ``signal.czt(x)`` is equivalent to
429
+ ``fft.fft(x)`` and, if ``m > len(x)``, that ``signal.czt(x, m)`` is
430
+ equivalent to ``fft.fft(x, m)``.
431
+
432
+ If the transform needs to be repeated, use `CZT` to construct a
433
+ specialized transform function which can be reused without
434
+ recomputing constants.
435
+
436
+ An example application is in system identification, repeatedly evaluating
437
+ small slices of the z-transform of a system, around where a pole is
438
+ expected to exist, to refine the estimate of the pole's true location. [1]_
439
+
440
+ References
441
+ ----------
442
+ .. [1] Steve Alan Shilling, "A study of the chirp z-transform and its
443
+ applications", pg 20 (1970)
444
+ https://krex.k-state.edu/dspace/bitstream/handle/2097/7844/LD2668R41972S43.pdf
445
+
446
+ Examples
447
+ --------
448
+ Generate a sinusoid:
449
+
450
+ >>> import numpy as np
451
+ >>> f1, f2, fs = 8, 10, 200 # Hz
452
+ >>> t = np.linspace(0, 1, fs, endpoint=False)
453
+ >>> x = np.sin(2*np.pi*t*f2)
454
+ >>> import matplotlib.pyplot as plt
455
+ >>> plt.plot(t, x)
456
+ >>> plt.axis([0, 1, -1.1, 1.1])
457
+ >>> plt.show()
458
+
459
+ Its discrete Fourier transform has all of its energy in a single frequency
460
+ bin:
461
+
462
+ >>> from scipy.fft import rfft, rfftfreq
463
+ >>> from scipy.signal import czt, czt_points
464
+ >>> plt.plot(rfftfreq(fs, 1/fs), abs(rfft(x)))
465
+ >>> plt.margins(0, 0.1)
466
+ >>> plt.show()
467
+
468
+ However, if the sinusoid is logarithmically-decaying:
469
+
470
+ >>> x = np.exp(-t*f1) * np.sin(2*np.pi*t*f2)
471
+ >>> plt.plot(t, x)
472
+ >>> plt.axis([0, 1, -1.1, 1.1])
473
+ >>> plt.show()
474
+
475
+ the DFT will have spectral leakage:
476
+
477
+ >>> plt.plot(rfftfreq(fs, 1/fs), abs(rfft(x)))
478
+ >>> plt.margins(0, 0.1)
479
+ >>> plt.show()
480
+
481
+ While the DFT always samples the z-transform around the unit circle, the
482
+ chirp z-transform allows us to sample the Z-transform along any
483
+ logarithmic spiral, such as a circle with radius smaller than unity:
484
+
485
+ >>> M = fs // 2 # Just positive frequencies, like rfft
486
+ >>> a = np.exp(-f1/fs) # Starting point of the circle, radius < 1
487
+ >>> w = np.exp(-1j*np.pi/M) # "Step size" of circle
488
+ >>> points = czt_points(M + 1, w, a) # M + 1 to include Nyquist
489
+ >>> plt.plot(points.real, points.imag, '.')
490
+ >>> plt.gca().add_patch(plt.Circle((0,0), radius=1, fill=False, alpha=.3))
491
+ >>> plt.axis('equal'); plt.axis([-1.05, 1.05, -0.05, 1.05])
492
+ >>> plt.show()
493
+
494
+ With the correct radius, this transforms the decaying sinusoid (and others
495
+ with the same decay rate) without spectral leakage:
496
+
497
+ >>> z_vals = czt(x, M + 1, w, a) # Include Nyquist for comparison to rfft
498
+ >>> freqs = np.angle(points)*fs/(2*np.pi) # angle = omega, radius = sigma
499
+ >>> plt.plot(freqs, abs(z_vals))
500
+ >>> plt.margins(0, 0.1)
501
+ >>> plt.show()
502
+ """
503
+ x = np.asarray(x)
504
+ transform = CZT(x.shape[axis], m=m, w=w, a=a)
505
+ return transform(x, axis=axis)
506
+
507
+
508
+ def zoom_fft(x, fn, m=None, *, fs=2, endpoint=False, axis=-1):
509
+ """
510
+ Compute the DFT of `x` only for frequencies in range `fn`.
511
+
512
+ Parameters
513
+ ----------
514
+ x : array
515
+ The signal to transform.
516
+ fn : array_like
517
+ A length-2 sequence [`f1`, `f2`] giving the frequency range, or a
518
+ scalar, for which the range [0, `fn`] is assumed.
519
+ m : int, optional
520
+ The number of points to evaluate. The default is the length of `x`.
521
+ fs : float, optional
522
+ The sampling frequency. If ``fs=10`` represented 10 kHz, for example,
523
+ then `f1` and `f2` would also be given in kHz.
524
+ The default sampling frequency is 2, so `f1` and `f2` should be
525
+ in the range [0, 1] to keep the transform below the Nyquist
526
+ frequency.
527
+ endpoint : bool, optional
528
+ If True, `f2` is the last sample. Otherwise, it is not included.
529
+ Default is False.
530
+ axis : int, optional
531
+ Axis over which to compute the FFT. If not given, the last axis is
532
+ used.
533
+
534
+ Returns
535
+ -------
536
+ out : ndarray
537
+ The transformed signal. The Fourier transform will be calculated
538
+ at the points f1, f1+df, f1+2df, ..., f2, where df=(f2-f1)/m.
539
+
540
+ See Also
541
+ --------
542
+ ZoomFFT : Class that creates a callable partial FFT function.
543
+
544
+ Notes
545
+ -----
546
+ The defaults are chosen such that ``signal.zoom_fft(x, 2)`` is equivalent
547
+ to ``fft.fft(x)`` and, if ``m > len(x)``, that ``signal.zoom_fft(x, 2, m)``
548
+ is equivalent to ``fft.fft(x, m)``.
549
+
550
+ To graph the magnitude of the resulting transform, use::
551
+
552
+ plot(linspace(f1, f2, m, endpoint=False), abs(zoom_fft(x, [f1, f2], m)))
553
+
554
+ If the transform needs to be repeated, use `ZoomFFT` to construct
555
+ a specialized transform function which can be reused without
556
+ recomputing constants.
557
+
558
+ Examples
559
+ --------
560
+ To plot the transform results use something like the following:
561
+
562
+ >>> import numpy as np
563
+ >>> from scipy.signal import zoom_fft
564
+ >>> t = np.linspace(0, 1, 1021)
565
+ >>> x = np.cos(2*np.pi*15*t) + np.sin(2*np.pi*17*t)
566
+ >>> f1, f2 = 5, 27
567
+ >>> X = zoom_fft(x, [f1, f2], len(x), fs=1021)
568
+ >>> f = np.linspace(f1, f2, len(x))
569
+ >>> import matplotlib.pyplot as plt
570
+ >>> plt.plot(f, 20*np.log10(np.abs(X)))
571
+ >>> plt.show()
572
+ """
573
+ x = np.asarray(x)
574
+ transform = ZoomFFT(x.shape[axis], fn, m=m, fs=fs, endpoint=endpoint)
575
+ return transform(x, axis=axis)