Skip to main content

No project description provided

Project description

ltool

PyPI Python Versions PyPI Downloads License

Documentation: https://nikolaos-siomos.github.io/ltool/

ltool is a layer detection tool based on the Wavelet Covariance Transform (WCT) for lidar profile analysis.

It provides:

  • A programmatic Python API (get_layers)
  • A standalone CLI (ltool_standalone) for local processing
  • An SCC/server CLI (ltool_scc) for server-side processing using an .ini configuration
  • Export of retrieved layers to NetCDF and generation of diagnostic plots

Installation

From PyPI:

pip install ltool

For development:

pip install -e .

Quick start

Python API

from ltool.__ltool__ import get_layers

layer_obj = get_layers(
    height=height,
    sig=sig,
    sig_err=sig_err,
    method="optimized_prm",
)

print(layer_obj.layers)

Export and plots:

layer_obj.export_to_netcdf(dir_out="/path/to/output", save_netcdf=True)
layer_obj.visualize(dir_out="/path/to/output", save_plots=True)

Standalone CLI

Run on a directory of NetCDF files:

ltool_standalone \
  --input_path /absolute/path/to/data \
  --method optimized_prm \
  --save_plots \
  --save_netcdf

SCC/server CLI

ltool_scc \
  --measurement_id 123456 \
  --config_file /absolute/path/to/ltool.ini

Layer detection methods

The --method option controls how bases/tops are selected. Choices:

  • height_based
  • wct_based
  • snr_based
  • prm_based
  • optimized_wct
  • optimized_snr
  • optimized_prm (default)

See docs/methods/pairing.md for the full explanation.


Documentation (MkDocs)

Serve docs locally:

mkdocs serve

Build static site:

mkdocs build

Project layout

Recommended structure:

.
├── pyproject.toml
├── src/
│   └── ltool/
├── examples/
├── docs/
├── mkdocs.yml
└── .gitlab-ci.yml

Release (PyPI)

Build:

rm -rf dist build *.egg-info
python -m build

Upload:

python -m twine upload dist/*

License

This project is licensed under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE.


Contact

Maintainer: Nikolaos Siomos
LMU
Email: nikolaos.siomos@lmu.de

Project details


Download files

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

Source Distribution

ltool-2.0.0.tar.gz (64.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ltool-2.0.0-py3-none-any.whl (61.8 kB view details)

Uploaded Python 3

File details

Details for the file ltool-2.0.0.tar.gz.

File metadata

  • Download URL: ltool-2.0.0.tar.gz
  • Upload date:
  • Size: 64.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for ltool-2.0.0.tar.gz
Algorithm Hash digest
SHA256 bf2265579437f0f8e97694bd5c58ee9078c4a9d6353865183037799242587204
MD5 bc8e06f7f7fe6632666a2504de16462b
BLAKE2b-256 2b3406fcdebef59e9e4468b50a661cd4ad037a95f525b8d811bc3c0b3ff27508

See more details on using hashes here.

File details

Details for the file ltool-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: ltool-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 61.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for ltool-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3b211b089338dad3db5e24ded929dcfbe218c90f2297d53d6298aa5f73eb8d9a
MD5 e900f31745ee6ee9e2aa2009fb482a9c
BLAKE2b-256 c71e550b64717bf8fdeef0496eea6ce6510828cf5b2d101b640b5c551205ca40

See more details on using hashes here.

Supported by

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