Changelog
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
Unreleased
0.3.0 - 2026-03-22
Added
- Added comprehensive notebook development guidelines in
docs/notebooks/README.md - get_implementations() and has_implementation() for operator dispatch introspection
- Operator params guide tutorial covering inspection, override, shared params, eqx.Module as params, NN-generated stencils, and learned gradient correction
Changed
- Breaking: Minimum Python version increased to 3.11 (from 3.9)
- Breaking: Migrated build system from Poetry to uv for faster dependency management
- Breaking: Converted from Poetry to standard pyproject.toml format (PEP 621)
- Updated JAX dependency to 0.8.x (from 0.4.x) for compatibility with latest features
- Updated Equinox dependency to 0.13.x (from 0.11.x)
- Updated plum-dispatch dependency to 2.6.x (from 2.5.x)
shift_operatornow returns only one output forFourierSeriesfields (removed unnecessary second output)- Updated development dependencies: pytest (9.x), isort (7.x), bump-my-version (1.x), mkdocs plugins, and others
Removed
- Removed Makefile in favor of direct uv commands
- Removed
debug_configdictionary and related deprecation warnings - Removed
Field.is_field_complexproperty (deprecated in favor of.is_complex) - Removed
discretizationdecorator from public API (deprecated)
Fixed
- Fixed bug in
Continuous.replace_paramswhere deprecatedself.get_fieldwas used instead ofself.get_fun - Inconsistent shift_operator between FourierSeries and FiniteDifferences (#146)
- Linear.eq no longer crashes when compared with non-Linear types (fixes #145)
- FiniteDifferences.replace_params now preserves the accuracy field (fixes ucl-bug/jwave#224)
- Import NotFoundLookupError from plum instead of plum.resolver (plum-dispatch 2.x compat)
0.2.8 - 2024-09-17
Fixed
- Fixed
util.get_implementedbug that was happening with the new version ofplum
Removed
- Removed the deprecated
util._get_implementedfunction
0.2.7 - 2023-11-24
Changed
- The Quickstart tutorial has been upgdated.
- The property
Field.ndimhas now been moved intoField.domain.ndim, as it is fundamentally a property of the domain - The
init_paramsfunction now will inherit the default parameters from its operator, to remove any source of ambiguity. This means that it should not have any default values, and an error is raised if it does.
Removed
- The
__about__file has been removed, as it is redundant - The function
params_mapis removed, usejax.tree_util.tree_mapinstead. - Operators are now expected to return only their outputs, and not parameters. If you need to get the parameters of an operator use its
default_paramsmethod. To minimize problems for packages relying onjaxdf, in this release the outputs of anoperatorare filtered to keep only the first one. This will change soon to allow the user to return arbitrary PyTrees.
Added
- JaxDF
Fields are now based on equinox. In theory, this should allow to usejaxdfwith all the scientific libraries for the jax ecosystem. In practice, please raise an issue when you encounter one of the inevitable bugs :) - The new
operator.abstractdecorator can be used to define an unimplemented operator, for specifying input arguments and docstrings. Linearfields are now defined as equal if they have the same set of parameters and the sameDomain.Ongridfields now have the method.add_dim(), which adds an extra tailing dimension to its parameters. This is not an in-place update: the method returns a new field.- The function
jaxdf.util.get_implementedis now exposed to the user. - Added
laplacianoperator forFiniteDifferencesfields. - JaxDF now uses standard Python logging. To set the logging level, use
jaxdf.logger.set_logging_level, for examplejaxdf.logger.set_logging_level("DEBUG"). The default level isINFO. - Fields have now a handy property
.θwhich is an alias for.params ContinuousandLinearfields now have the.is_complexpropertyFieldandDomainare nowModuless, which are based on fromequinox.Module. They are entirely equivalent toequinox.Module, but have the extra.replacemethod that is used to update a single field.
Deprecated
- The property
.is_field_complexis now deprecated in favor of.is_complex. Same goes for.is_real. Field.get_fieldis now deprecated in favor of the__call__method.- The
@discretizationdecorator is deprecated, as nowFieldsareequinoxmodules. It is just not needed now, and until removed it will act as a simple pass-trough
Fixed
OnGrid.from_gridnow automatically adds a dimension at the end of the array for scalar fields, if needed- Added a custom operator for
equinox.internal._omega._Metaωobjects and Fields, which makes the library compatible withdiffrax
0.2.6 - 2023-06-28
Changed
- removed
jaxlibfrom dependencies. See https://github.com/google/jax/discussions/16380 for more information
0.2.5 - 2023-06-23
Fixed
- The default_parameters function now works with custom field types
__rpow__forOnGrid- Avoids changing parameters of
OnGridinside jax transformations - Spectral gradient for signal of even length now treats the Nyquist frequency correctly
- Staggering in
FiniteDifferenceskernel - Incorrect behaviour for 3d staggered derivatives
Added
- Heterogeneous laplacian operator
FourierSeriesvalues on arbitrary point using__call__method- Automatically infer missing dimension for scalar fields
- Shift operator
- Staggering for
FourierSeriesdifferential operators
Changed
- Updated docs
- Renamed ode variable update, removed wrong test in utils
- Updated support/packaging files