Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
==1.10.0
->==1.15.1
Release Notes
scipy/scipy (scipy)
v1.15.1
: SciPy 1.15.1Compare Source
SciPy 1.15.1 Release Notes
SciPy
1.15.1
is a bug-fix release with no new featurescompared to
1.15.0
. Importantly, an issue with theimport of
scipy.optimize
breaking other packageshas been fixed.
Authors
A total of 5 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.15.0
: SciPy 1.15.0Compare Source
SciPy 1.15.0 Release Notes
SciPy
1.15.0
is the culmination of6
months of hard work. It containsmany new features, numerous bug-fixes, improved test coverage and better
documentation. There have been a number of deprecations and API changes
in this release, which are documented below. All users are encouraged to
upgrade to this release, as there are a large number of bug-fixes and
optimizations. Before upgrading, we recommend that users check that
their own code does not use deprecated SciPy functionality (to do so,
run your code with
python -Wd
and check forDeprecationWarning
s).Our development attention will now shift to bug-fix releases on the
1.15.x branch, and on adding new features on the main branch.
This release requires Python
3.10-3.13
and NumPy1.23.5
or greater.Highlights of this release
Sparse arrays are now fully functional for 1-D and 2-D arrays. We recommend
that all new code use sparse arrays instead of sparse matrices and that
developers start to migrate their existing code from sparse matrix to sparse
array:
migration_to_sparray
. Bothsparse.linalg
andsparse.csgraph
work with either sparse matrix or sparse array and work internally with
sparse array.
Sparse arrays now provide basic support for n-D arrays in the COO format
including
add
,subtract
,reshape
,transpose
,matmul
,dot
,tensordot
and others. More functionality is coming in futurereleases.
Preliminary support for free-threaded Python 3.13.
New probability distribution features in
scipy.stats
can be used to improvethe speed and accuracy of existing continuous distributions and perform new
probability calculations.
Several new features support vectorized calculations with Python Array API
Standard compatible input (see "Array API Standard Support" below):
scipy.differentiate
is a new top-level submodule for accurateestimation of derivatives of black box functions.
scipy.optimize.elementwise
contains new functions for root-finding andminimization of univariate functions.
scipy.integrate
offers new functionscubature
,tanhsinh
, andnsum
for multivariate integration, univariate integration, andunivariate series summation, respectively.
scipy.interpolate.AAA
adds the AAA algorithm for barycentric rationalapproximation of real or complex functions.
scipy.special
adds new functions offering improved Legendre functionimplementations with a more consistent interface.
New features
scipy.differentiate
introductionThe new
scipy.differentiate
sub-package contains functions for accurateestimation of derivatives of black box functions.
scipy.differentiate.derivative
for first-order derivatives ofscalar-in, scalar-out functions.
scipy.differentiate.jacobian
for first-order partial derivatives ofvector-in, vector-out functions.
scipy.differentiate.hessian
for second-order partial derivatives ofvector-in, scalar-out functions.
All functions use high-order finite difference rules with adaptive (real)
step size. To facilitate batch computation, these functions are vectorized
and support several Array API compatible array libraries in addition to NumPy
(see "Array API Standard Support" below).
scipy.integrate
improvementsscipy.integrate.cubature
function supports multidimensionalintegration, and has support for approximating integrals with
one or more sets of infinite limits.
scipy.integrate.tanhsinh
is now exposed for public use, allowingevaluation of a convergent integral using tanh-sinh quadrature.
scipy.integrate.nsum
evaluates finite and infinite series and theirlogarithms.
scipy.integrate.lebedev_rule
computes abscissae and weights forintegration over the surface of a sphere.
QUADPACK
Fortran77 package has been ported to C.scipy.interpolate
improvementsscipy.interpolate.AAA
adds the AAA algorithm for barycentric rationalapproximation of real or complex functions.
scipy.interpolate.FloaterHormannInterpolator
adds barycentric rationalinterpolation.
scipy.interpolate.make_splrep
andscipy.interpolate.make_splprep
implement construction of smoothing splines.The algorithmic content is equivalent to FITPACK (
splrep
andsplprep
functions, and
*UnivariateSpline
classes) and the user API is consistentwith
make_interp_spline
: these functions receive data arrays and returna
scipy.interpolate.BSpline
instance.scipy.interpolate.generate_knots
implements theFITPACK strategy for selecting knots of a smoothing spline given the
smoothness parameter,
s
. The function exposes the internal logic of knotselection that
splrep
and*UnivariateSpline
was using.scipy.linalg
improvementsscipy.linalg.interpolative
Fortran77 code has been ported to Cython.scipy.linalg.solve
supports several new values for theassume_a
argument, enabling faster computation for diagonal, tri-diagonal, banded, and
triangular matrices. Also, when
assume_a
is left unspecified, thefunction now automatically detects and exploits diagonal, tri-diagonal,
and triangular structures.
scipy.linalg
matrix creation functions (scipy.linalg.circulant
,scipy.linalg.companion
,scipy.linalg.convolution_matrix
,scipy.linalg.fiedler
,scipy.linalg.fiedler_companion
, andscipy.linalg.leslie
) now support batchmatrix creation.
scipy.linalg.funm
is faster.scipy.linalg.orthogonal_procrustes
now supports complex input.scipy.linalg.lapack
:?lantr
,?sytrs
,?hetrs
,?trcon
,and
?gtcon
.scipy.linalg.expm
was rewritten in C.scipy.linalg.null_space
now accepts the new argumentsoverwrite_a
,check_finite
, andlapack_driver
.id_dist
Fortran code was rewritten in Cython.scipy.ndimage
improvementsaxes
argumentthat specifies which axes of the input filtering is to be performed on.
These include
correlate
,convolve
,generic_laplace
,laplace
,gaussian_laplace
,derivative2
,generic_gradient_magnitude
,gaussian_gradient_magnitude
andgeneric_filter
.axes
argument that specifies which axes of the input filtering is to be performed
on.
scipy.ndimage.rank_filter
time complexity has improved fromn
tolog(n)
.scipy.optimize
improvements1.4.0
to1.8.0
,bringing accuracy and performance improvements to solvers.
MINPACK
Fortran77 package has been ported to C.L-BFGS-B
Fortran77 package has been ported to C.scipy.optimize.elementwise
namespace includes functionsbracket_root
,find_root
,bracket_minimum
, andfind_minimum
for root-finding and minimization of univariate functions. To facilitate
batch computation, these functions are vectorized and support several
Array API compatible array libraries in addition to NumPy (see
"Array API Standard Support" below). Compared to existing functions (e.g.
scipy.optimize.root_scalar
andscipy.optimize.minimize_scalar
),these functions can offer speedups of over 100x when used with NumPy arrays,
and even greater gains are possible with other Array API Standard compatible
array libraries (e.g. CuPy).
scipy.optimize.differential_evolution
now supports more general use ofworkers
, such as passing a map-like callable.scipy.optimize.nnls
was rewritten in Cython.HessianUpdateStrategy
now supports__matmul__
.scipy.signal
improvementssignal.chirp()
.scipy.signal.lombscargle
has two new arguments,weights
andfloating_mean
, enabling sample weighting and removal of an unknowny-offset independently for each frequency. Additionally, the
normalize
argument includes a new option to return the complex representation of the
amplitude and phase.
scipy.signal.envelope
for computation of the envelope of areal or complex valued signal.
scipy.sparse
improvementsmoving from sparse.matrix to sparse.array in your code/library.
arrays are now fully functional for 1-D and 2D.
for basic arithmetic.
sparse.linalg.is_sptriangular
andsparse.linalg.spbandwidth
mimic the existing dense toolslinalg.is_triangular
andlinalg.bandwidth
.sparse.linalg
andsparse.csgraph
now work with sparse arrays. Becareful that your index arrays are 32-bit. We are working on 64bit support.
ARPACK
library has been upgraded to version3.9.1
.axis
argument forcount_nonzero
.incompatible data types, such as
float16
.min
,max
,argmin
, andargmax
now support computationover nonzero elements only via the new
explicit
argument.get_index_dtype
andsafely_cast_index_arrays
areavailable to facilitate index array casting in
sparse
.scipy.spatial
improvementsRotation.concatenate
now accepts a bareRotation
object, and willreturn a copy of it.
scipy.special
improvementsNew functions offering improved Legendre function implementations with a
more consistent interface. See respective docstrings for more information.
scipy.special.legendre_p
,scipy.special.legendre_p_all
scipy.special.assoc_legendre_p
,scipy.special.assoc_legendre_p_all
scipy.special.sph_harm_y
,scipy.special.sph_harm_y_all
scipy.special.sph_legendre_p
,scipy.special.sph_legendre_p_all
,The factorial functions
special.{factorial,factorial2,factorialk}
nowoffer an extension to the complex domain by passing the kwarg
extend='complex'
. This is opt-in because it changes the values fornegative inputs (which by default return 0), as well as for some integers
(in the case of
factorial2
andfactorialk
; for more details,check the respective docstrings).
scipy.special.zeta
now defines the Riemann zeta function on the complexplane.
scipy.special.softplus
computes the softplus functionThe spherical Bessel functions (
scipy.special.spherical_jn
,scipy.special.spherical_yn
,scipy.special.spherical_in
, andscipy.special.spherical_kn
) now support negative arguments with real dtype.scipy.special.logsumexp
now preserves precision when one element of thesum has magnitude much bigger than the rest.
The accuracy of several functions has been improved:
scipy.special.ncfdtr
,scipy.special.nctdtr
, andscipy.special.gdtrib
have been improved throughout the domain.scipy.special.hyperu
is improved for the case ofb=1
, smallx
,and small
a
.scipy.special.logit
is improved near the argumentp=0.5
.scipy.special.rel_entr
is improved whenx/y
overflows, underflows,or is close to
1
.scipy.special.ndtr
is now more efficient forsqrt(2)/2 < |x| < 1
.scipy.stats
improvementsA new probability distribution infrastructure has been added for the
implementation of univariate, continuous distributions. It has several
speed, accuracy, memory, and interface advantages compared to the
previous infrastructure. See
rv_infrastructure
for a tutorial.scipy.stats.make_distribution
to treat an existing continuousdistribution (e.g.
scipy.stats.norm
) with the new infrastructure.This can improve the speed and accuracy of existing distributions,
especially those with methods not overridden with distribution-specific
formulas.
scipy.stats.Normal
andscipy.stats.Uniform
are pre-defined classesto represent the normal and uniform distributions, respectively.
Their interfaces may be faster and more convenient than those produced by
make_distribution
.scipy.stats.Mixture
can be used to represent mixture distributions.Instances of
scipy.stats.Normal
,scipy.stats.Uniform
, and the classesreturned by
scipy.stats.make_distribution
are supported by several newmathematical transformations.
scipy.stats.truncate
for truncation of the support.scipy.stats.order_statistic
for the order statistics of a given numberof IID random variables.
scipy.stats.abs
,scipy.stats.exp
, andscipy.stats.log
. For example,scipy.stats.abs(Normal())
is distributed according to the folded normaland
scipy.stats.exp(Normal())
is lognormally distributed.The new
scipy.stats.lmoment
calculates sample l-moments and l-momentratios. Notably, these sample estimators are unbiased.
scipy.stats.chatterjeexi
computes the Xi correlation coefficient, whichcan detect nonlinear dependence. The function also performs a hypothesis
test of independence between samples.
scipy.stats.wilcoxon
has improved method resolution logic for the defaultmethod='auto'
. Other values ofmethod
provided by the user are nowrespected in all cases, and the method argument
approx
has beenrenamed to
asymptotic
for consistency with similar functions. (Use ofapprox
is still allowed for backward compatibility.)There are several new probability distributions:
scipy.stats.dpareto_lognorm
represents the double Pareto lognormaldistribution.
scipy.stats.landau
represents the Landau distribution.scipy.stats.normal_inverse_gamma
represents the normal-inverse-gammadistribution.
scipy.stats.poisson_binom
represents the Poisson binomial distribution.Batch calculation with
scipy.stats.alexandergovern
andscipy.stats.combine_pvalues
is faster.scipy.stats.chisquare
added an argumentsum_check
. By default, thefunction raises an error when the sum of expected and obseved frequencies
are not equal; setting
sum_check=False
disables this check tofacilitate hypothesis tests other than Pearson's chi-squared test.
The accuracy of several distribution methods has been improved, including:
scipy.stats.nct
methodpdf
scipy.stats.crystalball
methodsf
scipy.stats.geom
methodrvs
scipy.stats.cauchy
methodslogpdf
,pdf
,ppf
andisf
logcdf
and/orlogsf
methods of distributions that do notoverride the generic implementation of these methods, including
scipy.stats.beta
,scipy.stats.betaprime
,scipy.stats.cauchy
,scipy.stats.chi
,scipy.stats.chi2
,scipy.stats.exponweib
,scipy.stats.gamma
,scipy.stats.gompertz
,scipy.stats.halflogistic
,scipy.stats.hypsecant
,scipy.stats.invgamma
,scipy.stats.laplace
,scipy.stats.levy
,scipy.stats.loggamma
,scipy.stats.maxwell
,scipy.stats.nakagami
, andscipy.stats.t
.scipy.stats.qmc.PoissonDisk
now accepts lower and upper boundsparameters
l_bounds
andu_bounds
.scipy.stats.fisher_exact
now supports two-dimensional tables with shapesother than
(2, 2)
.Preliminary Support for Free-Threaded CPython 3.13
SciPy
1.15
has preliminary support for the free-threaded build of CPython3.13.
This allows SciPy functionality to execute in parallel with Pythonthreads
(see the
threading
stdlib module). This support was enabled by fixing asignificant number of thread-safety issues in both pure Python and
C/C++/Cython/Fortran extension modules. Wheels are provided on PyPI for this
release; NumPy
>=2.1.3
is required at runtime. Note that building for afree-threaded interpreter requires a recent pre-release or nightly for Cython
3.1.0
.Support for free-threaded Python does not mean that SciPy is fully thread-safe.
Please see
scipy_thread_safety
for more details.If you are interested in free-threaded Python, for example because you have a
multiprocessing-based workflow that you are interested in running with Python
threads, we encourage testing and experimentation. If you run into problems
that you suspect are because of SciPy, please open an issue, checking first if
the bug also occurs in the "regular" non-free-threaded CPython
3.13
build.Many threading bugs can also occur in code that releases the GIL; disabling
the GIL only makes it easier to hit threading bugs.
Array API Standard Support
Experimental support for array libraries other than NumPy has been added to
existing sub-packages in recent versions of SciPy. Please consider testing
these features by setting an environment variable
SCIPY_ARRAY_API=1
andproviding PyTorch, JAX, ndonnx, or CuPy arrays as array arguments. Features
with support added for SciPy
1.15.0
include:scipy.differentiate
(new sub-package)scipy.optimize.elementwise
(new namespace)scipy.optimize.rosen
,scipy.optimize.rosen_der
, andscipy.optimize.rosen_hess
scipy.special.logsumexp
scipy.integrate.trapezoid
scipy.integrate.tanhsinh
(newly public function)scipy.integrate.cubature
(new function)scipy.integrate.nsum
(new function)scipy.special.chdtr
,scipy.special.betainc
, andscipy.special.betaincc
scipy.stats.boxcox_llf
scipy.stats.differential_entropy
scipy.stats.zmap
,scipy.stats.zscore
, andscipy.stats.gzscore
scipy.stats.tmean
,scipy.stats.tvar
,scipy.stats.tstd
,scipy.stats.tsem
,scipy.stats.tmin
, andscipy.stats.tmax
scipy.stats.gmean
,scipy.stats.hmean
andscipy.stats.pmean
scipy.stats.combine_pvalues
scipy.stats.ttest_ind
,scipy.stats.ttest_rel
scipy.stats.directional_stats
scipy.ndimage
functions will now delegate tocupyx.scipy.ndimage
,and for other backends will transit via NumPy arrays on the host.
Deprecated features and future changes
scipy.linalg.interpolative.rand
andscipy.linalg.interpolative.seed
have been deprecated and will be removedin SciPy
1.17.0
.scipy.spatial.distance.cosine
andscipy.spatial.distance.correlation
have been deprecated and will raisean error in SciPy
1.17.0
.scipy.spatial.distance.kulczynski1
andscipy.spatial.distance.sokalmichener
were deprecated and will be removedin SciPy
1.17.0
.scipy.stats.find_repeats
is deprecated and will beremoved in SciPy
1.17.0
. Please usenumpy.unique
/numpy.unique_counts
instead.scipy.linalg.kron
is deprecated in favour ofnumpy.kron
.scipy.signal
convolution/correlation functions (
scipy.signal.correlate
,scipy.signal.convolve
andscipy.signal.choose_conv_method
) andfiltering functions (
scipy.signal.lfilter
,scipy.signal.sosfilt
) hasbeen deprecated and will be removed in SciPy
1.17.0
.scipy.stats.linregress
has deprecated one-argument use; the twovariables must be specified as separate arguments.
scipy.stats.trapz
is deprecated in favor ofscipy.stats.trapezoid
.scipy.special.lpn
is deprecated in favor ofscipy.special.legendre_p_all
.scipy.special.lpmn
andscipy.special.clpmn
are deprecated in favor ofscipy.special.assoc_legendre_p_all
.scipy.special.sph_harm
has been deprecated in favor ofscipy.special.sph_harm_y
.r
andc
arrays passed toscipy.linalg.toeplitz
,scipy.linalg.matmul_toeplitz
, orscipy.linalg.solve_toeplitz
will betreated as batches of 1-D coefficients beginning in SciPy
1.17.0
.random_state
andpermutations
arguments ofscipy.stats.ttest_ind
are deprecated. Usemethod
to perform apermutation test, instead.
Expired Deprecations
scipy.signal
have been removed. This includesdaub
,qmf
,cascade
,morlet
,morlet2
,ricker
,and
cwt
. Users should usepywavelets
instead.scipy.signal.cmplx_sort
has been removed.scipy.integrate.quadrature
andscipy.integrate.romberg
have beenremoved in favour of
scipy.integrate.quad
.scipy.stats.rvs_ratio_uniforms
has been removed in favor ofscipy.stats.sampling.RatioUniforms
.scipy.special.factorial
now raises an error for non-integer scalars whenexact=True
.scipy.integrate.cumulative_trapezoid
now raises an error for values ofinitial
other than0
andNone
.scipy.interpolate.Akima1DInterpolator
and
scipy.interpolate.PchipInterpolator
special.btdtr
andspecial.btdtri
have been removed.exact=
kwarg inspecial.factorialk
has changedfrom
True
toFalse
.scipy.misc
submodule have been removed.Backwards incompatible changes
interpolate.BSpline.integrate
output is now always a numpy array.Previously, for 1D splines the output was a python float or a 0D array
depending on the value of the
extrapolate
argument.scipy.stats.wilcoxon
now respects themethod
argument provided by theuser. Previously, even if
method='exact'
was specified, the functionwould resort to
method='approx'
in some cases.scipy.integrate.AccuracyWarning
has been removed as the functions thewarning was emitted from (
scipy.integrate.quadrature
andscipy.integrate.romberg
) have been removed.Other changes
A separate accompanying type stubs package,
scipy-stubs
, will be madeavailable with the
1.15.0
release. Installation instructions areavailable.
scipy.stats.bootstrap
now emits aFutureWarning
if the shapes of theinput arrays do not agree. Broadcast the arrays to the same batch shape
(i.e. for all dimensions except those specified by the
axis
argument)to avoid the warning. Broadcasting will be performed automatically in the
future.
SciPy endorsed SPEC-7,
which proposes a
rng
argument to control pseudorandom number generation(PRNG) in a standard way, replacing legacy arguments like
seed
andrandom_sate
. In many cases, use ofrng
will change the behavior ofthe function unless the argument is already an instance of
numpy.random.Generator
.Effective in SciPy
1.15.0
:rng
argument has been added to the following functions:scipy.cluster.vq.kmeans
,scipy.cluster.vq.kmeans2
,scipy.interpolate.BarycentricInterpolator
,scipy.interpolate.barycentric_interpolate
,scipy.linalg.clarkson_woodruff_transform
,scipy.optimize.basinhopping
,scipy.optimize.differential_evolution
,scipy.optimize.dual_annealing
,scipy.optimize.check_grad
,scipy.optimize.quadratic_assignment
,scipy.sparse.random
,scipy.sparse.random_array
,scipy.sparse.rand
,scipy.sparse.linalg.svds
,scipy.spatial.transform.Rotation.random
,scipy.spatial.distance.directed_hausdorff
,scipy.stats.goodness_of_fit
,scipy.stats.BootstrapMethod
,scipy.stats.PermutationMethod
,scipy.stats.bootstrap
,scipy.stats.permutation_test
,scipy.stats.dunnett
, allscipy.stats.qmc
classes that consume random numbers, andscipy.stats.sobol_indices
.rng
argument will follow the SPEC 7standard behavior: the argument will be normalized with
np.random.default_rng
before being used.will remain unchanged (for now).
It is planned that in
1.17.0
the legacy argument will start emittingwarnings, and that in
1.19.0
the default behavior will change.In all cases, users can avoid future disruption by proactively passing
an instance of
np.random.Generator
by keywordrng
. For details,see SPEC-7.
The SciPy build no longer adds
-std=legacy
for Fortran code,except when using Gfortran. This avoids problems with the new Flang and
AMD Fortran compilers. It may make new build warnings appear for other
compilers - if so, please file an issue.
scipy.signal.sosfreqz
has been renamed toscipy.signal.freqz_sos
.New code should use the new name. The old name is maintained as an alias for
backwards compatibility.
Testing thread-safety improvements related to Python
3.13t
have beenmade in:
scipy.special
,scipy.spatial
,scipy.sparse
,scipy.interpolate
.Authors (commits)
A total of 149 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.14.1
: SciPy 1.14.1Compare Source
SciPy 1.14.1 Release Notes
SciPy
1.14.1
adds support for Python3.13
, including binarywheels on PyPI. Apart from that, it is a bug-fix release with
no new features compared to
1.14.0
.Authors
A total of 17 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.14.0
: SciPy 1.14.0Compare Source
SciPy 1.14.0 Release Notes
SciPy
1.14.0
is the culmination of 3 months of hard work. It containsmany new features, numerous bug-fixes, improved test coverage and better
documentation. There have been a number of deprecations and API changes
in this release, which are documented below. All users are encouraged to
upgrade to this release, as there are a large number of bug-fixes and
optimizations. Before upgrading, we recommend that users check that
their own code does not use deprecated SciPy functionality (to do so,
run your code with
python -Wd
and check forDeprecationWarning
s).Our development attention will now shift to bug-fix releases on the
1.14.x branch, and on adding new features on the main branch.
This release requires Python
3.10+
and NumPy1.23.5
or greater.For running on PyPy, PyPy3
6.0+
is required.Highlights of this release
has wheels built against Accelerate for macOS >=14 resulting in significant
performance improvements for many linear algebra operations.
cobyqa
, has been added toscipy.optimize.minimize
- thisis an interface for COBYQA (Constrained Optimization BY Quadratic
Approximations), a derivative-free optimization solver, designed to
supersede COBYLA, developed by the Department of Applied Mathematics, The
Hong Kong Polytechnic University.
scipy.sparse.linalg.spsolve_triangular
is now more than an order ofmagnitude faster in many cases.
New features
scipy.fft
improvementsscipy.fft.prev_fast_len
, has been added. This functionfinds the largest composite of FFT radices that is less than the target
length. It is useful for discarding a minimal number of samples before FFT.
scipy.io
improvementswavfile
now supports reading and writing ofwav
files in the RF64format, allowing files greater than 4 GB in size to be handled.
scipy.constants
improvementsscipy.interpolate
improvementsscipy.interpolate.Akima1DInterpolator
now supports extrapolation via theextrapolate
argument.scipy.optimize
improvementsscipy.optimize.HessianUpdateStrategy
now also accepts square arrays forinit_scale
.cobyqa
, has been added toscipy.optimize.minimize
- thisis an interface for COBYQA (Constrained Optimization BY Quadratic
Approximations), a derivative-free optimization solver, designed to
supersede COBYLA, developed by the Department of Applied Mathematics, The
Hong Kong Polytechnic University.
scipy.optimize.differential_evolution
.scipy.optimize.approx_fprime
now has linear space complexity.scipy.signal
improvementsscipy.signal.minimum_phase
has a new argumenthalf
, allowing theprovision of a filter of the same length as the linear-phase FIR filter
coefficients and with the same magnitude spectrum.
scipy.sparse
improvementsThese are all the formats we currently intend to support 1D shapes.
Other sparse array formats raise an exception for 1D input.
Results are still COO format sparse arrays for min/nanmin and
dense
np.ndarray
for argmin.repr
andstr
output.dia_array
by ascalar, which avoids a potentially costly conversion to CSR format.
scipy.sparse.csgraph.yen
has been added, allowing usage of Yen's K-ShortestPaths algorithm on a directed on undirected graph.
scipy.sparse.linalg.spsolve_triangular
is now more than an order ofmagnitude faster in many cases.
scipy.spatial
improvementsRotation
supports an alternative "scalar-first" convention of quaternioncomponent ordering. It is available via the keyword argument
scalar_first
of
from_quat
andas_quat
methods.Rotation
objects.scipy.special
improvementsscipy.special.log_wright_bessel
, for calculation of the logarithm ofWright's Bessel function.
scipy.special.hyp2f1
calculations has improvedsubstantially.
boxcox
,inv_boxcox
,boxcox1p
, andinv_boxcox1p
by preventing premature overflow.scipy.stats
improvementsscipy.stats.power
can be used for simulating the powerof a hypothesis test with respect to a specified alternative.
scipy.stats.irwinhall
.scipy.stats.mannwhitneyu
are much fasterand use less memory.
scipy.stats.pearsonr
now accepts n-D arrays and computes the statisticalong a specified
axis
.scipy.stats.kstat
,scipy.stats.kstatvar
, andscipy.stats.bartlett
are faster at performing calculations along an axis of a large n-D array.
Array API Standard Support
Experimental support for array libraries other than NumPy has been added to
existing sub-packages in recent versions of SciPy. Please consider testing
these features by setting an environment variable
SCIPY_ARRAY_API=1
andproviding PyTorch, JAX, or CuPy arrays as array arguments.
As of 1.14.0, there is support for
scipy.cluster
scipy.fft
scipy.constants
scipy.special
: (select functions)scipy.special.log_ndtr
scipy.special.ndtr
scipy.special.ndtri
scipy.special.erf
scipy.special.erfc
scipy.special.i0
scipy.special.i0e
scipy.special.i1
scipy.special.i1e
scipy.special.gammaln
scipy.special.gammainc
scipy.special.gammaincc
scipy.special.logit
scipy.special.expit
scipy.special.entr
scipy.special.rel_entr
scipy.special.xlogy
scipy.special.chdtrc
scipy.stats
: (select functions)scipy.stats.describe
scipy.stats.moment
scipy.stats.skew
scipy.stats.kurtosis
scipy.stats.kstat
scipy.stats.kstatvar
scipy.stats.circmean
scipy.stats.circvar
scipy.stats.circstd
scipy.stats.entropy
scipy.stats.variation
scipy.stats.sem
scipy.stats.ttest_1samp
scipy.stats.pearsonr
scipy.stats.chisquare
scipy.stats.skewtest
scipy.stats.kurtosistest
scipy.stats.normaltest
scipy.stats.jarque_bera
scipy.stats.bartlett
scipy.stats.power_divergence
scipy.stats.monte_carlo_test
Deprecated features
scipy.stats.gstd
,scipy.stats.chisquare
, andscipy.stats.power_divergence
have deprecated support for masked arrayinput.
scipy.stats.linregress
has deprecated support for specifying both samplesin one argument;
x
andy
are to be provided as separate arguments.conjtransp
method forscipy.sparse.dok_array
andscipy.sparse.dok_matrix
has been deprecated and will be removed in SciPy1.16.0.
quadrature="trapz"
inscipy.integrate.quad_vec
has beendeprecated in favour of
quadrature="trapezoid"
and will be removed inSciPy 1.16.0.
scipy.special.{comb,perm}
have deprecated support for use ofexact=True
inconjunction with non-integral
N
and/ork
.Backwards incompatible changes
scipy.stats
functions now produce a standardized warning message whenan input sample is too small (e.g. zero size). Previously, these functions
may have raised an error, emitted one or more less informative warnings, or
emitted no warnings. In most cases, returned results are unchanged; in almost
all cases the correct result is
NaN
.Expired deprecations
There is an ongoing effort to follow through on long-standing deprecations.
The following previously deprecated features are affected:
Several previously deprecated methods for sparse arrays were removed:
asfptype
,getrow
,getcol
,get_shape
,getmaxprint
,set_shape
,getnnz
, andgetformat
. Additionally, the.A
and.H
attributes were removed.scipy.integrate.{simps,trapz,cumtrapz}
have been removed in favour ofsimpson
,trapezoid
, andcumulative_trapezoid
.The
tol
argument ofscipy.sparse.linalg.{bcg,bicstab,cg,cgs,gcrotmk, mres,lgmres,minres,qmr,tfqmr}
has been removed in favour ofrtol
.Furthermore, the default value of
atol
for these functions has changedto
0.0
.The
restrt
argument ofscipy.sparse.linalg.gmres
has been removed infavour of
restart
.The
initial_lexsort
argument ofscipy.stats.kendalltau
has beenremoved.
The
cond
andrcond
arguments ofscipy.linalg.pinv
have beenremoved.
The
even
argument ofscipy.integrate.simpson
has been removed.The
turbo
andeigvals
arguments fromscipy.linalg.{eigh,eigvalsh}
have been removed.
The
legacy
argument ofscipy.special.comb
has been removed.The
hz
/nyq
argument ofsignal.{firls, firwin, firwin2, remez}
hasbeen removed.
Objects that weren't part of the public interface but were accessible through
deprecated submodules have been removed.
float128
,float96
, and object arrays now raise an error inscipy.signal.medfilt
andscipy.signal.order_filter
.scipy.interpolate.interp2d
has been replaced by an empty stub (to beremoved completely in the future).
Coinciding with changes to function signatures (e.g. removal of a deprecated
keyword), we had deprecated positional use of keyword arguments for the
affected functions, which will now raise an error. Affected functions are:
sparse.linalg.{bicg, bicgstab, cg, cgs, gcrotmk, gmres, lgmres, minres, qmr, tfqmr}
stats.kendalltau
linalg.pinv
integrate.simpson
linalg.{eigh,eigvalsh}
special.comb
signal.{firls, firwin, firwin2, remez}
Other changes
standard remains C++17.
This results in significant performance improvements for linear algebra
operations, as well as smaller binary wheels.
to run the cross interpreter.
parts of SciPy.
Authors
A total of 85 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.13.1
: SciPy 1.13.1Compare Source
SciPy 1.13.1 Release Notes
SciPy
1.13.1
is a bug-fix release with no new featurescompared to
1.13.0
. The version of OpenBLAS shipped withthe PyPI binaries has been increased to
0.3.27
.Authors
A total of 19 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.13.0
: SciPy 1.13.0Compare Source
SciPy 1.13.0 Release Notes
SciPy
1.13.0
is the culmination of 3 months of hard work. Thisout-of-band release aims to support NumPy
2.0.0
, and is backwardscompatible to NumPy
1.22.4
. The version of OpenBLAS used to buildthe PyPI wheels has been increased to
0.3.26.dev
.This release requires Python 3.9+ and NumPy 1.22.4 or greater.
For running on PyPy, PyPy3 6.0+ is required.
Highlights of this release
2.0.0
.to run the examples locally on embedded Jupyterlite notebooks in their
browser.
scipy.stats
functions have gained support for additionalaxis
,nan_policy
, andkeepdims
arguments.scipy.stats
alsohas several performance and accuracy improvements.
New features
scipy.integrate
improvementsterminal
attribute ofscipy.integrate.solve_ivp
events
callables now additionally accepts integer values to specify a number
of occurrences required for termination, rather than the previous restriction
of only accepting a
bool
value to terminate on the first registeredevent.
scipy.io
improvementsscipy.io.wavfile.write
has improveddtype
input validation.scipy.interpolate
improvementsinterpolate.Akima1DInterpolator
, available via the newmethod
argument.
BSpline.insert_knot
inserts a knot into aBSpline
instance.This routine is similar to the module-level
scipy.interpolate.insert
function, and works with the BSpline objects instead of
tck
tuples.RegularGridInterpolator
gained the functionality to compute derivativesin place. For instance,
RegularGridInterolator((x, y), values, method="cubic")(xi, nu=(1, 1))
evaluates the mixed second derivative,:math:
\partial^2 / \partial x \partial y
atxi
.RegularGridInterpolator
have been changed: evaluations should besignificantly faster, while construction might be slower. If you experience
issues with construction times, you may need to experiment with optional
keyword arguments
solver
andsolver_args
. Previous behavior (fastconstruction, slow evaluations) can be obtained via
"*_legacy"
methods:method="cubic_legacy"
is exactly equivalent tomethod="cubic"
inprevious releases. See
gh-19633
for details.scipy.signal
improvementssampling frequency (
fs
).scipy.sparse
improvementscoo_array
now supports 1D shapes, and has additional 1D support formin
,max
,argmin
, andargmax
. The DOK format now haspreliminary 1D support as well, though only supports simple integer indices
at the time of writing.
pydata/sparse
array inputs toscipy.sparse.csgraph
.dok_array
anddok_matrix
now have proper implementations offromkeys
.csr
andcsc
formats now have improvedsetdiag
performance.scipy.spatial
improvementsvoronoi_plot_2d
now draws Voronoi edges to infinity more clearlywhen the aspect ratio is skewed.
scipy.special
improvementsAMOS
,specfun
, andcdflib
librariesthat the majority of special functions depend on, is ported to Cython/C.
factorialk
now also supports faster, approximatecalculation using
exact=False
.scipy.stats
improvementsscipy.stats.rankdata
andscipy.stats.wilcoxon
have been vectorized,improving their performance and the performance of hypothesis tests that
depend on them.
stats.mannwhitneyu
should now be faster due to a vectorized statisticcalculation, improved caching, improved exploitation of symmetry, and a
memory reduction.
PermutationMethod
support was also added.scipy.stats.mood
now hasnan_policy
andkeepdims
support.scipy.stats.brunnermunzel
now hasaxis
andkeepdims
support.scipy.stats.friedmanchisquare
,scipy.stats.shapiro
,scipy.stats.normaltest
,scipy.stats.skewtest
,scipy.stats.kurtosistest
,scipy.stats.f_oneway
,scipy.stats.alexandergovern
,scipy.stats.combine_pvalues
, andscipy.stats.kstest
have gainedaxis
,nan_policy
andkeepdims
support.scipy.stats.boxcox_normmax
has gained aymax
parameter to allow userspecification of the maximum value of the transformed data.
scipy.stats.vonmises
pdf
method has been extended to supportkappa=0
. Thefit
method is also more performant due to the use ofnon-trivial bounds to solve for
kappa
.moment
calculations forscipy.stats.powerlaw
are now moreaccurate.
fit
methods ofscipy.stats.gamma
(withmethod='mm'
) andscipy.stats.loglaplace
are faster and more reliable.scipy.stats.goodness_of_fit
now supports the use of a customstatistic
provided by the user.
scipy.stats.wilcoxon
now supportsPermutationMethod
, enablingcalculation of accurate p-values in the presence of ties and zeros.
scipy.stats.monte_carlo_test
now has improved robustness in the face ofnumerical noise.
scipy.stats.wasserstein_distance_nd
was introduced to compute theWasserstein-1 distance between two N-D discrete distributions.
Deprecated features
PchipInterpolator
andAkima1DInterpolator
havebeen deprecated and will raise an error in SciPy 1.15.0. If you are trying
to use the real components of the passed array, use
np.real
ony
.Backwards incompatible changes
Other changes
scipy.stats.moment
has been renamed toorder
while maintaining backward compatibility.
Authors
A total of 96 people contributed to this release.
People with a "+" by their names contributed a patch for the first time.
This list of names is automatically generated, and may not be fully complete.
v1.12.0
: SciPy 1.12.0Compare Source
SciPy 1.12.0 Release Notes
SciPy
1.12.0
is the culmination of6
months of hard work. It containsmany new features, numerous bug-fixes, improved test coverage and better
documentation. There have been a number of deprecations and API changes
in this release, which are documented below. All users are encouraged to
upgrade to this release, as there are a large number of bug-fixes and
optimizations. Before upgrading, we recommend that users check that
their own code does not use deprecated SciPy functionality (to do so,
run your code with
python -Wd
and check forDeprecationWarning
s).Our development attention will now shift to bug-fix releases on the
1.12.x branch, and on adding new features on the main branch.
This release requires Python
3.9+
and NumPy1.22.4
or greater.For running on PyPy, PyPy3
6.0+
is required.Highlights of this release
scipy.special
, and to all ofscipy.fft
andscipy.cluster
. There arelikely to be bugs and early feedback for usage with CuPy arrays, PyTorch
tensors, and other array API compatible libraries is appreciated. Use the
SCIPY_ARRAY_API
environment variable for testing.ShortTimeFFT
, provides a more versatile implementation of theshort-time Fourier transform (STFT), its inverse (ISTFT) as well as the (cross-)
spectrogram. It utilizes an improved algorithm for calculating the ISTFT.
now additionally support sparse arrays, further facilitating the migration
from sparse matrices.
scipy.stats
API now has improved support for handlingNaN
values, masked arrays, and more fine-grained shape-handling. Theaccuracy and performance of a number of
stats
methods have been improved,and a number of new statistical tests and distributions have been added.
New features
scipy.cluster
improvementsCuPy arrays and array API compatible array libraries are now accepted
(GPU support is limited to functions with pure Python implementations).
CPU arrays which can be converted to and from NumPy are supported
module-wide and returned arrays will match the input type.
This behaviour is enabled by setting the
SCIPY_ARRAY_API
environmentvariable before importing
scipy
. This experimental support is stillunder development and likely to contain bugs - testing is very welcome.
scipy.fft
improvementspart of the
fft
array API standard extension module, as well as theFast Hankel Transforms and the basic FFTs which are not in the extension
module, now accept PyTorch tensors, CuPy arrays and array API compatible
array libraries. CPU arrays which can be converted to and from NumPy arrays
are supported module-wide and returned arrays will match the input type.
This behaviour is enabled by setting the
SCIPY_ARRAY_API
environmentvariable before importing `s
Configuration
📅 Schedule: Branch creation - "* 0-4 * * 3" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.