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
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.tar.gz.
File metadata
- Download URL: shoreline-0.2.tar.gz
- Upload date:
- Size: 36.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
400c1c5c171bd31c3354dc518d44f5cb42d3efced2103f13cfba0a1bb9c27eb0
|
|
| MD5 |
e32ca20e367e2c3dc4906c4d1ecf135e
|
|
| BLAKE2b-256 |
3ae8015d9a5aec620d51667208c78f8f8bdd8f3762616ba3ad6b6ae28357ce4e
|
Provenance
The following attestation bundles were made for shoreline-0.2.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.tar.gz -
Subject digest:
400c1c5c171bd31c3354dc518d44f5cb42d3efced2103f13cfba0a1bb9c27eb0 - Sigstore transparency entry: 244846886
- Sigstore integration time:
-
Permalink:
urschrei/naturescapes@5e90e4441ea3f37bc7c71d08174bf7c451970da4 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/urschrei
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
test.yml@5e90e4441ea3f37bc7c71d08174bf7c451970da4 -
Trigger Event:
push
-
Statement type:
File details
Details for the file shoreline-0.2-py3-none-any.whl.
File metadata
- Download URL: shoreline-0.2-py3-none-any.whl
- Upload date:
- Size: 35.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 |
962ebb2145634931b8243cf5ab72253ee81660600e651a5a0c4f07a1a582b802
|
|
| MD5 |
bd4a5c362cbf4f150e125215769407fe
|
|
| BLAKE2b-256 |
84016d0be7bd81235e97979926c507fca61584cd2673e6b3114aaa1f9549dc4b
|
Provenance
The following attestation bundles were made for shoreline-0.2-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-py3-none-any.whl -
Subject digest:
962ebb2145634931b8243cf5ab72253ee81660600e651a5a0c4f07a1a582b802 - Sigstore transparency entry: 244846891
- Sigstore integration time:
-
Permalink:
urschrei/naturescapes@5e90e4441ea3f37bc7c71d08174bf7c451970da4 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/urschrei
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
test.yml@5e90e4441ea3f37bc7c71d08174bf7c451970da4 -
Trigger Event:
push
-
Statement type: