scipy 1.15.3__cp313-cp313-musllinux_1_2_aarch64.whl → 1.16.0__cp313-cp313-musllinux_1_2_aarch64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (642) hide show
  1. scipy/__config__.py +11 -11
  2. scipy/__init__.py +3 -6
  3. scipy/_cyutility.cpython-313-aarch64-linux-musl.so +0 -0
  4. scipy/_lib/_array_api.py +486 -161
  5. scipy/_lib/_array_api_compat_vendor.py +9 -0
  6. scipy/_lib/_bunch.py +4 -0
  7. scipy/_lib/_ccallback_c.cpython-313-aarch64-linux-musl.so +0 -0
  8. scipy/_lib/_docscrape.py +1 -1
  9. scipy/_lib/_elementwise_iterative_method.py +15 -26
  10. scipy/_lib/_fpumode.cpython-313-aarch64-linux-musl.so +0 -0
  11. scipy/_lib/_sparse.py +41 -0
  12. scipy/_lib/_test_ccallback.cpython-313-aarch64-linux-musl.so +0 -0
  13. scipy/_lib/_test_deprecation_call.cpython-313-aarch64-linux-musl.so +0 -0
  14. scipy/_lib/_test_deprecation_def.cpython-313-aarch64-linux-musl.so +0 -0
  15. scipy/_lib/_testutils.py +6 -2
  16. scipy/_lib/_uarray/_uarray.cpython-313-aarch64-linux-musl.so +0 -0
  17. scipy/_lib/_util.py +222 -125
  18. scipy/_lib/array_api_compat/__init__.py +4 -4
  19. scipy/_lib/array_api_compat/_internal.py +19 -6
  20. scipy/_lib/array_api_compat/common/__init__.py +1 -1
  21. scipy/_lib/array_api_compat/common/_aliases.py +365 -193
  22. scipy/_lib/array_api_compat/common/_fft.py +94 -64
  23. scipy/_lib/array_api_compat/common/_helpers.py +413 -180
  24. scipy/_lib/array_api_compat/common/_linalg.py +116 -40
  25. scipy/_lib/array_api_compat/common/_typing.py +179 -10
  26. scipy/_lib/array_api_compat/cupy/__init__.py +1 -4
  27. scipy/_lib/array_api_compat/cupy/_aliases.py +61 -41
  28. scipy/_lib/array_api_compat/cupy/_info.py +16 -6
  29. scipy/_lib/array_api_compat/cupy/_typing.py +24 -39
  30. scipy/_lib/array_api_compat/dask/array/__init__.py +6 -3
  31. scipy/_lib/array_api_compat/dask/array/_aliases.py +267 -108
  32. scipy/_lib/array_api_compat/dask/array/_info.py +105 -34
  33. scipy/_lib/array_api_compat/dask/array/fft.py +5 -8
  34. scipy/_lib/array_api_compat/dask/array/linalg.py +21 -22
  35. scipy/_lib/array_api_compat/numpy/__init__.py +13 -15
  36. scipy/_lib/array_api_compat/numpy/_aliases.py +98 -49
  37. scipy/_lib/array_api_compat/numpy/_info.py +36 -16
  38. scipy/_lib/array_api_compat/numpy/_typing.py +27 -43
  39. scipy/_lib/array_api_compat/numpy/fft.py +11 -5
  40. scipy/_lib/array_api_compat/numpy/linalg.py +75 -22
  41. scipy/_lib/array_api_compat/torch/__init__.py +3 -5
  42. scipy/_lib/array_api_compat/torch/_aliases.py +262 -159
  43. scipy/_lib/array_api_compat/torch/_info.py +27 -16
  44. scipy/_lib/array_api_compat/torch/_typing.py +3 -0
  45. scipy/_lib/array_api_compat/torch/fft.py +17 -18
  46. scipy/_lib/array_api_compat/torch/linalg.py +16 -16
  47. scipy/_lib/array_api_extra/__init__.py +26 -3
  48. scipy/_lib/array_api_extra/_delegation.py +171 -0
  49. scipy/_lib/array_api_extra/_lib/__init__.py +1 -0
  50. scipy/_lib/array_api_extra/_lib/_at.py +463 -0
  51. scipy/_lib/array_api_extra/_lib/_backends.py +46 -0
  52. scipy/_lib/array_api_extra/_lib/_funcs.py +937 -0
  53. scipy/_lib/array_api_extra/_lib/_lazy.py +357 -0
  54. scipy/_lib/array_api_extra/_lib/_testing.py +278 -0
  55. scipy/_lib/array_api_extra/_lib/_utils/__init__.py +1 -0
  56. scipy/_lib/array_api_extra/_lib/_utils/_compat.py +74 -0
  57. scipy/_lib/array_api_extra/_lib/_utils/_compat.pyi +45 -0
  58. scipy/_lib/array_api_extra/_lib/_utils/_helpers.py +559 -0
  59. scipy/_lib/array_api_extra/_lib/_utils/_typing.py +10 -0
  60. scipy/_lib/array_api_extra/_lib/_utils/_typing.pyi +105 -0
  61. scipy/_lib/array_api_extra/testing.py +359 -0
  62. scipy/_lib/decorator.py +2 -2
  63. scipy/_lib/doccer.py +1 -7
  64. scipy/_lib/messagestream.cpython-313-aarch64-linux-musl.so +0 -0
  65. scipy/_lib/pyprima/__init__.py +212 -0
  66. scipy/_lib/pyprima/cobyla/__init__.py +0 -0
  67. scipy/_lib/pyprima/cobyla/cobyla.py +559 -0
  68. scipy/_lib/pyprima/cobyla/cobylb.py +714 -0
  69. scipy/_lib/pyprima/cobyla/geometry.py +226 -0
  70. scipy/_lib/pyprima/cobyla/initialize.py +215 -0
  71. scipy/_lib/pyprima/cobyla/trustregion.py +492 -0
  72. scipy/_lib/pyprima/cobyla/update.py +289 -0
  73. scipy/_lib/pyprima/common/__init__.py +0 -0
  74. scipy/_lib/pyprima/common/_bounds.py +34 -0
  75. scipy/_lib/pyprima/common/_linear_constraints.py +46 -0
  76. scipy/_lib/pyprima/common/_nonlinear_constraints.py +54 -0
  77. scipy/_lib/pyprima/common/_project.py +173 -0
  78. scipy/_lib/pyprima/common/checkbreak.py +93 -0
  79. scipy/_lib/pyprima/common/consts.py +47 -0
  80. scipy/_lib/pyprima/common/evaluate.py +99 -0
  81. scipy/_lib/pyprima/common/history.py +38 -0
  82. scipy/_lib/pyprima/common/infos.py +30 -0
  83. scipy/_lib/pyprima/common/linalg.py +435 -0
  84. scipy/_lib/pyprima/common/message.py +290 -0
  85. scipy/_lib/pyprima/common/powalg.py +131 -0
  86. scipy/_lib/pyprima/common/preproc.py +277 -0
  87. scipy/_lib/pyprima/common/present.py +5 -0
  88. scipy/_lib/pyprima/common/ratio.py +54 -0
  89. scipy/_lib/pyprima/common/redrho.py +47 -0
  90. scipy/_lib/pyprima/common/selectx.py +296 -0
  91. scipy/_lib/tests/test__util.py +105 -121
  92. scipy/_lib/tests/test_array_api.py +166 -35
  93. scipy/_lib/tests/test_bunch.py +7 -0
  94. scipy/_lib/tests/test_ccallback.py +2 -10
  95. scipy/_lib/tests/test_public_api.py +13 -0
  96. scipy/cluster/_hierarchy.cpython-313-aarch64-linux-musl.so +0 -0
  97. scipy/cluster/_optimal_leaf_ordering.cpython-313-aarch64-linux-musl.so +0 -0
  98. scipy/cluster/_vq.cpython-313-aarch64-linux-musl.so +0 -0
  99. scipy/cluster/hierarchy.py +393 -223
  100. scipy/cluster/tests/test_hierarchy.py +273 -335
  101. scipy/cluster/tests/test_vq.py +45 -61
  102. scipy/cluster/vq.py +39 -35
  103. scipy/conftest.py +282 -151
  104. scipy/constants/_constants.py +4 -1
  105. scipy/constants/tests/test_codata.py +2 -2
  106. scipy/constants/tests/test_constants.py +11 -18
  107. scipy/datasets/_download_all.py +15 -1
  108. scipy/datasets/_fetchers.py +7 -1
  109. scipy/datasets/_utils.py +1 -1
  110. scipy/differentiate/_differentiate.py +25 -25
  111. scipy/differentiate/tests/test_differentiate.py +24 -25
  112. scipy/fft/_basic.py +20 -0
  113. scipy/fft/_helper.py +3 -34
  114. scipy/fft/_pocketfft/helper.py +29 -1
  115. scipy/fft/_pocketfft/pypocketfft.cpython-313-aarch64-linux-musl.so +0 -0
  116. scipy/fft/_pocketfft/tests/test_basic.py +2 -4
  117. scipy/fft/_pocketfft/tests/test_real_transforms.py +4 -4
  118. scipy/fft/_realtransforms.py +13 -0
  119. scipy/fft/tests/test_basic.py +27 -25
  120. scipy/fft/tests/test_fftlog.py +16 -7
  121. scipy/fft/tests/test_helper.py +18 -34
  122. scipy/fft/tests/test_real_transforms.py +8 -10
  123. scipy/fftpack/convolve.cpython-313-aarch64-linux-musl.so +0 -0
  124. scipy/fftpack/tests/test_basic.py +2 -4
  125. scipy/fftpack/tests/test_real_transforms.py +8 -9
  126. scipy/integrate/_bvp.py +9 -3
  127. scipy/integrate/_cubature.py +3 -2
  128. scipy/integrate/_dop.cpython-313-aarch64-linux-musl.so +0 -0
  129. scipy/integrate/_lsoda.cpython-313-aarch64-linux-musl.so +0 -0
  130. scipy/integrate/_ode.py +9 -2
  131. scipy/integrate/_odepack.cpython-313-aarch64-linux-musl.so +0 -0
  132. scipy/integrate/_quad_vec.py +21 -29
  133. scipy/integrate/_quadpack.cpython-313-aarch64-linux-musl.so +0 -0
  134. scipy/integrate/_quadpack_py.py +11 -7
  135. scipy/integrate/_quadrature.py +3 -3
  136. scipy/integrate/_rules/_base.py +2 -2
  137. scipy/integrate/_tanhsinh.py +48 -47
  138. scipy/integrate/_test_multivariate.cpython-313-aarch64-linux-musl.so +0 -0
  139. scipy/integrate/_test_odeint_banded.cpython-313-aarch64-linux-musl.so +0 -0
  140. scipy/integrate/_vode.cpython-313-aarch64-linux-musl.so +0 -0
  141. scipy/integrate/tests/test__quad_vec.py +0 -6
  142. scipy/integrate/tests/test_banded_ode_solvers.py +85 -0
  143. scipy/integrate/tests/test_cubature.py +21 -35
  144. scipy/integrate/tests/test_quadrature.py +6 -8
  145. scipy/integrate/tests/test_tanhsinh.py +56 -48
  146. scipy/interpolate/__init__.py +70 -58
  147. scipy/interpolate/_bary_rational.py +22 -22
  148. scipy/interpolate/_bsplines.py +119 -66
  149. scipy/interpolate/_cubic.py +65 -50
  150. scipy/interpolate/_dfitpack.cpython-313-aarch64-linux-musl.so +0 -0
  151. scipy/interpolate/_dierckx.cpython-313-aarch64-linux-musl.so +0 -0
  152. scipy/interpolate/_fitpack.cpython-313-aarch64-linux-musl.so +0 -0
  153. scipy/interpolate/_fitpack2.py +9 -6
  154. scipy/interpolate/_fitpack_impl.py +32 -26
  155. scipy/interpolate/_fitpack_repro.py +23 -19
  156. scipy/interpolate/_interpnd.cpython-313-aarch64-linux-musl.so +0 -0
  157. scipy/interpolate/_interpolate.py +30 -12
  158. scipy/interpolate/_ndbspline.py +13 -18
  159. scipy/interpolate/_ndgriddata.py +5 -8
  160. scipy/interpolate/_polyint.py +95 -31
  161. scipy/interpolate/_ppoly.cpython-313-aarch64-linux-musl.so +0 -0
  162. scipy/interpolate/_rbf.py +2 -2
  163. scipy/interpolate/_rbfinterp.py +1 -1
  164. scipy/interpolate/_rbfinterp_pythran.cpython-313-aarch64-linux-musl.so +0 -0
  165. scipy/interpolate/_rgi.py +31 -26
  166. scipy/interpolate/_rgi_cython.cpython-313-aarch64-linux-musl.so +0 -0
  167. scipy/interpolate/dfitpack.py +0 -20
  168. scipy/interpolate/interpnd.py +1 -2
  169. scipy/interpolate/tests/test_bary_rational.py +2 -2
  170. scipy/interpolate/tests/test_bsplines.py +97 -1
  171. scipy/interpolate/tests/test_fitpack2.py +39 -1
  172. scipy/interpolate/tests/test_interpnd.py +32 -20
  173. scipy/interpolate/tests/test_interpolate.py +48 -4
  174. scipy/interpolate/tests/test_rgi.py +2 -1
  175. scipy/io/_fast_matrix_market/__init__.py +2 -0
  176. scipy/io/_fast_matrix_market/_fmm_core.cpython-313-aarch64-linux-musl.so +0 -0
  177. scipy/io/_harwell_boeing/_fortran_format_parser.py +19 -16
  178. scipy/io/_harwell_boeing/hb.py +7 -11
  179. scipy/io/_idl.py +5 -7
  180. scipy/io/_netcdf.py +15 -5
  181. scipy/io/_test_fortran.cpython-313-aarch64-linux-musl.so +0 -0
  182. scipy/io/arff/tests/test_arffread.py +3 -3
  183. scipy/io/matlab/__init__.py +5 -3
  184. scipy/io/matlab/_mio.py +4 -1
  185. scipy/io/matlab/_mio5.py +19 -13
  186. scipy/io/matlab/_mio5_utils.cpython-313-aarch64-linux-musl.so +0 -0
  187. scipy/io/matlab/_mio_utils.cpython-313-aarch64-linux-musl.so +0 -0
  188. scipy/io/matlab/_miobase.py +4 -1
  189. scipy/io/matlab/_streams.cpython-313-aarch64-linux-musl.so +0 -0
  190. scipy/io/matlab/tests/test_mio.py +46 -18
  191. scipy/io/matlab/tests/test_mio_funcs.py +1 -1
  192. scipy/io/tests/test_mmio.py +7 -1
  193. scipy/io/tests/test_wavfile.py +41 -0
  194. scipy/io/wavfile.py +57 -10
  195. scipy/linalg/_basic.py +113 -86
  196. scipy/linalg/_cythonized_array_utils.cpython-313-aarch64-linux-musl.so +0 -0
  197. scipy/linalg/_decomp.py +22 -9
  198. scipy/linalg/_decomp_cholesky.py +28 -13
  199. scipy/linalg/_decomp_cossin.py +45 -30
  200. scipy/linalg/_decomp_interpolative.cpython-313-aarch64-linux-musl.so +0 -0
  201. scipy/linalg/_decomp_ldl.py +4 -1
  202. scipy/linalg/_decomp_lu.py +18 -6
  203. scipy/linalg/_decomp_lu_cython.cpython-313-aarch64-linux-musl.so +0 -0
  204. scipy/linalg/_decomp_polar.py +2 -0
  205. scipy/linalg/_decomp_qr.py +6 -2
  206. scipy/linalg/_decomp_qz.py +3 -0
  207. scipy/linalg/_decomp_schur.py +3 -1
  208. scipy/linalg/_decomp_svd.py +13 -2
  209. scipy/linalg/_decomp_update.cpython-313-aarch64-linux-musl.so +0 -0
  210. scipy/linalg/_expm_frechet.py +4 -0
  211. scipy/linalg/_fblas.cpython-313-aarch64-linux-musl.so +0 -0
  212. scipy/linalg/_flapack.cpython-313-aarch64-linux-musl.so +0 -0
  213. scipy/linalg/_linalg_pythran.cpython-313-aarch64-linux-musl.so +0 -0
  214. scipy/linalg/_matfuncs.py +187 -4
  215. scipy/linalg/_matfuncs_expm.cpython-313-aarch64-linux-musl.so +0 -0
  216. scipy/linalg/_matfuncs_schur_sqrtm.cpython-313-aarch64-linux-musl.so +0 -0
  217. scipy/linalg/_matfuncs_sqrtm.py +1 -99
  218. scipy/linalg/_matfuncs_sqrtm_triu.cpython-313-aarch64-linux-musl.so +0 -0
  219. scipy/linalg/_procrustes.py +2 -0
  220. scipy/linalg/_sketches.py +17 -6
  221. scipy/linalg/_solve_toeplitz.cpython-313-aarch64-linux-musl.so +0 -0
  222. scipy/linalg/_solvers.py +7 -2
  223. scipy/linalg/_special_matrices.py +26 -36
  224. scipy/linalg/blas.py +35 -24
  225. scipy/linalg/cython_blas.cpython-313-aarch64-linux-musl.so +0 -0
  226. scipy/linalg/cython_lapack.cpython-313-aarch64-linux-musl.so +0 -0
  227. scipy/linalg/lapack.py +22 -2
  228. scipy/linalg/tests/_cython_examples/meson.build +7 -0
  229. scipy/linalg/tests/test_basic.py +31 -16
  230. scipy/linalg/tests/test_batch.py +588 -0
  231. scipy/linalg/tests/test_cythonized_array_utils.py +0 -2
  232. scipy/linalg/tests/test_decomp.py +40 -3
  233. scipy/linalg/tests/test_decomp_cossin.py +14 -0
  234. scipy/linalg/tests/test_decomp_ldl.py +1 -1
  235. scipy/linalg/tests/test_lapack.py +115 -7
  236. scipy/linalg/tests/test_matfuncs.py +157 -102
  237. scipy/linalg/tests/test_procrustes.py +0 -7
  238. scipy/linalg/tests/test_solve_toeplitz.py +1 -1
  239. scipy/linalg/tests/test_special_matrices.py +1 -5
  240. scipy/ndimage/__init__.py +1 -0
  241. scipy/ndimage/_ctest.cpython-313-aarch64-linux-musl.so +0 -0
  242. scipy/ndimage/_cytest.cpython-313-aarch64-linux-musl.so +0 -0
  243. scipy/ndimage/_delegators.py +8 -2
  244. scipy/ndimage/_filters.py +453 -5
  245. scipy/ndimage/_interpolation.py +36 -6
  246. scipy/ndimage/_measurements.py +4 -2
  247. scipy/ndimage/_morphology.py +5 -0
  248. scipy/ndimage/_nd_image.cpython-313-aarch64-linux-musl.so +0 -0
  249. scipy/ndimage/_ni_docstrings.py +5 -1
  250. scipy/ndimage/_ni_label.cpython-313-aarch64-linux-musl.so +0 -0
  251. scipy/ndimage/_ni_support.py +1 -5
  252. scipy/ndimage/_rank_filter_1d.cpython-313-aarch64-linux-musl.so +0 -0
  253. scipy/ndimage/_support_alternative_backends.py +18 -6
  254. scipy/ndimage/tests/test_filters.py +370 -259
  255. scipy/ndimage/tests/test_fourier.py +7 -9
  256. scipy/ndimage/tests/test_interpolation.py +68 -61
  257. scipy/ndimage/tests/test_measurements.py +18 -35
  258. scipy/ndimage/tests/test_morphology.py +143 -131
  259. scipy/ndimage/tests/test_splines.py +1 -3
  260. scipy/odr/__odrpack.cpython-313-aarch64-linux-musl.so +0 -0
  261. scipy/optimize/_basinhopping.py +13 -7
  262. scipy/optimize/_bglu_dense.cpython-313-aarch64-linux-musl.so +0 -0
  263. scipy/optimize/_bracket.py +17 -24
  264. scipy/optimize/_chandrupatla.py +9 -10
  265. scipy/optimize/_cobyla_py.py +104 -123
  266. scipy/optimize/_constraints.py +14 -10
  267. scipy/optimize/_differentiable_functions.py +371 -230
  268. scipy/optimize/_differentialevolution.py +4 -3
  269. scipy/optimize/_direct.cpython-313-aarch64-linux-musl.so +0 -0
  270. scipy/optimize/_dual_annealing.py +1 -1
  271. scipy/optimize/_elementwise.py +1 -4
  272. scipy/optimize/_group_columns.cpython-313-aarch64-linux-musl.so +0 -0
  273. scipy/optimize/_highspy/_core.cpython-313-aarch64-linux-musl.so +0 -0
  274. scipy/optimize/_highspy/_highs_options.cpython-313-aarch64-linux-musl.so +0 -0
  275. scipy/optimize/_lbfgsb.cpython-313-aarch64-linux-musl.so +0 -0
  276. scipy/optimize/_lbfgsb_py.py +80 -24
  277. scipy/optimize/_linprog_doc.py +2 -2
  278. scipy/optimize/_linprog_highs.py +2 -2
  279. scipy/optimize/_linprog_ip.py +25 -10
  280. scipy/optimize/_linprog_util.py +14 -16
  281. scipy/optimize/_lsap.cpython-313-aarch64-linux-musl.so +0 -0
  282. scipy/optimize/_lsq/common.py +3 -3
  283. scipy/optimize/_lsq/dogbox.py +16 -2
  284. scipy/optimize/_lsq/givens_elimination.cpython-313-aarch64-linux-musl.so +0 -0
  285. scipy/optimize/_lsq/least_squares.py +198 -126
  286. scipy/optimize/_lsq/lsq_linear.py +6 -6
  287. scipy/optimize/_lsq/trf.py +35 -8
  288. scipy/optimize/_milp.py +3 -1
  289. scipy/optimize/_minimize.py +105 -36
  290. scipy/optimize/_minpack.cpython-313-aarch64-linux-musl.so +0 -0
  291. scipy/optimize/_minpack_py.py +21 -14
  292. scipy/optimize/_moduleTNC.cpython-313-aarch64-linux-musl.so +0 -0
  293. scipy/optimize/_nnls.py +20 -21
  294. scipy/optimize/_nonlin.py +34 -3
  295. scipy/optimize/_numdiff.py +288 -110
  296. scipy/optimize/_optimize.py +86 -48
  297. scipy/optimize/_pava_pybind.cpython-313-aarch64-linux-musl.so +0 -0
  298. scipy/optimize/_remove_redundancy.py +5 -5
  299. scipy/optimize/_root_scalar.py +1 -1
  300. scipy/optimize/_shgo.py +6 -0
  301. scipy/optimize/_shgo_lib/_complex.py +1 -1
  302. scipy/optimize/_slsqp_py.py +216 -124
  303. scipy/optimize/_slsqplib.cpython-313-aarch64-linux-musl.so +0 -0
  304. scipy/optimize/_spectral.py +1 -1
  305. scipy/optimize/_tnc.py +8 -1
  306. scipy/optimize/_trlib/_trlib.cpython-313-aarch64-linux-musl.so +0 -0
  307. scipy/optimize/_trustregion.py +20 -6
  308. scipy/optimize/_trustregion_constr/canonical_constraint.py +7 -7
  309. scipy/optimize/_trustregion_constr/equality_constrained_sqp.py +1 -1
  310. scipy/optimize/_trustregion_constr/minimize_trustregion_constr.py +11 -3
  311. scipy/optimize/_trustregion_constr/projections.py +12 -8
  312. scipy/optimize/_trustregion_constr/qp_subproblem.py +9 -9
  313. scipy/optimize/_trustregion_constr/tests/test_projections.py +7 -7
  314. scipy/optimize/_trustregion_constr/tests/test_qp_subproblem.py +77 -77
  315. scipy/optimize/_trustregion_constr/tr_interior_point.py +5 -5
  316. scipy/optimize/_trustregion_exact.py +0 -1
  317. scipy/optimize/_zeros.cpython-313-aarch64-linux-musl.so +0 -0
  318. scipy/optimize/_zeros_py.py +97 -17
  319. scipy/optimize/cython_optimize/_zeros.cpython-313-aarch64-linux-musl.so +0 -0
  320. scipy/optimize/slsqp.py +0 -1
  321. scipy/optimize/tests/test__basinhopping.py +1 -1
  322. scipy/optimize/tests/test__differential_evolution.py +4 -4
  323. scipy/optimize/tests/test__linprog_clean_inputs.py +5 -3
  324. scipy/optimize/tests/test__numdiff.py +66 -22
  325. scipy/optimize/tests/test__remove_redundancy.py +2 -2
  326. scipy/optimize/tests/test__shgo.py +9 -1
  327. scipy/optimize/tests/test_bracket.py +36 -46
  328. scipy/optimize/tests/test_chandrupatla.py +133 -135
  329. scipy/optimize/tests/test_cobyla.py +74 -45
  330. scipy/optimize/tests/test_constraints.py +1 -1
  331. scipy/optimize/tests/test_differentiable_functions.py +226 -6
  332. scipy/optimize/tests/test_lbfgsb_hessinv.py +22 -0
  333. scipy/optimize/tests/test_least_squares.py +125 -13
  334. scipy/optimize/tests/test_linear_assignment.py +3 -3
  335. scipy/optimize/tests/test_linprog.py +3 -3
  336. scipy/optimize/tests/test_lsq_linear.py +6 -6
  337. scipy/optimize/tests/test_minimize_constrained.py +2 -2
  338. scipy/optimize/tests/test_minpack.py +4 -4
  339. scipy/optimize/tests/test_nnls.py +43 -3
  340. scipy/optimize/tests/test_nonlin.py +36 -0
  341. scipy/optimize/tests/test_optimize.py +98 -20
  342. scipy/optimize/tests/test_slsqp.py +36 -4
  343. scipy/optimize/tests/test_zeros.py +34 -1
  344. scipy/signal/__init__.py +12 -23
  345. scipy/signal/_delegators.py +568 -0
  346. scipy/signal/_filter_design.py +459 -241
  347. scipy/signal/_fir_filter_design.py +262 -90
  348. scipy/signal/_lti_conversion.py +3 -2
  349. scipy/signal/_ltisys.py +118 -91
  350. scipy/signal/_max_len_seq_inner.cpython-313-aarch64-linux-musl.so +0 -0
  351. scipy/signal/_peak_finding_utils.cpython-313-aarch64-linux-musl.so +0 -0
  352. scipy/signal/_polyutils.py +172 -0
  353. scipy/signal/_short_time_fft.py +519 -70
  354. scipy/signal/_signal_api.py +30 -0
  355. scipy/signal/_signaltools.py +719 -399
  356. scipy/signal/_sigtools.cpython-313-aarch64-linux-musl.so +0 -0
  357. scipy/signal/_sosfilt.cpython-313-aarch64-linux-musl.so +0 -0
  358. scipy/signal/_spectral_py.py +230 -50
  359. scipy/signal/_spline.cpython-313-aarch64-linux-musl.so +0 -0
  360. scipy/signal/_spline_filters.py +108 -68
  361. scipy/signal/_support_alternative_backends.py +73 -0
  362. scipy/signal/_upfirdn.py +4 -1
  363. scipy/signal/_upfirdn_apply.cpython-313-aarch64-linux-musl.so +0 -0
  364. scipy/signal/_waveforms.py +2 -11
  365. scipy/signal/_wavelets.py +1 -1
  366. scipy/signal/fir_filter_design.py +1 -0
  367. scipy/signal/spline.py +4 -11
  368. scipy/signal/tests/_scipy_spectral_test_shim.py +2 -171
  369. scipy/signal/tests/test_bsplines.py +114 -79
  370. scipy/signal/tests/test_cont2discrete.py +9 -2
  371. scipy/signal/tests/test_filter_design.py +721 -481
  372. scipy/signal/tests/test_fir_filter_design.py +332 -140
  373. scipy/signal/tests/test_savitzky_golay.py +4 -3
  374. scipy/signal/tests/test_short_time_fft.py +221 -3
  375. scipy/signal/tests/test_signaltools.py +2145 -1349
  376. scipy/signal/tests/test_spectral.py +50 -6
  377. scipy/signal/tests/test_splines.py +161 -96
  378. scipy/signal/tests/test_upfirdn.py +84 -50
  379. scipy/signal/tests/test_waveforms.py +20 -0
  380. scipy/signal/tests/test_windows.py +607 -466
  381. scipy/signal/windows/_windows.py +287 -148
  382. scipy/sparse/__init__.py +23 -4
  383. scipy/sparse/_base.py +270 -108
  384. scipy/sparse/_bsr.py +7 -4
  385. scipy/sparse/_compressed.py +59 -231
  386. scipy/sparse/_construct.py +90 -38
  387. scipy/sparse/_coo.py +115 -181
  388. scipy/sparse/_csc.py +4 -4
  389. scipy/sparse/_csparsetools.cpython-313-aarch64-linux-musl.so +0 -0
  390. scipy/sparse/_csr.py +2 -2
  391. scipy/sparse/_data.py +48 -48
  392. scipy/sparse/_dia.py +105 -18
  393. scipy/sparse/_dok.py +0 -23
  394. scipy/sparse/_index.py +4 -4
  395. scipy/sparse/_matrix.py +23 -0
  396. scipy/sparse/_sparsetools.cpython-313-aarch64-linux-musl.so +0 -0
  397. scipy/sparse/_sputils.py +37 -22
  398. scipy/sparse/base.py +0 -9
  399. scipy/sparse/bsr.py +0 -14
  400. scipy/sparse/compressed.py +0 -23
  401. scipy/sparse/construct.py +0 -6
  402. scipy/sparse/coo.py +0 -14
  403. scipy/sparse/csc.py +0 -3
  404. scipy/sparse/csgraph/_flow.cpython-313-aarch64-linux-musl.so +0 -0
  405. scipy/sparse/csgraph/_matching.cpython-313-aarch64-linux-musl.so +0 -0
  406. scipy/sparse/csgraph/_min_spanning_tree.cpython-313-aarch64-linux-musl.so +0 -0
  407. scipy/sparse/csgraph/_reordering.cpython-313-aarch64-linux-musl.so +0 -0
  408. scipy/sparse/csgraph/_shortest_path.cpython-313-aarch64-linux-musl.so +0 -0
  409. scipy/sparse/csgraph/_tools.cpython-313-aarch64-linux-musl.so +0 -0
  410. scipy/sparse/csgraph/_traversal.cpython-313-aarch64-linux-musl.so +0 -0
  411. scipy/sparse/csgraph/tests/test_matching.py +14 -2
  412. scipy/sparse/csgraph/tests/test_pydata_sparse.py +4 -1
  413. scipy/sparse/csgraph/tests/test_shortest_path.py +83 -27
  414. scipy/sparse/csr.py +0 -5
  415. scipy/sparse/data.py +1 -6
  416. scipy/sparse/dia.py +0 -7
  417. scipy/sparse/dok.py +0 -10
  418. scipy/sparse/linalg/_dsolve/_superlu.cpython-313-aarch64-linux-musl.so +0 -0
  419. scipy/sparse/linalg/_dsolve/linsolve.py +9 -0
  420. scipy/sparse/linalg/_dsolve/tests/test_linsolve.py +35 -28
  421. scipy/sparse/linalg/_eigen/arpack/_arpack.cpython-313-aarch64-linux-musl.so +0 -0
  422. scipy/sparse/linalg/_eigen/arpack/arpack.py +23 -17
  423. scipy/sparse/linalg/_eigen/lobpcg/lobpcg.py +6 -6
  424. scipy/sparse/linalg/_interface.py +17 -18
  425. scipy/sparse/linalg/_isolve/_gcrotmk.py +4 -4
  426. scipy/sparse/linalg/_isolve/iterative.py +51 -45
  427. scipy/sparse/linalg/_isolve/lgmres.py +6 -6
  428. scipy/sparse/linalg/_isolve/minres.py +5 -5
  429. scipy/sparse/linalg/_isolve/tfqmr.py +7 -7
  430. scipy/sparse/linalg/_isolve/utils.py +2 -8
  431. scipy/sparse/linalg/_matfuncs.py +1 -1
  432. scipy/sparse/linalg/_norm.py +1 -1
  433. scipy/sparse/linalg/_propack/_cpropack.cpython-313-aarch64-linux-musl.so +0 -0
  434. scipy/sparse/linalg/_propack/_dpropack.cpython-313-aarch64-linux-musl.so +0 -0
  435. scipy/sparse/linalg/_propack/_spropack.cpython-313-aarch64-linux-musl.so +0 -0
  436. scipy/sparse/linalg/_propack/_zpropack.cpython-313-aarch64-linux-musl.so +0 -0
  437. scipy/sparse/linalg/_special_sparse_arrays.py +39 -38
  438. scipy/sparse/linalg/tests/test_pydata_sparse.py +14 -0
  439. scipy/sparse/tests/test_arithmetic1d.py +5 -2
  440. scipy/sparse/tests/test_base.py +214 -42
  441. scipy/sparse/tests/test_common1d.py +7 -7
  442. scipy/sparse/tests/test_construct.py +1 -1
  443. scipy/sparse/tests/test_coo.py +272 -4
  444. scipy/sparse/tests/test_sparsetools.py +5 -0
  445. scipy/sparse/tests/test_sputils.py +36 -7
  446. scipy/spatial/_ckdtree.cpython-313-aarch64-linux-musl.so +0 -0
  447. scipy/spatial/_distance_pybind.cpython-313-aarch64-linux-musl.so +0 -0
  448. scipy/spatial/_distance_wrap.cpython-313-aarch64-linux-musl.so +0 -0
  449. scipy/spatial/_hausdorff.cpython-313-aarch64-linux-musl.so +0 -0
  450. scipy/spatial/_qhull.cpython-313-aarch64-linux-musl.so +0 -0
  451. scipy/spatial/_voronoi.cpython-313-aarch64-linux-musl.so +0 -0
  452. scipy/spatial/distance.py +49 -42
  453. scipy/spatial/tests/test_distance.py +15 -1
  454. scipy/spatial/tests/test_kdtree.py +1 -0
  455. scipy/spatial/tests/test_qhull.py +7 -2
  456. scipy/spatial/transform/__init__.py +5 -3
  457. scipy/spatial/transform/_rigid_transform.cpython-313-aarch64-linux-musl.so +0 -0
  458. scipy/spatial/transform/_rotation.cpython-313-aarch64-linux-musl.so +0 -0
  459. scipy/spatial/transform/tests/test_rigid_transform.py +1221 -0
  460. scipy/spatial/transform/tests/test_rotation.py +1213 -832
  461. scipy/spatial/transform/tests/test_rotation_groups.py +3 -3
  462. scipy/spatial/transform/tests/test_rotation_spline.py +29 -8
  463. scipy/special/__init__.py +1 -47
  464. scipy/special/_add_newdocs.py +34 -772
  465. scipy/special/_basic.py +22 -25
  466. scipy/special/_comb.cpython-313-aarch64-linux-musl.so +0 -0
  467. scipy/special/_ellip_harm_2.cpython-313-aarch64-linux-musl.so +0 -0
  468. scipy/special/_gufuncs.cpython-313-aarch64-linux-musl.so +0 -0
  469. scipy/special/_logsumexp.py +67 -58
  470. scipy/special/_orthogonal.pyi +1 -1
  471. scipy/special/_specfun.cpython-313-aarch64-linux-musl.so +0 -0
  472. scipy/special/_special_ufuncs.cpython-313-aarch64-linux-musl.so +0 -0
  473. scipy/special/_spherical_bessel.py +4 -4
  474. scipy/special/_support_alternative_backends.py +212 -119
  475. scipy/special/_test_internal.cpython-313-aarch64-linux-musl.so +0 -0
  476. scipy/special/_testutils.py +4 -4
  477. scipy/special/_ufuncs.cpython-313-aarch64-linux-musl.so +0 -0
  478. scipy/special/_ufuncs.pyi +1 -0
  479. scipy/special/_ufuncs.pyx +215 -1400
  480. scipy/special/_ufuncs_cxx.cpython-313-aarch64-linux-musl.so +0 -0
  481. scipy/special/_ufuncs_cxx.pxd +2 -15
  482. scipy/special/_ufuncs_cxx.pyx +5 -44
  483. scipy/special/_ufuncs_cxx_defs.h +2 -16
  484. scipy/special/_ufuncs_defs.h +0 -8
  485. scipy/special/cython_special.cpython-313-aarch64-linux-musl.so +0 -0
  486. scipy/special/cython_special.pxd +1 -1
  487. scipy/special/tests/_cython_examples/meson.build +10 -1
  488. scipy/special/tests/test_basic.py +153 -20
  489. scipy/special/tests/test_boost_ufuncs.py +3 -0
  490. scipy/special/tests/test_cdflib.py +35 -11
  491. scipy/special/tests/test_gammainc.py +16 -0
  492. scipy/special/tests/test_hyp2f1.py +2 -2
  493. scipy/special/tests/test_log1mexp.py +85 -0
  494. scipy/special/tests/test_logsumexp.py +206 -64
  495. scipy/special/tests/test_mpmath.py +1 -0
  496. scipy/special/tests/test_nan_inputs.py +1 -1
  497. scipy/special/tests/test_orthogonal.py +17 -18
  498. scipy/special/tests/test_sf_error.py +3 -2
  499. scipy/special/tests/test_sph_harm.py +6 -7
  500. scipy/special/tests/test_support_alternative_backends.py +211 -76
  501. scipy/stats/__init__.py +4 -1
  502. scipy/stats/_ansari_swilk_statistics.cpython-313-aarch64-linux-musl.so +0 -0
  503. scipy/stats/_axis_nan_policy.py +5 -12
  504. scipy/stats/_biasedurn.cpython-313-aarch64-linux-musl.so +0 -0
  505. scipy/stats/_continued_fraction.py +387 -0
  506. scipy/stats/_continuous_distns.py +277 -310
  507. scipy/stats/_correlation.py +1 -1
  508. scipy/stats/_covariance.py +6 -3
  509. scipy/stats/_discrete_distns.py +39 -32
  510. scipy/stats/_distn_infrastructure.py +39 -12
  511. scipy/stats/_distribution_infrastructure.py +920 -238
  512. scipy/stats/_entropy.py +9 -10
  513. scipy/{_lib → stats}/_finite_differences.py +1 -1
  514. scipy/stats/_hypotests.py +83 -50
  515. scipy/stats/_kde.py +53 -49
  516. scipy/stats/_ksstats.py +1 -1
  517. scipy/stats/_levy_stable/__init__.py +7 -15
  518. scipy/stats/_levy_stable/levyst.cpython-313-aarch64-linux-musl.so +0 -0
  519. scipy/stats/_morestats.py +118 -73
  520. scipy/stats/_mstats_basic.py +13 -17
  521. scipy/stats/_mstats_extras.py +8 -8
  522. scipy/stats/_multivariate.py +89 -113
  523. scipy/stats/_new_distributions.py +97 -20
  524. scipy/stats/_page_trend_test.py +12 -5
  525. scipy/stats/_probability_distribution.py +265 -43
  526. scipy/stats/_qmc.py +14 -9
  527. scipy/stats/_qmc_cy.cpython-313-aarch64-linux-musl.so +0 -0
  528. scipy/stats/_qmvnt.py +16 -95
  529. scipy/stats/_qmvnt_cy.cpython-313-aarch64-linux-musl.so +0 -0
  530. scipy/stats/_quantile.py +335 -0
  531. scipy/stats/_rcont/rcont.cpython-313-aarch64-linux-musl.so +0 -0
  532. scipy/stats/_resampling.py +5 -30
  533. scipy/stats/_sampling.py +1 -1
  534. scipy/stats/_sobol.cpython-313-aarch64-linux-musl.so +0 -0
  535. scipy/stats/_stats.cpython-313-aarch64-linux-musl.so +0 -0
  536. scipy/stats/_stats_mstats_common.py +21 -2
  537. scipy/stats/_stats_py.py +551 -477
  538. scipy/stats/_stats_pythran.cpython-313-aarch64-linux-musl.so +0 -0
  539. scipy/stats/_unuran/unuran_wrapper.cpython-313-aarch64-linux-musl.so +0 -0
  540. scipy/stats/_unuran/unuran_wrapper.pyi +2 -1
  541. scipy/stats/_variation.py +6 -8
  542. scipy/stats/_wilcoxon.py +13 -7
  543. scipy/stats/tests/common_tests.py +6 -4
  544. scipy/stats/tests/test_axis_nan_policy.py +62 -24
  545. scipy/stats/tests/test_continued_fraction.py +173 -0
  546. scipy/stats/tests/test_continuous.py +379 -60
  547. scipy/stats/tests/test_continuous_basic.py +18 -12
  548. scipy/stats/tests/test_discrete_basic.py +14 -8
  549. scipy/stats/tests/test_discrete_distns.py +16 -16
  550. scipy/stats/tests/test_distributions.py +95 -75
  551. scipy/stats/tests/test_entropy.py +40 -48
  552. scipy/stats/tests/test_fit.py +4 -3
  553. scipy/stats/tests/test_hypotests.py +153 -24
  554. scipy/stats/tests/test_kdeoth.py +109 -41
  555. scipy/stats/tests/test_marray.py +289 -0
  556. scipy/stats/tests/test_morestats.py +81 -49
  557. scipy/stats/tests/test_mstats_basic.py +3 -3
  558. scipy/stats/tests/test_multivariate.py +434 -83
  559. scipy/stats/tests/test_qmc.py +13 -10
  560. scipy/stats/tests/test_quantile.py +199 -0
  561. scipy/stats/tests/test_rank.py +119 -112
  562. scipy/stats/tests/test_resampling.py +47 -56
  563. scipy/stats/tests/test_sampling.py +9 -4
  564. scipy/stats/tests/test_stats.py +799 -939
  565. scipy/stats/tests/test_variation.py +8 -6
  566. scipy/version.py +2 -2
  567. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/LICENSE.txt +4 -4
  568. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/METADATA +11 -11
  569. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/RECORD +1284 -1291
  570. scipy.libs/libgcc_s-2d945d6c.so.1 +0 -0
  571. scipy.libs/libgfortran-67378ab2.so.5.0.0 +0 -0
  572. scipy.libs/{libstdc++-1b614e01.so.6.0.32 → libstdc++-85f2cd6d.so.6.0.33} +0 -0
  573. scipy/_lib/array_api_extra/_funcs.py +0 -484
  574. scipy/_lib/array_api_extra/_typing.py +0 -8
  575. scipy/interpolate/_bspl.cpython-313-aarch64-linux-musl.so +0 -0
  576. scipy/optimize/_cobyla.cpython-313-aarch64-linux-musl.so +0 -0
  577. scipy/optimize/_cython_nnls.cpython-313-aarch64-linux-musl.so +0 -0
  578. scipy/optimize/_slsqp.cpython-313-aarch64-linux-musl.so +0 -0
  579. scipy/spatial/qhull_src/COPYING.txt +0 -38
  580. scipy/special/libsf_error_state.so +0 -0
  581. scipy/special/tests/test_log_softmax.py +0 -109
  582. scipy/special/tests/test_xsf_cuda.py +0 -114
  583. scipy/special/xsf/binom.h +0 -89
  584. scipy/special/xsf/cdflib.h +0 -100
  585. scipy/special/xsf/cephes/airy.h +0 -307
  586. scipy/special/xsf/cephes/besselpoly.h +0 -51
  587. scipy/special/xsf/cephes/beta.h +0 -257
  588. scipy/special/xsf/cephes/cbrt.h +0 -131
  589. scipy/special/xsf/cephes/chbevl.h +0 -85
  590. scipy/special/xsf/cephes/chdtr.h +0 -193
  591. scipy/special/xsf/cephes/const.h +0 -87
  592. scipy/special/xsf/cephes/ellie.h +0 -293
  593. scipy/special/xsf/cephes/ellik.h +0 -251
  594. scipy/special/xsf/cephes/ellpe.h +0 -107
  595. scipy/special/xsf/cephes/ellpk.h +0 -117
  596. scipy/special/xsf/cephes/expn.h +0 -260
  597. scipy/special/xsf/cephes/gamma.h +0 -398
  598. scipy/special/xsf/cephes/hyp2f1.h +0 -596
  599. scipy/special/xsf/cephes/hyperg.h +0 -361
  600. scipy/special/xsf/cephes/i0.h +0 -149
  601. scipy/special/xsf/cephes/i1.h +0 -158
  602. scipy/special/xsf/cephes/igam.h +0 -421
  603. scipy/special/xsf/cephes/igam_asymp_coeff.h +0 -195
  604. scipy/special/xsf/cephes/igami.h +0 -313
  605. scipy/special/xsf/cephes/j0.h +0 -225
  606. scipy/special/xsf/cephes/j1.h +0 -198
  607. scipy/special/xsf/cephes/jv.h +0 -715
  608. scipy/special/xsf/cephes/k0.h +0 -164
  609. scipy/special/xsf/cephes/k1.h +0 -163
  610. scipy/special/xsf/cephes/kn.h +0 -243
  611. scipy/special/xsf/cephes/lanczos.h +0 -112
  612. scipy/special/xsf/cephes/ndtr.h +0 -275
  613. scipy/special/xsf/cephes/poch.h +0 -85
  614. scipy/special/xsf/cephes/polevl.h +0 -167
  615. scipy/special/xsf/cephes/psi.h +0 -194
  616. scipy/special/xsf/cephes/rgamma.h +0 -111
  617. scipy/special/xsf/cephes/scipy_iv.h +0 -811
  618. scipy/special/xsf/cephes/shichi.h +0 -248
  619. scipy/special/xsf/cephes/sici.h +0 -224
  620. scipy/special/xsf/cephes/sindg.h +0 -221
  621. scipy/special/xsf/cephes/tandg.h +0 -139
  622. scipy/special/xsf/cephes/trig.h +0 -58
  623. scipy/special/xsf/cephes/unity.h +0 -186
  624. scipy/special/xsf/cephes/zeta.h +0 -172
  625. scipy/special/xsf/config.h +0 -304
  626. scipy/special/xsf/digamma.h +0 -205
  627. scipy/special/xsf/error.h +0 -57
  628. scipy/special/xsf/evalpoly.h +0 -47
  629. scipy/special/xsf/expint.h +0 -266
  630. scipy/special/xsf/hyp2f1.h +0 -694
  631. scipy/special/xsf/iv_ratio.h +0 -173
  632. scipy/special/xsf/lambertw.h +0 -150
  633. scipy/special/xsf/loggamma.h +0 -163
  634. scipy/special/xsf/sici.h +0 -200
  635. scipy/special/xsf/tools.h +0 -427
  636. scipy/special/xsf/trig.h +0 -164
  637. scipy/special/xsf/wright_bessel.h +0 -843
  638. scipy/special/xsf/zlog1.h +0 -35
  639. scipy/stats/_mvn.cpython-313-aarch64-linux-musl.so +0 -0
  640. scipy.libs/libgcc_s-7393e603.so.1 +0 -0
  641. scipy.libs/libgfortran-eb933d8e.so.5.0.0 +0 -0
  642. {scipy-1.15.3.dist-info → scipy-1.16.0.dist-info}/WHEEL +0 -0
@@ -1,17 +1,21 @@
1
1
  import math
2
2
 
3
3
  import numpy as np
4
- from numpy.testing import assert_allclose, assert_, assert_array_equal
5
- import pytest
4
+ from numpy.testing import assert_allclose, assert_array_almost_equal
6
5
 
7
- from scipy.optimize import fmin_cobyla, minimize, Bounds
6
+ from scipy.optimize import (
7
+ fmin_cobyla, minimize, Bounds, NonlinearConstraint, LinearConstraint,
8
+ OptimizeResult
9
+ )
8
10
 
9
11
 
10
12
  class TestCobyla:
11
13
  def setup_method(self):
12
- self.x0 = [4.95, 0.66]
14
+ # The algorithm is very fragile on 32 bit, so unfortunately we need to start
15
+ # very near the solution in order for the test to pass.
16
+ self.x0 = [np.sqrt(25 - (2.0/3)**2), 2.0/3 + 1e-4]
13
17
  self.solution = [math.sqrt(25 - (2.0/3)**2), 2.0/3]
14
- self.opts = {'disp': False, 'rhobeg': 1, 'tol': 1e-5,
18
+ self.opts = {'disp': 0, 'rhobeg': 1, 'tol': 1e-6,
15
19
  'maxiter': 100}
16
20
 
17
21
  def fun(self, x):
@@ -23,11 +27,10 @@ class TestCobyla:
23
27
  def con2(self, x):
24
28
  return -self.con1(x)
25
29
 
26
- @pytest.mark.xslow(True, reason='not slow, but noisy so only run rarely')
27
- def test_simple(self, capfd):
30
+ def test_simple(self):
28
31
  # use disp=True as smoke test for gh-8118
29
32
  x = fmin_cobyla(self.fun, self.x0, [self.con1, self.con2], rhobeg=1,
30
- rhoend=1e-5, maxfun=100, disp=True)
33
+ rhoend=1e-5, maxfun=100, disp=1)
31
34
  assert_allclose(x, self.solution, atol=1e-4)
32
35
 
33
36
  def test_minimize_simple(self):
@@ -40,54 +43,80 @@ class TestCobyla:
40
43
  self.n_calls += 1
41
44
  self.last_x = x
42
45
 
46
+ class CallbackNewSyntax:
47
+ def __init__(self):
48
+ self.n_calls = 0
49
+
50
+ def __call__(self, intermediate_result):
51
+ assert isinstance(intermediate_result, OptimizeResult)
52
+ self.n_calls += 1
53
+
43
54
  callback = Callback()
55
+ callback_new_syntax = CallbackNewSyntax()
44
56
 
45
57
  # Minimize with method='COBYLA'
46
- cons = ({'type': 'ineq', 'fun': self.con1},
58
+ cons = (NonlinearConstraint(self.con1, 0, np.inf),
47
59
  {'type': 'ineq', 'fun': self.con2})
48
60
  sol = minimize(self.fun, self.x0, method='cobyla', constraints=cons,
49
61
  callback=callback, options=self.opts)
62
+ sol_new = minimize(self.fun, self.x0, method='cobyla', constraints=cons,
63
+ callback=callback_new_syntax, options=self.opts)
50
64
  assert_allclose(sol.x, self.solution, atol=1e-4)
51
- assert_(sol.success, sol.message)
52
- assert_(sol.maxcv < 1e-5, sol)
53
- assert_(sol.nfev < 70, sol)
54
- assert_(sol.fun < self.fun(self.solution) + 1e-3, sol)
55
- assert_(sol.nfev == callback.n_calls,
56
- "Callback is not called exactly once for every function eval.")
57
- assert_array_equal(
65
+ assert sol.success, sol.message
66
+ assert sol.maxcv < 1e-5, sol
67
+ assert sol.nfev < 70, sol
68
+ assert sol.fun < self.fun(self.solution) + 1e-3, sol
69
+ assert_array_almost_equal(
58
70
  sol.x,
59
71
  callback.last_x,
60
- "Last design vector sent to the callback is not equal to returned value.",
72
+ decimal=5,
73
+ err_msg="Last design vector sent to the callback is not equal to"
74
+ " returned value.",
61
75
  )
76
+ assert sol_new.success, sol_new.message
77
+ assert sol.fun == sol_new.fun
78
+ assert sol.maxcv == sol_new.maxcv
79
+ assert sol.nfev == sol_new.nfev
80
+ assert callback.n_calls == callback_new_syntax.n_calls, \
81
+ "Callback is not called the same amount of times for old and new syntax."
62
82
 
63
83
  def test_minimize_constraint_violation(self):
64
- rng = np.random.RandomState(1234)
65
- pb = rng.rand(10, 10)
66
- spread = rng.rand(10)
67
-
68
- def p(w):
69
- return pb.dot(w)
70
-
71
- def f(w):
72
- return -(w * spread).sum()
73
-
74
- def c1(w):
75
- return 500 - abs(p(w)).sum()
76
-
77
- def c2(w):
78
- return 5 - abs(p(w).sum())
79
-
80
- def c3(w):
81
- return 5 - abs(p(w)).max()
82
-
83
- cons = ({'type': 'ineq', 'fun': c1},
84
- {'type': 'ineq', 'fun': c2},
85
- {'type': 'ineq', 'fun': c3})
86
- w0 = np.zeros((10,))
87
- sol = minimize(f, w0, method='cobyla', constraints=cons,
88
- options={'catol': 1e-6})
89
- assert_(sol.maxcv > 1e-6)
90
- assert_(not sol.success)
84
+ # We set up conflicting constraints so that the algorithm will be
85
+ # guaranteed to end up with maxcv > 0.
86
+ cons = ({'type': 'ineq', 'fun': lambda x: 4 - x},
87
+ {'type': 'ineq', 'fun': lambda x: x - 5})
88
+ sol = minimize(lambda x: x, [0], method='cobyla', constraints=cons,
89
+ options={'catol': 0.6})
90
+ assert sol.maxcv > 0.1
91
+ assert sol.success
92
+ sol = minimize(lambda x: x, [0], method='cobyla', constraints=cons,
93
+ options={'catol': 0.4})
94
+ assert sol.maxcv > 0.1
95
+ assert not sol.success
96
+
97
+ def test_f_target(self):
98
+ f_target = 250
99
+ sol = minimize(lambda x: x**2, [500], method='cobyla',
100
+ options={'f_target': f_target})
101
+ assert sol.status == 1
102
+ assert sol.success
103
+ assert sol.fun <= f_target
104
+
105
+ def test_minimize_linear_constraints(self):
106
+ constraints = LinearConstraint([1.0, 1.0], 1.0, 1.0)
107
+ sol = minimize(
108
+ self.fun,
109
+ self.x0,
110
+ method='cobyla',
111
+ constraints=constraints,
112
+ options=self.opts,
113
+ )
114
+ solution = [(4 - np.sqrt(7)) / 3, (np.sqrt(7) - 1) / 3]
115
+ assert_allclose(sol.x, solution, atol=1e-4)
116
+ assert sol.success, sol.message
117
+ assert sol.maxcv < 1e-8, sol
118
+ assert sol.nfev <= 100, sol
119
+ assert sol.fun < self.fun(solution) + 1e-3, sol
91
120
 
92
121
 
93
122
  def test_vector_constraints():
@@ -124,7 +153,7 @@ def test_vector_constraints():
124
153
  constraints = [{'type': 'ineq', 'fun': cons} for cons in cons_list]
125
154
  sol = minimize(fun, x0, constraints=constraints, tol=1e-5)
126
155
  assert_allclose(sol.x, xsol, atol=1e-4)
127
- assert_(sol.success, sol.message)
156
+ assert sol.success, sol.message
128
157
  assert_allclose(sol.fun, fsol, atol=1e-4)
129
158
 
130
159
  constraints = {'type': 'ineq', 'fun': fmin}
@@ -97,7 +97,7 @@ def test_prepare_constraint_infeasible_x0():
97
97
  return A
98
98
 
99
99
  def hess(x, v):
100
- return sps.csr_matrix((4, 4))
100
+ return sps.csr_array((4, 4))
101
101
 
102
102
  nonlinear = NonlinearConstraint(fun, -np.inf, 0, jac, hess,
103
103
  enforce_feasibility)
@@ -5,7 +5,8 @@ from numpy.testing import (TestCase, assert_array_almost_equal,
5
5
  assert_array_equal, assert_, assert_allclose,
6
6
  assert_equal)
7
7
  from scipy._lib._gcutils import assert_deallocated
8
- from scipy.sparse import csr_matrix
8
+ from scipy._lib._util import MapWrapper
9
+ from scipy.sparse import csr_array
9
10
  from scipy.sparse.linalg import LinearOperator
10
11
  from scipy.optimize._differentiable_functions import (ScalarFunction,
11
12
  VectorFunction,
@@ -130,6 +131,67 @@ class TestScalarFunction(TestCase):
130
131
  assert_array_almost_equal(f_analit, f_approx)
131
132
  assert_array_almost_equal(g_analit, g_approx)
132
133
 
134
+ @pytest.mark.fail_slow(5.0)
135
+ def test_workers(self):
136
+ x0 = np.array([2.0, 0.3])
137
+ ex = ExScalarFunction()
138
+ ex2 = ExScalarFunction()
139
+ with MapWrapper(2) as mapper:
140
+ approx = ScalarFunction(ex.fun, x0, (), '2-point',
141
+ ex.hess, None, (-np.inf, np.inf),
142
+ workers=mapper)
143
+ approx_series = ScalarFunction(ex2.fun, x0, (), '2-point',
144
+ ex2.hess, None, (-np.inf, np.inf),
145
+ )
146
+ assert_allclose(approx.grad(x0), ex.grad(x0))
147
+ assert_allclose(approx_series.grad(x0), ex.grad(x0))
148
+ assert_allclose(approx_series.hess(x0), ex.hess(x0))
149
+ assert_allclose(approx.hess(x0), ex.hess(x0))
150
+ assert_equal(approx.nfev, approx_series.nfev)
151
+ assert_equal(approx_series.nfev, ex2.nfev)
152
+ assert_equal(approx.ngev, approx_series.ngev)
153
+ assert_equal(approx.nhev, approx_series.nhev)
154
+ assert_equal(approx_series.nhev, ex2.nhev)
155
+
156
+ ex = ExScalarFunction()
157
+ ex2 = ExScalarFunction()
158
+ approx = ScalarFunction(ex.fun, x0, (), '3-point',
159
+ ex.hess, None, (-np.inf, np.inf),
160
+ workers=mapper)
161
+ approx_series = ScalarFunction(ex2.fun, x0, (), '3-point',
162
+ ex2.hess, None, (-np.inf, np.inf),
163
+ )
164
+ assert_allclose(approx.grad(x0), ex.grad(x0))
165
+ assert_allclose(approx_series.grad(x0), ex.grad(x0))
166
+ assert_allclose(approx_series.hess(x0), ex.hess(x0))
167
+ assert_allclose(approx.hess(x0), ex.hess(x0))
168
+ assert_equal(approx.nfev, approx_series.nfev)
169
+ assert_equal(approx_series.nfev, ex2.nfev)
170
+ assert_equal(approx.ngev, approx_series.ngev)
171
+ assert_equal(approx.nhev, approx_series.nhev)
172
+ assert_equal(approx_series.nhev, ex2.nhev)
173
+
174
+ ex = ExScalarFunction()
175
+ ex2 = ExScalarFunction()
176
+ x1 = np.array([3.0, 4.0])
177
+
178
+ approx = ScalarFunction(ex.fun, x0, (), ex.grad,
179
+ '3-point', None, (-np.inf, np.inf),
180
+ workers=mapper)
181
+ approx_series = ScalarFunction(ex2.fun, x0, (), ex2.grad,
182
+ '3-point', None, (-np.inf, np.inf),
183
+ )
184
+ assert_allclose(approx.grad(x1), ex.grad(x1))
185
+ assert_allclose(approx_series.grad(x1), ex.grad(x1))
186
+ approx_series.hess(x1)
187
+ approx.hess(x1)
188
+ assert_equal(approx.nfev, approx_series.nfev)
189
+ assert_equal(approx_series.nfev, ex2.nfev)
190
+ assert_equal(approx.ngev, approx_series.ngev)
191
+ assert_equal(approx_series.ngev, ex2.ngev)
192
+ assert_equal(approx.nhev, approx_series.nhev)
193
+ assert_equal(approx_series.nhev, ex2.nhev)
194
+
133
195
  def test_fun_and_grad(self):
134
196
  ex = ExScalarFunction()
135
197
 
@@ -419,8 +481,9 @@ class TestVectorialFunction(TestCase):
419
481
  assert_array_equal(analit.nfev, nfev)
420
482
  assert_array_equal(ex.njev, njev)
421
483
  assert_array_equal(analit.njev, njev)
422
- approx = VectorFunction(ex.fun, x0, '2-point', ex.hess, None, None,
423
- (-np.inf, np.inf), None)
484
+ # create with defaults for the keyword arguments, to
485
+ # ensure that the defaults work
486
+ approx = VectorFunction(ex.fun, x0, '2-point', ex.hess)
424
487
  nfev += 3
425
488
  assert_array_equal(ex.nfev, nfev)
426
489
  assert_array_equal(analit.nfev+approx.nfev, nfev)
@@ -501,6 +564,94 @@ class TestVectorialFunction(TestCase):
501
564
  assert_array_almost_equal(f_analit, f_approx)
502
565
  assert_array_almost_equal(J_analit, J_approx)
503
566
 
567
+ def test_updating_on_initial_setup(self):
568
+ # Check that memoisation works with the freshly created VectorFunction
569
+ # On initialization vf.f_updated attribute wasn't being set correctly.
570
+ x0 = np.array([2.5, 3.0])
571
+ ex = ExVectorialFunction()
572
+ vf = VectorFunction(ex.fun, x0, ex.jac, ex.hess)
573
+ assert vf.f_updated
574
+ assert vf.nfev == 1
575
+ assert vf.njev == 1
576
+ assert ex.nfev == 1
577
+ assert ex.njev == 1
578
+ vf.fun(x0)
579
+ vf.jac(x0)
580
+ assert vf.nfev == 1
581
+ assert vf.njev == 1
582
+ assert ex.nfev == 1
583
+ assert ex.njev == 1
584
+
585
+ @pytest.mark.fail_slow(5.0)
586
+ def test_workers(self):
587
+ x0 = np.array([2.5, 3.0])
588
+ ex = ExVectorialFunction()
589
+ ex2 = ExVectorialFunction()
590
+ v = np.array([1.0, 2.0])
591
+
592
+ with MapWrapper(2) as mapper:
593
+ approx = VectorFunction(ex.fun, x0, '2-point',
594
+ ex.hess, None, None, (-np.inf, np.inf),
595
+ False, workers=mapper)
596
+ approx_series = VectorFunction(ex2.fun, x0, '2-point',
597
+ ex2.hess, None, None, (-np.inf, np.inf),
598
+ False)
599
+
600
+ assert_allclose(approx.jac(x0), ex.jac(x0))
601
+ assert_allclose(approx_series.jac(x0), ex.jac(x0))
602
+ assert_allclose(approx_series.hess(x0, v), ex.hess(x0, v))
603
+ assert_allclose(approx.hess(x0, v), ex.hess(x0, v))
604
+ assert_equal(approx.nfev, approx_series.nfev)
605
+ assert_equal(approx_series.nfev, ex2.nfev)
606
+ assert_equal(approx.njev, approx_series.njev)
607
+ assert_equal(approx.nhev, approx_series.nhev)
608
+ assert_equal(approx_series.nhev, ex2.nhev)
609
+
610
+ ex.nfev = ex.njev = ex.nhev = 0
611
+ ex2.nfev = ex2.njev = ex2.nhev = 0
612
+ approx = VectorFunction(ex.fun, x0, '3-point',
613
+ ex.hess, None, None, (-np.inf, np.inf),
614
+ False, workers=mapper)
615
+ approx_series = VectorFunction(ex2.fun, x0, '3-point',
616
+ ex2.hess, None, None, (-np.inf, np.inf),
617
+ False)
618
+ assert_allclose(approx.jac(x0), ex.jac(x0))
619
+ assert_allclose(approx_series.jac(x0), ex.jac(x0))
620
+ assert_allclose(approx_series.hess(x0, v), ex.hess(x0, v))
621
+ assert_allclose(approx.hess(x0, v), ex.hess(x0, v))
622
+
623
+ assert_equal(approx.nfev, approx_series.nfev)
624
+ assert_equal(approx_series.nfev, ex2.nfev)
625
+ assert_equal(approx.njev, approx_series.njev)
626
+ assert_equal(approx.nhev, approx_series.nhev)
627
+ assert_equal(approx_series.nhev, ex2.nhev)
628
+
629
+ # The following tests are somewhat redundant because the LinearOperator
630
+ # produced by VectorFunction.hess does not use any parallelisation.
631
+ # The tests are left for completeness, in case that situation changes.
632
+ ex.nfev = ex.njev = ex.nhev = 0
633
+ ex2.nfev = ex2.njev = ex2.nhev = 0
634
+ approx = VectorFunction(ex.fun, x0, ex.jac,
635
+ '2-point', None, None, (-np.inf, np.inf),
636
+ False, workers=mapper)
637
+ approx_series = VectorFunction(ex2.fun, x0, ex2.jac,
638
+ '2-point', None, None, (-np.inf, np.inf),
639
+ False)
640
+ assert_allclose(approx.jac(x0), ex.jac(x0))
641
+ assert_allclose(approx_series.jac(x0), ex.jac(x0))
642
+
643
+ H_analit = ex2.hess(x0, v)
644
+ H_approx_series = approx_series.hess(x0, v)
645
+ H_approx = approx.hess(x0, v)
646
+ x = [5, 2.0]
647
+ assert_allclose(H_approx.dot(x), H_analit.dot(x))
648
+ assert_allclose(H_approx_series.dot(x), H_analit.dot(x))
649
+
650
+ assert_equal(approx.nfev, approx_series.nfev)
651
+ assert_equal(approx_series.nfev, ex2.nfev)
652
+ assert_equal(approx.njev, approx_series.njev)
653
+ assert_equal(approx.nhev, approx_series.nhev)
654
+
504
655
  def test_finite_difference_hess_linear_operator(self):
505
656
  ex = ExVectorialFunction()
506
657
  nfev = 0
@@ -629,6 +780,38 @@ class TestVectorialFunction(TestCase):
629
780
  assert_array_equal(ex.nhev, nhev)
630
781
  assert_array_equal(analit.nhev+approx.nhev, nhev)
631
782
 
783
+ # Test VectorFunction.hess_wrapped with J0=None
784
+ x = np.array([1.5, 0.5])
785
+ v = np.array([1.0, 2.0])
786
+ njev_before = approx.hess_wrapped.njev
787
+ H = approx.hess_wrapped(x, v, J0=None)
788
+ assert isinstance(H, LinearOperator)
789
+ # The njev counter should be incremented by exactly 1
790
+ assert approx.hess_wrapped.njev == njev_before + 1
791
+
792
+ def test_fgh_overlap(self):
793
+ # VectorFunction.fun/jac should return copies to internal attributes
794
+ ex = ExVectorialFunction()
795
+ x0 = np.array([1.0, 0.0])
796
+
797
+ vf = VectorFunction(ex.fun, x0, '3-point', ex.hess, None, None,
798
+ (-np.inf, np.inf), None)
799
+ f = vf.fun(np.array([1.1, 0.1]))
800
+ J = vf.jac([1.1, 0.1])
801
+ assert vf.f is not f
802
+ assert vf.J is not J
803
+ assert_equal(f, vf.f)
804
+ assert_equal(J, vf.J)
805
+
806
+ vf = VectorFunction(ex.fun, x0, ex.jac, ex.hess, None, None,
807
+ (-np.inf, np.inf), None)
808
+ f = vf.fun(np.array([1.1, 0.1]))
809
+ J = vf.jac([1.1, 0.1])
810
+ assert vf.f is not f
811
+ assert vf.J is not J
812
+ assert_equal(f, vf.f)
813
+ assert_equal(J, vf.J)
814
+
632
815
  @pytest.mark.thread_unsafe
633
816
  def test_x_storage_overlap(self):
634
817
  # VectorFunction should not store references to arrays, it should
@@ -686,6 +869,44 @@ class TestVectorialFunction(TestCase):
686
869
  res = vf.jac(x0)
687
870
  assert res.dtype == np.float32
688
871
 
872
+ def test_sparse_analytic_jac(self):
873
+ ex = ExVectorialFunction()
874
+ x0 = np.array([1.0, 0.0])
875
+ def sparse_adapter(func):
876
+ def inner(x):
877
+ f_x = func(x)
878
+ return csr_array(f_x)
879
+ return inner
880
+
881
+ # jac(x) returns dense jacobian
882
+ vf1 = VectorFunction(ex.fun, x0, ex.jac, ex.hess, None, None,
883
+ (-np.inf, np.inf), sparse_jacobian=None)
884
+ # jac(x) returns sparse jacobian, but sparse_jacobian=False requests dense
885
+ vf2 = VectorFunction(ex.fun, x0, sparse_adapter(ex.jac), ex.hess, None, None,
886
+ (-np.inf, np.inf), sparse_jacobian=False)
887
+
888
+ res1 = vf1.jac(x0 + 1)
889
+ res2 = vf2.jac(x0 + 1)
890
+ assert_equal(res1, res2)
891
+
892
+ def test_sparse_numerical_jac(self):
893
+ ex = ExVectorialFunction()
894
+ x0 = np.array([1.0, 0.0])
895
+ N = len(x0)
896
+
897
+ # normal dense numerical difference
898
+ vf1 = VectorFunction(ex.fun, x0, '2-point', ex.hess, None, None,
899
+ (-np.inf, np.inf), sparse_jacobian=None)
900
+ # use sparse numerical difference, but ask it to be converted to dense
901
+ finite_diff_jac_sparsity = csr_array(np.ones((N, N)))
902
+ vf2 = VectorFunction(ex.fun, x0, '2-point', ex.hess, None,
903
+ finite_diff_jac_sparsity, (-np.inf, np.inf),
904
+ sparse_jacobian=False)
905
+
906
+ res1 = vf1.jac(x0 + 1)
907
+ res2 = vf2.jac(x0 + 1)
908
+ assert_equal(res1, res2)
909
+
689
910
 
690
911
  def test_LinearVectorFunction():
691
912
  A_dense = np.array([
@@ -693,7 +914,7 @@ def test_LinearVectorFunction():
693
914
  [0, 4, 2]
694
915
  ])
695
916
  x0 = np.zeros(3)
696
- A_sparse = csr_matrix(A_dense)
917
+ A_sparse = csr_array(A_dense)
697
918
  x = np.array([1, -1, 0])
698
919
  v = np.array([-1, 1])
699
920
  Ax = np.array([-3, -4])
@@ -779,7 +1000,6 @@ def test_ScalarFunctionNoReferenceCycle():
779
1000
  platform.python_implementation() == "PyPy",
780
1001
  reason="assert_deallocate not available on PyPy"
781
1002
  )
782
- @pytest.mark.xfail(reason="TODO remove reference cycle from VectorFunction")
783
1003
  def test_VectorFunctionNoReferenceCycle():
784
1004
  """Regression test for gh-20768."""
785
1005
  ex = ExVectorialFunction()
@@ -800,6 +1020,6 @@ def test_LinearVectorFunctionNoReferenceCycle():
800
1020
  [0, 4, 2]
801
1021
  ])
802
1022
  x0 = np.zeros(3)
803
- A_sparse = csr_matrix(A_dense)
1023
+ A_sparse = csr_array(A_dense)
804
1024
  with assert_deallocated(lambda: LinearVectorFunction(A_sparse, x0, None)):
805
1025
  pass
@@ -41,3 +41,25 @@ def test_2():
41
41
  assert_allclose(H1, result2.hess_inv, rtol=1e-2, atol=0.03)
42
42
 
43
43
 
44
+ def test_3():
45
+
46
+ def todense_old_impl(self):
47
+ s, y, n_corrs, rho = self.sk, self.yk, self.n_corrs, self.rho
48
+ I_arr = np.eye(*self.shape, dtype=self.dtype)
49
+ Hk = I_arr
50
+
51
+ for i in range(n_corrs):
52
+ A1 = I_arr - s[i][:, np.newaxis] * y[i][np.newaxis, :] * rho[i]
53
+ A2 = I_arr - y[i][:, np.newaxis] * s[i][np.newaxis, :] * rho[i]
54
+
55
+ Hk = np.dot(A1, np.dot(Hk, A2)) + (rho[i] * s[i][:, np.newaxis] *
56
+ s[i][np.newaxis, :])
57
+ return Hk
58
+
59
+ H0 = [[3, 0], [1, 2]]
60
+
61
+ def f(x):
62
+ return np.dot(x, np.dot(scipy.linalg.inv(H0), x))
63
+
64
+ result1 = minimize(fun=f, method='L-BFGS-B', x0=[10, 20])
65
+ assert_allclose(result1.hess_inv.todense(), todense_old_impl(result1.hess_inv))