Changes
- Changed how numpy is handled as an optional dependency. Previously,
- importing a numpy-dependent function, like correlated_values, without numpy installed would result in an ImportError at import time. Now such a function can be imported but if the user attempts to execute it, a NotImplementedError is raised indicating that the function can't be used because numpy couldn't be imported.
Adds:
- Added a small benchmarking suite to CI to guard against absolute performance
- regressions and accidental breakage of the lazy expansion algorithm whichs ensures O(N), rather than O(N^2), scaling complexity for operations involving many numbers with uncertainty. Established connectivity with `codspeed.io<codspeed.io>`_ to track benchmarking results. (#274)
Fixes:
- add note on string not containing uncertainty to ufloat_fromstr doctring (#287)
- fix typos in ufloat_fromstr docstring examples (#285)
- fix readthedocs configuration so that the build passes (#254)
- adjust codecov.io configuration so that minor code coverage changes will not result
- in indications that tests are failing. Rather code coverage reports will be purely informational for code reviewers. Also fix other minor configuration issues. (#270)
Fixes:
- fix support for Numpy 2.0 (#245). Note: uncertainties.unumpy still
- provides umatrix based on numpy.matrix. With numpy.matrix discouraged, umatrix is too, and will be dropped in a future release.
- fix automated running and reporting of code coverage with tests (#246)
- use setuptools-scm for setting version number from git tag (#247)
3.2.1 2024-June-08
Fixes for build, deployment, and docs
- Use explicit package list to make sure unumpy is included (#232)
- Use setuptools-scm to make sure all files are in the source distribution (#235)
- updates to configuration for and links to readthedocs documentation. (#239)
- use double backticks more uniformly in docs. (#240)
- fixes to README.rst to allow it to render (needed for PyPI upload) (#243)
Version 3.2.0 is the first release of Uncertainties in nearly two years and the first minor release in over five years. It marks the beginning of an effort to refresh and update the project with a new and expanded team of maintainers.
- Main Changes
- Moved code development to lmfit organization, with 4 maintainers.
- Update documentation.
- Drop future dependency. Uncertainties now has no external dependencies when
- not using Numpy integration (Drop official support for Python versions before 3.8 #200).
- Drop support for Python versions before 3.8, including Python 2 (Drop official support for Python versions before 3.8 #200)
- remove 1to2 and deprecations (remove 1to2 and depreciations #214)
- Developer related changes
- Moved from setup.py to pyproject.toml (Transition from setup.py to pyproject.toml #199)
- Move tests to tests folder (Move tests to tests folder #216)
- Update unumpy test to be compatible with numpy 2
- Mark docstrings with backslashes as raw strings in tests (Mark docstrings with backslashes as raw strings #226)
Main changes: - 3.1.6: The pretty-print and LaTeX format can now be customized. - 3.1.5: Added a "p" formatting option, that makes sure that there are always
parentheses around the … ± … part of printed numbers.
- 3.1.4: Python 2.7+ is now required.
- 3.1.2: Fix for NumPy 1.17 and
unumpy.ulinalg.pinv()
. - 3.1: Variables built through a correlation or covariance matrix, and that
have uncertainties that span many orders of magnitude are now
calculated more accurately (improved
correlated_values()
andcorrelated_values_norm()
functions). - 3.0: Massive speedup for some operations involving large numbers of numbers with uncertainty, like
sum(ufloat(1, 1) for _ in xrange(100000))
(this is about 5,000 times faster than before). - 2.4.8: Friendlier completions in Python shells, etc.: internal functions should not appear anymore (for the user modules:
uncertainties
,uncertainties.umath
anduncertainties.unumpy
). Parsing the shorthand notation (e.g.3.1(2)
) now works with infinite values (e.g.-inf(inf)
); this mirrors the ability to print such numbers with uncertainty. The Particle Data Group rounding rule is applied in more cases (e.g. printing 724.2±26.2 now gives724±26
). The shorthand+LaTeX formatting of numbers with an infinite nominal value is fixed.uncertainties.unumpy.matrix
now uses.std_devs
instead of.std_devs()
, for consistency with floats with uncertainty (automatic conversion of code added touncertainties.1to2
). - 2.4.7: String formatting now works for
(-)inf+/-...
numbers. - 2.4.5: String formatting now works for
NaN+/-...
numbers. - 2.4.4: The documentation license now allows its commercial use.
- 2.4.2: NumPy 1.8 compatibility.
- 2.4.1: In
uncertainties.umath
, functionsceil()
,floor()
,isinf()
,isnan()
andtrunc()
now return values of the same type as the correspondingmath
module function (instead of generally returning a value with a zero uncertainty...+/-0
). - 2.4: Extensive support for the formatting of numbers with uncertainties.
A zero uncertainty is now explicitly displayed as the integer 0.
The new formats are generally understood by
ufloat_fromstr()
. Abbreviations for the nominal value (n
) and the standard deviation (s
) are now available. - 2.3.6: Full support for limit cases of the power operator
umath.pow()
. - 2.3.5: Uncertainties and derivatives can now be NaN (not-a-number).
Full support for numbers with a zero uncertainty
(
sqrt(ufloat(0, 0))
now works). Full support for limit cases of the power operator (x**y
). - 2.3: Functions wrapped
so that they accept numbers with uncertainties instead of floats
now have full keyword arguments support
(improved
wrap()
function). Incompatible change:wrap(..., None)
should be replaced bywrap(...)
orwrap(..., [])
. - 2.2: Creating arrays and matrices of numbers with uncertainties
with
uarray()
andumatrix()
now requires two simple arguments (nominal values and standard deviations) instead of a tuple argument. This is consistent with the new, simplerufloat()
interface. The previous usage will be supported for some time. Users are encouraged to update their code, for instance through the newly provided code updater, which in addition now automatically converts.set_std_dev(v)
to.std_dev = v
. - 2.1: Numbers with uncertainties are now created more directly like
ufloat(3, 0.1)
,ufloat(3, 0.1, "pi")
,ufloat_fromstr("3.0(1)")
, orufloat_fromstr("3.0(1)", "pi")
. The previousufloat((3, 0.1))
andufloat("3.0(1)")
forms will be supported for some time. Users are encouraged to update their code, for instance through the newly provided code updater. - 2.0: The standard deviation is now obtained more directly without an
explicit
call (
x.std_dev
instead ofx.std_dev()
).x.std_dev()
will be supported for some time. Users are encouraged to update their code. The standard deviation of a variable can now be directly updated withx.std_dev = 0.1
. As a consequence,x.set_std_dev()
is deprecated. - 1.9.1: Support added for pickling subclasses of
UFloat
(=Variable
). - 1.9: Added functions for handling correlation matrices:
correlation_matrix()
andcorrelated_values_norm()
. (These new functions mirror the covariance-matrix basedcovariance_matrix()
andcorrelated_values()
.)UFloat.position_in_sigmas()
is now namedUFloat.std_score()
, so as to follow the common naming convention (standard score). Obsolete functions were removed (from the main module:NumberWithUncert
,num_with_uncert
,array_u
,nominal_values
,std_devs
). - 1.8: Compatibility with Python 3.2 added.
- 1.7.2: Compatibility with Python 2.3, Python 2.4, Jython 2.5.1 and Jython 2.5.2 added.
- 1.7.1: New semantics:
ufloat("12.3(78)")
now represents 12.3+/-7.8 instead of 12.3+/-78. - 1.7:
ufloat()
now raises ValueError instead of a generic Exception, when given an incorrect string representation, likefloat()
does. - 1.6: Testing whether an object is a number with uncertainty should now
be done with
isinstance(..., UFloat)
.AffineScalarFunc
is not imported byfrom uncertainties import *
anymore, but its new aliasUFloat
is. - 1.5.5: The first possible license is now the Revised BSD License instead of GPLv2, which makes it easier to include this package in other projects.
- 1.5.4.2: Added
umath.modf()
andumath.frexp()
. - 1.5.4:
ufloat
does not accept a single number (nominal value) anymore. This removes some potential confusion aboutufloat(1.1)
(zero uncertainty) being different fromufloat("1.1")
(uncertainty of 1 on the last digit). - 1.5.2:
float_u
,array_u
andmatrix_u
renamedufloat
,uarray
andumatrix
, for ease of typing. - 1.5: Added functions
nominal_value
andstd_dev
, and modulesunumpy
(additional support for NumPy arrays and matrices) andunumpy.ulinalg
(generalization of some functions fromnumpy.linalg
). Memory footprint of arrays of numbers with uncertainties divided by 3. Functionarray_u
is 5 times faster. Main functionnum_with_uncert
renamedfloat_u
, for consistency withunumpy.array_u
andunumpy.matrix_u
, with the added benefit of a shorter name. - 1.4.5: Added support for the standard
pickle
module. - 1.4.2: Added support for the standard
copy
module. - 1.4: Added utilities for manipulating NumPy arrays of numbers with
uncertainties (
array_u
,nominal_values
andstd_devs
). - 1.3: Numbers with uncertainties are now constructed with
num_with_uncert()
, which replacesNumberWithUncert()
. This simplifies the class hierarchy by removing theNumberWithUncert
class. - 1.2.5: Numbers with uncertainties can now be entered as
NumberWithUncert("1.23+/-0.45")
too. - 1.2.3:
log(x, base)
is now supported byumath.log()
, in addition tolog(x)
. - 1.2.2: Values with uncertainties are now output like 3+/-1, in order to avoid confusing 3+-1 with 3+(-1).
- 1.2: A new function,
wrap()
, is exposed, which allows non-Python functions (e.g. Fortran or C used through a module such as SciPy) to handle numbers with uncertainties. - 1.1: Mathematical functions (such as cosine, etc.) are in a new
uncertainties.umath module;
they do not override functions from the
math
module anymore. - 1.0.12: Main class (
Number_with_uncert
) renamedNumberWithUncert
so as to follow PEP 8. - 1.0.11:
origin_value
renamed more appropriately asnominal_value
. - 1.0.9:
correlations()
renamed more appropriately ascovariance_matrix()
.