dea-tools 0.3.4.dev48__tar.gz → 0.3.5.dev1__tar.gz
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.
- {dea_tools-0.3.4.dev48/dea_tools.egg-info → dea_tools-0.3.5.dev1}/PKG-INFO +1 -1
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/coastal.py +34 -4
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1/dea_tools.egg-info}/PKG-INFO +1 -1
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/.gitignore +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/LICENSE +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/MANIFEST.in +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/README.rst +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/__init__.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/__main__.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/__init__.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/animations.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/changefilmstrips.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/crophealth.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/deacoastlines.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/geomedian.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/imageexport.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/miningrehab.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/app/widgetconstructors.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/bandindices.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/bom.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/classification.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/climate.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/dask.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/datahandling.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/landcover.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/maps.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/plotting.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/pyfes_model.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/spatial.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/temporal.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/validation.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/waterbodies.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools/wetlands.py +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools.egg-info/SOURCES.txt +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools.egg-info/dependency_links.txt +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools.egg-info/requires.txt +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/dea_tools.egg-info/top_level.txt +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/index.rst +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/mock_imports.txt +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/pyproject.toml +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/setup.cfg +0 -0
- {dea_tools-0.3.4.dev48 → dea_tools-0.3.5.dev1}/setup.py +0 -0
|
@@ -16,7 +16,7 @@ https://gis.stackexchange.com/questions/tagged/open-data-cube).
|
|
|
16
16
|
If you would like to report an issue with this script, you can file one
|
|
17
17
|
on GitHub (https://github.com/GeoscienceAustralia/dea-notebooks/issues/new).
|
|
18
18
|
|
|
19
|
-
Last modified:
|
|
19
|
+
Last modified: July 2024
|
|
20
20
|
|
|
21
21
|
"""
|
|
22
22
|
|
|
@@ -238,6 +238,7 @@ def _model_tides(
|
|
|
238
238
|
time,
|
|
239
239
|
directory,
|
|
240
240
|
crs,
|
|
241
|
+
crop,
|
|
241
242
|
method,
|
|
242
243
|
extrapolate,
|
|
243
244
|
cutoff,
|
|
@@ -250,7 +251,6 @@ def _model_tides(
|
|
|
250
251
|
`pyTMD`.
|
|
251
252
|
"""
|
|
252
253
|
|
|
253
|
-
import pyTMD.constants
|
|
254
254
|
import pyTMD.eop
|
|
255
255
|
import pyTMD.io
|
|
256
256
|
import pyTMD.time
|
|
@@ -279,8 +279,17 @@ def _model_tides(
|
|
|
279
279
|
# Convert datetime
|
|
280
280
|
timescale = pyTMD.time.timescale().from_datetime(time.flatten())
|
|
281
281
|
|
|
282
|
+
# Calculate bounds for cropping
|
|
283
|
+
buffer = 1 # one degree on either side
|
|
284
|
+
bounds = [
|
|
285
|
+
lon.min() - buffer,
|
|
286
|
+
lon.max() + buffer,
|
|
287
|
+
lat.min() - buffer,
|
|
288
|
+
lat.max() + buffer,
|
|
289
|
+
]
|
|
290
|
+
|
|
282
291
|
# Read tidal constants and interpolate to grid points
|
|
283
|
-
if pytmd_model.format in ("OTIS", "ATLAS", "
|
|
292
|
+
if pytmd_model.format in ("OTIS", "ATLAS", "TMD3"):
|
|
284
293
|
amp, ph, D, c = pyTMD.io.OTIS.extract_constants(
|
|
285
294
|
lon,
|
|
286
295
|
lat,
|
|
@@ -288,6 +297,8 @@ def _model_tides(
|
|
|
288
297
|
pytmd_model.model_file,
|
|
289
298
|
pytmd_model.projection,
|
|
290
299
|
type=pytmd_model.type,
|
|
300
|
+
crop=crop,
|
|
301
|
+
bounds=bounds,
|
|
291
302
|
method=method,
|
|
292
303
|
extrapolate=extrapolate,
|
|
293
304
|
cutoff=cutoff,
|
|
@@ -304,6 +315,8 @@ def _model_tides(
|
|
|
304
315
|
pytmd_model.grid_file,
|
|
305
316
|
pytmd_model.model_file,
|
|
306
317
|
type=pytmd_model.type,
|
|
318
|
+
crop=crop,
|
|
319
|
+
bounds=bounds,
|
|
307
320
|
method=method,
|
|
308
321
|
extrapolate=extrapolate,
|
|
309
322
|
cutoff=cutoff,
|
|
@@ -319,6 +332,8 @@ def _model_tides(
|
|
|
319
332
|
lon,
|
|
320
333
|
lat,
|
|
321
334
|
pytmd_model.model_file,
|
|
335
|
+
crop=crop,
|
|
336
|
+
bounds=bounds,
|
|
322
337
|
method=method,
|
|
323
338
|
extrapolate=extrapolate,
|
|
324
339
|
cutoff=cutoff,
|
|
@@ -336,6 +351,8 @@ def _model_tides(
|
|
|
336
351
|
pytmd_model.model_file,
|
|
337
352
|
type=pytmd_model.type,
|
|
338
353
|
version=pytmd_model.version,
|
|
354
|
+
crop=crop,
|
|
355
|
+
bounds=bounds,
|
|
339
356
|
method=method,
|
|
340
357
|
extrapolate=extrapolate,
|
|
341
358
|
cutoff=cutoff,
|
|
@@ -585,6 +602,7 @@ def model_tides(
|
|
|
585
602
|
model="FES2014",
|
|
586
603
|
directory=None,
|
|
587
604
|
crs="EPSG:4326",
|
|
605
|
+
crop=True,
|
|
588
606
|
method="spline",
|
|
589
607
|
extrapolate=True,
|
|
590
608
|
cutoff=None,
|
|
@@ -614,6 +632,10 @@ def model_tides(
|
|
|
614
632
|
- {directory}/fes2014/ocean_tide/
|
|
615
633
|
- {directory}/fes2014/load_tide/
|
|
616
634
|
|
|
635
|
+
For FES2022 (https://www.aviso.altimetry.fr/en/data/products/auxiliary-products/global-tide-fes.html):
|
|
636
|
+
- {directory}/fes2022b/ocean_tide/
|
|
637
|
+
- {directory}/fes2022b/load_tide/
|
|
638
|
+
|
|
617
639
|
For TPXO8-atlas (https://www.tpxo.net/tpxo-products-and-registration):
|
|
618
640
|
- {directory}/tpxo8_atlas/
|
|
619
641
|
|
|
@@ -648,6 +670,7 @@ def model_tides(
|
|
|
648
670
|
model : string, optional
|
|
649
671
|
The tide model used to model tides. Options include:
|
|
650
672
|
- "FES2014" (pre-configured on DEA Sandbox)
|
|
673
|
+
- "FES2022"
|
|
651
674
|
- "TPXO9-atlas-v5"
|
|
652
675
|
- "TPXO8-atlas"
|
|
653
676
|
- "EOT20"
|
|
@@ -670,6 +693,10 @@ def model_tides(
|
|
|
670
693
|
crs : str, optional
|
|
671
694
|
Input coordinate reference system for x and y coordinates.
|
|
672
695
|
Defaults to "EPSG:4326" (WGS84; degrees latitude, longitude).
|
|
696
|
+
crop : bool optional
|
|
697
|
+
Whether to crop tide model constituent files on-the-fly to
|
|
698
|
+
improve performance. Cropping will be performed based on a
|
|
699
|
+
1 degree buffer around all input points. Defaults to True.
|
|
673
700
|
method : string, optional
|
|
674
701
|
Method used to interpolate tidal constituents
|
|
675
702
|
from model files. Options include:
|
|
@@ -719,7 +746,7 @@ def model_tides(
|
|
|
719
746
|
Defaults to "long".
|
|
720
747
|
ensemble_models : list, optional
|
|
721
748
|
An optional list of models used to generate the ensemble tide
|
|
722
|
-
model if "ensemble" tide modelling is requested. Defaults to
|
|
749
|
+
model if "ensemble" tide modelling is requested. Defaults to
|
|
723
750
|
["FES2014", "TPXO9-atlas-v5", "EOT20", "HAMTIDE11", "GOT4.10",
|
|
724
751
|
"FES2012", "TPXO8-atlas-v1"].
|
|
725
752
|
**ensemble_kwargs :
|
|
@@ -781,6 +808,7 @@ def model_tides(
|
|
|
781
808
|
|
|
782
809
|
# Verify that all provided models are supported
|
|
783
810
|
valid_models = [
|
|
811
|
+
"FES2022",
|
|
784
812
|
"FES2014",
|
|
785
813
|
"TPXO9-atlas-v5",
|
|
786
814
|
"EOT20",
|
|
@@ -826,6 +854,7 @@ def model_tides(
|
|
|
826
854
|
_model_tides,
|
|
827
855
|
directory=directory,
|
|
828
856
|
crs=crs,
|
|
857
|
+
crop=crop,
|
|
829
858
|
method=method,
|
|
830
859
|
extrapolate=extrapolate,
|
|
831
860
|
cutoff=np.inf if cutoff is None else cutoff,
|
|
@@ -1072,6 +1101,7 @@ def pixel_tides(
|
|
|
1072
1101
|
The tide model or a list of models used to model tides, as
|
|
1073
1102
|
supported by the `pyTMD` Python package. Options include:
|
|
1074
1103
|
- "FES2014" (default; pre-configured on DEA Sandbox)
|
|
1104
|
+
- "FES2022"
|
|
1075
1105
|
- "TPXO8-atlas"
|
|
1076
1106
|
- "TPXO9-atlas-v5"
|
|
1077
1107
|
- "EOT20"
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|