NATURESCAPES shoreline analysis
Project description
NATURESCAPES shoreline Package
This is the repo for the Naturescapes shoreline package and research notebooks.
Utilities for ray casting, working with LineString resolution, and clipping rays have been organized as a Python package in the src directory. The main interface is provided by the ShorelineAnalyzer class.
The minimum supported Python version is Python 3.10.
Usage (see shoreline.ipynb for example)
from shoreline import ShorelineAnalyzer
# Create a new analyzer
analyzer = ShorelineAnalyzer()
sa = ShorelineAnalyzer(
crs="EPSG:25829",
shoreline="geodata/ireland/gadm36_IRL_shp/gadm36_IRL_0.shp",
tideline="geodata/cleanup/Calculated Contours Backup/vorf_lat_simplified.gpkg",
hat=2.09,
lat=-2.44,
wave_period=3.0,
wave_height=2.0,
ray_resolution=10,
smoothing_window=500, # optional, defaults to 250
origin_angle=0, # angle at which waves travel towards LAT; 0 is north, positive is clockwise
origin_distance=1500 # distance in m from LAT bbox at which wave rays originate
)
analysis = sa.evaluate()
# we now have a result object containing analysis metadata (.metadata), as well as geometries
# and summary stats
# call help(analysis) for more
# we can plot results if we're using a notebook. pl is a tuple of Matplotlib figures
pl = analysis.visualise_coastal_slopes()
# this gives us a (map, stats) tuple. Each figure can be saved
pl[0].savefig("dublin.png", dpi=300, bbox_inches="tight")
# you can also call the analysis.summary_stats property
# the computed ray and slope DataFrame is available as analysis.ray_data
AnalysisResult Object Fields
The AnalysisResult object returned by sa.evaluate() contains the following fields:
Metadata
metadata: Dictionary containing analysis parameters including:timestamp: ISO format timestamp of analysisanalysis_crs: The coordinate reference system usedlat/hat: Lowest/Highest Astronomical Tide valueslat_crs/hat_crs: Original CRS of LAT/HAT datawave_period/wave_height: Wave parametersray_resolution: Resolution of ray casting in metressmoothing_window: Window size used for smoothing
Geometry Data
lat_line: GeoDataFrame containing the LAT (Lowest Astronomical Tide) lineshore_line: GeoDataFrame containing the HAT (Highest Astronomical Tide) shorelineorigin_rays: GeoDataFrame containing the original rays before intersectionslopes: GeoDataFrame containing the trimmed rays with calculated metrics (see below)shoaling: GeoDataFrame containing the line where waves begin shoalingbreaking: GeoDataFrame containing the line where waves breakintertidal: GeoDataFrame containing the intertidal zone polygonscore: GeoDataFrame containing a LineString with impact intensity scoresintersections: List of any ray intersections that were removed
The slopes DataFrame
This is the main analysis output containing trimmed rays with the following columns:
geometry: LineString geometries of rays from LAT to HATlength: Length of each ray in metresstart_depth/end_depth: Depths at LAT and HATslope: Gradient (rise/run)slope_degrees: Slope angle in degreesslope_radians: Slope angle in radiansslope_degrees_normalised: Normalised slope values (0-1)distance_to_breaking: Distance from HAT to breaking linedistance_to_shoaling: Distance from HAT to shoaling lineshoal_break_width: Width between shoaling and breaking linesdistance_to_breaking_normalised: Inverted normalised values (shorter = higher score)distance_to_shoaling_normalised: Inverted normalised values (shorter = higher score)shoal_break_width_normalised: Inverted normalised values (narrower = higher score)geom_mean_normalised: Geometric mean of the four normalised metrics, representing overall impact intensity (higher = more intense)
Summary Statistics
metrics: Array of calculated gradient metricsfriendly_metrics: Dictionary version of metrics with descriptive namespcbreaks: Percentile breakpoints used for visualisation [10, 25, 50, 75, 90, 95]
Methods
visualise_coastal_slopes(): Returns a tuple of (map_figure, stats_figure) for visualisationsummary_stats: Property that returns formatted summary statistics
Sample output from shoreline.ipynb (Dublin Bay)
Sample output of a ray intersecting isobaths ray_slope.ipynb
Installation
uv add shoreline or pip install shoreline
Installing for local development
This project is developed using uv, but should work with just pip. The use of a virtualenv is advised.
uv venv
source .venv/bin/activate
uv sync --all-extras
uv add --dev ipykernel
uv run ipython kernel install --user --env VIRTUAL_ENV $(pwd)/.venv --name=shoreline
uv run --with jupyter jupyter lab
When creating a notebook, select the shoreline kernel from the dropdown. Then use e.g. !uv add pydantic to add pydantic to the project's dependencies, or !uv pip install pydantic to install pydantic into the project's virtual environment without persisting the change to the project pyproject.toml or uv.lock files. Either command will make import pydantic work within the notebook
Anaconda
For Anaconda users: you will probably have to pull the requirements out of pyproject.toml. Sorry!
Testing
The smoothing algorithm is relatively well covered by tests (see tests/test_utils.py). Run pytest in the root dir in order to test if you'd like to tinker with it.
Data
Are in the geodata folder.
Copyright
Stephan Hügel / Naturescapes, 2025
Funding
The NATURESCAPES project is funded by the European Union under Grant Agreement No 10108434
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file shoreline-0.2.1.tar.gz.
File metadata
- Download URL: shoreline-0.2.1.tar.gz
- Upload date:
- Size: 38.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1c1633f768e1dbbdc2b1df674391dd0aedfc1b369e2acfc69a6679b7b73267ab
|
|
| MD5 |
55cffd605e5e2637146605a956daa0e6
|
|
| BLAKE2b-256 |
60858f960c54733c9b9c8ef262333cafe61177505e2be9890f3627a251a8b526
|
Provenance
The following attestation bundles were made for shoreline-0.2.1.tar.gz:
Publisher:
test.yml on urschrei/naturescapes
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shoreline-0.2.1.tar.gz -
Subject digest:
1c1633f768e1dbbdc2b1df674391dd0aedfc1b369e2acfc69a6679b7b73267ab - Sigstore transparency entry: 246543729
- Sigstore integration time:
-
Permalink:
urschrei/naturescapes@59ae87da062a35837c74ab89318e21c410268416 -
Branch / Tag:
refs/tags/v2.0.1 - Owner: https://github.com/urschrei
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
test.yml@59ae87da062a35837c74ab89318e21c410268416 -
Trigger Event:
push
-
Statement type:
File details
Details for the file shoreline-0.2.1-py3-none-any.whl.
File metadata
- Download URL: shoreline-0.2.1-py3-none-any.whl
- Upload date:
- Size: 36.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b9abd41d365e8a549df618801ddcae24642f839a7529adea9d014e103ddf7408
|
|
| MD5 |
8d8d636b997f31e9a27ba61db41ce6b6
|
|
| BLAKE2b-256 |
d2842eb168fd80e28b237ffcd591ea323a19c7a655161ebf9c59ed9d4b02edc3
|
Provenance
The following attestation bundles were made for shoreline-0.2.1-py3-none-any.whl:
Publisher:
test.yml on urschrei/naturescapes
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shoreline-0.2.1-py3-none-any.whl -
Subject digest:
b9abd41d365e8a549df618801ddcae24642f839a7529adea9d014e103ddf7408 - Sigstore transparency entry: 246543733
- Sigstore integration time:
-
Permalink:
urschrei/naturescapes@59ae87da062a35837c74ab89318e21c410268416 -
Branch / Tag:
refs/tags/v2.0.1 - Owner: https://github.com/urschrei
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
test.yml@59ae87da062a35837c74ab89318e21c410268416 -
Trigger Event:
push
-
Statement type: