Changelog¶
0.7.4 - 2025-05-30¶
What's Changed¶
New features¶
- Add version attribute to init file by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/98
Documentation updates¶
- Fix capitalisation in JOSS paper bibliography by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/97
- Update suggested citation to use new JOSS paper citation by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/100
Other changes¶
- Update PR labelling and release template by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/99
- Reformat code with additional
ruff
linting rules by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/101
New Contributors¶
- @github-actions made their first contribution in https://github.com/GeoscienceAustralia/eo-tides/pull/96
Full Changelog: https://github.com/GeoscienceAustralia/eo-tides/compare/0.7.3...0.7.4
0.7.3 - 2025-05-22¶
Changes¶
- Use dynamic version handling via
hatch-vcs
, add automatic changelog update action by @robbibt in https://github.com/GeoscienceAustralia/eo-tides/pull/95 - Bump the python-deps group with 2 updates by @dependabot in https://github.com/GeoscienceAustralia/eo-tides/pull/94
Full Changelog: https://github.com/GeoscienceAustralia/eo-tides/compare/0.7.2...0.7.3
0.7.2 - 2025-05-19¶
New features¶
- Minor updates to improve documentation around accessing GESLA 3.0 tide gauge data,
- Made validation functions more re-usable by removing hard-coded paths and adding helpful error messages.
0.7.1 - 2025-05-19¶
Minor update to package dependencies
0.7.0 - 2025-05-14¶
New features¶
- This version corresponds to the code archived as part of Journal of Open Source Software publication. No new features introduced.
0.6.5 - 2025-05-08¶
New features¶
- Support for
pyTMD
versions 2.2.3 and 2.2.4
0.6.4 - 2025-02-31¶
New features¶
- Updated installation documentation to improve reproducibility
Bug fixes¶
- Temporarily pinned Dask to avoid
odc-geo
andodc-stac
errors
0.6.3 - 2025-03-20¶
New features¶
- Major updates to installation and setup documentation, to provide additional context about tide modelling data and installing
eo-tides
using bothpip
anduv
Bug fixes¶
- Fixed bug where ensemble tide modelling used excessive memory, by ensuring dtype of ensemble modelled tides matches dtype of input modelled tides (#70)
- Added missing
dask
dependency to requirements (#68)
0.6.2 - 2025-02-25¶
New features¶
- Added
apply_node
parameteter tomodel_tides
to applypyTMD
's adjustments to harmonic constituents to allow for periodic modulations over the 18.6-year nodal period (lunar nodal tide). Default is False.
Bug fixes¶
- Further fixes for bug causing tide model clipping with
clip_tides
to fail for bounding boxes completely west of the prime meridian (#50); default value forcrop
param is now"auto"
instead ofTrue
.
0.6.1 - 2025-02-20¶
Bug fixes¶
- Fixed bug causing tide model clipping with
clip_tides
to fail for bounding boxes completely west of the prime meridian (#50)
0.6.0 - 2025-02-11¶
New features¶
- Added
return_phases
parameter toeo_tides.eo.tag_tides
, which will return a dataframe containing tide phase information for each satellite observation - Added support for Technical University of Denmark tide models (DTU23)
- Minor docs improvements, updates for new FES2022 data format
0.5.0 - 2025-01-17¶
New features¶
- Added draft version of a Journal of Open Source Software paper
- Added benchmarking notebook that compares performance with parallelisation on and off
Bug fixes¶
- Fix documentation to point to correct location of
list_models
function (e.g.eo_tides.utils.list_models
)
Breaking changes¶
- Removed Python 3.9 support
- Added Python 3.13 support
0.4.0 - 2025-12-21¶
New features¶
-
Publishes ensemble tide modelling code for combining multiple global ocean tide models into a single locally optimised ensemble tide model using external model ranking data (e.g. satellite altimetry or NDWI-tide correlations along the coastline).
-
Update ensemble code to latest version that includes FES2022, GOT5.6 and TPXO10 tide models
- Make ensemble model calculation function a top level function (i.e. rename from
_ensemble_model
toensemble_tides
) -
Load tide model ranking points from external
flatgeobuf
format file for faster cloud access -
Major refactor to statistics functions to standardise code across both
pixel_stats
andtide_stats
and add support for multiple models -
tide_stats
will now return apandas.Series
if one model is requested, and apandas.DataFrame
if multiple are requested -
Added a new
point_col
parameter totide_stats
to control the colour of plotted points. Ifplot_var
is also provided, points will now be coloured differently by default. -
Added a new
crop_buffer
parameter to configure buffer distance when cropping model files withcrop=True
(defaults to 5 degrees) -
Reorder
model_tides
parameters to provide more logical flow and move more common params likemode
,output_format
andoutput_units
higher
Bug fixes¶
- Fix warnings from
load_gauge_gesla
function
Breaking changes¶
- The
plot_col
parameter fromtide_stats
has been renamed toplot_var
0.3.1 - 2024-11-15¶
New features¶
- Add new "all" option to
model
param inmodel_tides
,pixel_tides
etc, which will model tides using all available tide models in your provideddirectory
.
Bug fixes¶
- Fix bug where GOT5.6 was not detected as a valid model because it contains files in multiple directories (e.g. both "GOT5.6" and "GOT5.5"). This also affected clipping GOT5.6 data using the
eo_tides.utils.clip_models
function.
0.3.0 - 2024-11-11¶
New features¶
- Added new
eo_tides.utils.clip_models
function for clipping tide models to a smaller spatial extent. This can have a major positive impact on performance, sometimes producing more than a 10 x speedup. This function identifies all NetCDF-format tide models in a given input directory, including "ATLAS-netcdf" (e.g.TPXO9-atlas-nc
), "FES-netcdf" (e.g.FES2022
,EOT20
), and "GOT-netcdf" (e.g.GOT5.5
) format files. Files for each model are then clipped to the extent of the provided bounding box, handling model-specific file structures. After each model is clipped, the result is exported to the output directory and verified withpyTMD
to ensure the clipped data is suitable for tide modelling.
Major changes¶
- The
parallel_splits
parameter that controls the number of chunks data is broken into for parallel analysis has been refactored to use a new default of "auto". This now attempts to automatically determine a sensible value based on available CPU, number of points, and number of models being run. All CPUs will be used where possible, unless this will produce splits with less than 1000 points in each (which would increase overhead). Parallel splits will be reduced if multiple models are requested, as these are run in parallel too and will compete for the same resources. - Changed the default interpolation
method
from "spline" to "linear". This appears to produce the same results, but works considerably faster. - Updates to enable correct cropping, recently resolved in PyTMD 2.1.8
Breaking changes¶
- The
list_models
function has been relocated toeo_tides.utils
(fromeo_tides.model
)
0.2.0 - 2024-10-30¶
New features¶
- New
model_phases
function for calculating tidal phases ("low-flow", high-flow", "high-ebb", "low-ebb") for each tide height in a timeseries. Ebb and low phases are calculated by running theeo_tides.model.model_tides
function twice, once for the requested timesteps, and again after subtracting a small time offset (by default, 15 minutes). If tides increased over this period, they are assigned as "flow"; if they decreased, they are assigned as "ebb". Tides are considered "high" if equal or greater than 0 metres tide height, otherwise "low". - Major refactor to use consistent input parameters across all EO focused functions: input can now be either
xr.DataArray
orxr.Dataset
orodc.geo.geobox.GeoBox
; if an xarray object is passed, it must have a"time"
dimension; if GeoBox is passed, time must be provided by thetime
parameter. time
parameters now accept any format that can be converted bypandas.to_datetime()
; e.g. np.ndarray[datetime64], pd.DatetimeIndex, pd.Timestamp, datetime.datetime and strings (e.g. "2020-01-01 23:00").model_tides
now uses default cropping approach frompyTMD
, rather than applying a bespoke 1 degree buffer around the selected analysis areamodel_tides
refactored to use simpler approach to loading tide consistuents enabled inpyTMD==2.1.7
Breaking changes¶
- The
ds
param in all satellite data functions (tag_tides
,pixel_tides
,tide_stats
,pixel_tides
) has been renamed to a more generic namedata
(to account for now accepting eitherxarray.Dataset
,xarray.DataArray
or aodc.geo.geobox.GeoBox
inputs).
0.1.0 - 2024-10-18¶
New features¶
- Initial creation of
eo-tides
repo
Breaking changes¶
See Migrating from DEA Tools for a guide to updating your code from the original Digital Earth Australia Notebooks and Tools
repository.