Skip to main content

A package for tree disk rings detection in images

Project description

Tree Disk Rings

PyPI - Version

A Python package for analyzing tree rings in cross-sectional images. Originally forked from hmarichal93/cstrd_ipol.

Installation

pip install tree-disk-rings

Usage

Python API

import treediskrings

# Configure the analyzer
treediskrings.configure(
    input_image="input/tree-disk4.png",
    cx=1204,
    cy=1264,
    save_results=True,
)

# Run the analysis
(
    img_in,          # Original input image
    img_pre,         # Preprocessed image
    devernay_edges,  # Detected edges
    devernay_curves_f,  # Filtered curves
    devernay_curves_s,  # Smoothed curves
    devernay_curves_c,  # Connected curves
    devernay_curves_p,  # Final processed curves
) = treediskrings.run()

Command Line Interface (CLI)

Basic usage:

tree-disk-rings --input_image input/tree-disk4.png --cx 1204 --cy 1264

Save intermediate results:

tree-disk-rings --input_image input/tree-disk4.png --cx 1204 --cy 1264 --save_results

Advanced usage with custom parameters:

tree-disk-rings \
    --input_image input/F02c.png \
    --cx 1204 \
    --cy 1264 \
    --output_dir custom_output/ \
    --sigma 4.0 \
    --th_low 10 \
    --th_high 25 \
    --save_results \
    --debug

CLI Arguments

Argument Type Required Default Description
--input_image str Yes - Path to input image
--cx int Yes - Pith x-coordinate
--cy int Yes - Pith y-coordinate
--output_dir str No ./output Output directory path
--root str No Current dir Root directory of the repository
--sigma float No 3.0 Gaussian kernel parameter for edge detection
--th_low float No 5.0 Low threshold for gradient magnitude
--th_high float No 20.0 High threshold for gradient magnitude
--height int No 0 Height after resizing (0 to keep original)
--width int No 0 Width after resizing (0 to keep original)
--alpha float No 30.0 Edge filtering parameter (collinearity threshold)
--nr int No 360 Number of rays
--min_chain_length int No 2 Minimum chain length
--debug flag No False Enable debug mode
--save_results flag No False Save intermediate images, labelme and config file

Development

Setting up Development Environment

  1. Clone the repository:
git clone https://github.com/tuke307/tree-disk-rings.git
cd tree-disk-rings
  1. Create and activate virtual environment:
poetry install
poetry shell
  1. Compile the external C code:
cd ./externas/devernay_1.0 && make clean && make

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

tree_disk_rings-0.4.5.tar.gz (68.7 kB view details)

Uploaded Source

Built Distribution

tree_disk_rings-0.4.5-py3-none-any.whl (79.9 kB view details)

Uploaded Python 3

File details

Details for the file tree_disk_rings-0.4.5.tar.gz.

File metadata

  • Download URL: tree_disk_rings-0.4.5.tar.gz
  • Upload date:
  • Size: 68.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for tree_disk_rings-0.4.5.tar.gz
Algorithm Hash digest
SHA256 83751fee5daf36f17ac2b640f3ede934e5ac4e188eb1fc8a45cdc18de5a15a24
MD5 4cda02f7d2c631ceb9436cd56fd22894
BLAKE2b-256 808cf15ec223d0e44827b73f13a371af21cc9f6e542769a7ce09b4c46808c293

See more details on using hashes here.

Provenance

The following attestation bundles were made for tree_disk_rings-0.4.5.tar.gz:

Publisher: publish_rings.yml on tuke307/tree-disk-analyzer

Attestations:

File details

Details for the file tree_disk_rings-0.4.5-py3-none-any.whl.

File metadata

File hashes

Hashes for tree_disk_rings-0.4.5-py3-none-any.whl
Algorithm Hash digest
SHA256 e8b726b53b5e394c61b6fa25bb3746f50284f7974be5b5f984fbbecd9a0f6049
MD5 26529182f2be0ab58faf79635a27e411
BLAKE2b-256 2ced22e97bcf617ca3c03b4f9ec4563f5c6fc98b484ff025bcfddab288def1ba

See more details on using hashes here.

Provenance

The following attestation bundles were made for tree_disk_rings-0.4.5-py3-none-any.whl:

Publisher: publish_rings.yml on tuke307/tree-disk-analyzer

Attestations:

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