Skip to main content

MERIDIAN Python package for ocean ambient noise modelling

Project description

Welcome to Kadlu, a Python package for modelling ocean ambient noise

Kadlu was developed for the purpose of modelling noise due to waves and rain in shallow coastal waters, but contains tools useful for many other underwater sound modelling tasks.

Kadlu is written in Python and utilizes a number of powerful software packages including NumPy, HDF5, NetCDF-4, and SQLite. It is licensed under the GNU GPLv3 license and hence freely available for anyone to use and modify. The project is hosted on GitLab at https://git-dev.cs.dal.ca/meridian/kadlu. Kadlu was developed by the MERIDIAN Data Analytics Team at the Institute for Big Data Analytics at Dalhousie University with the support and assistance of David Barclay and Calder Robinson, both from the Department of Oceanography at Dalhousie University.

Kadlu provides functionalities that automate the process of fetching and interpolating environmental data necessary to model ocean ambient noise levels (bathymetry, water temperature and salinity, wave height, wind speed, etc.). It also includes various routines that allow accurate estimates of noise source levels and transmission losses in realistic ocean environments. You can find more information about the technical aspects of how sound propagation is modelled in Kadlu in this note.

The intended users of Kadlu are researchers and students in underwater acoustics working with ambient noise modeling. While Kadlu comes with complete documentation and comprehensive step-by-step tutorials, some familiarity with Python and especially the NumPy package would be beneficial. A basic understanding of the physical principles of underwater sound propagation would also be an advantage.

For more information, please consult Kadlu's Documentation Page.

Installation

Kadlu runs on the most recent stable version of Python 3.

  1. ensure that GCC is installed. On Ubuntu, this can be done by installing the build-essential package if its not installed already

    sudo apt update 
    sudo apt install build-essential
    
  2. Install Kadlu using pip

    python -m pip install kadlu
    

Configuration

Optionally set the storage directory

Kadlu allows configuration for where data is stored on your machine. By default, a folder 'kadlu_data' will be created in the home directory. To specify a custom location, run the following:

import kadlu
kadlu.storage_cfg(setdir='/specify/desired/path/here/')

Optionally add an API token for fetching ERA5 data

Kadlu uses ECMWF's Era5 dataset as one of the data sources for wave height/direction/period and wind speed data. By default, an API token is included with kadlu, but if you intend to make frequent use of the Era5 dataset, please consider obtaining your own token. This can be obtained by registering an account at Copernicus API. Once logged in, your token and URL will be displayed on the aforementioned webpage under heading 'Install the CDS API key'. Additionally, you will need to accept the Copernicus Terms of Use to activate the token.

Configure Kadlu to use the token by executing:

kadlu.era5_cfg(key="TOKEN_HERE", url="URL_HERE")

Jupyter notebook tutorials

  1. The Ocean Module

  2. Fetch and Load Environmental Data

  3. Interpolate Multi-Dimensional Data

  4. Plot and Export Data

  5. Transmission Loss

Useful resources

  • gsw Python package (Python implementation of the Thermodynamic Equation of Seawater 2010)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

kadlu-2.3.7-py3-none-any.whl (91.9 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page