Object-based analysis functions for fractal dimensions and size distributions
Project description
Figure from DeWitt et al. (2025)
objscale
Object-based analysis functions for fractal dimensions and size distributions in atmospheric sciences and beyond. Optimized for large datasets.
Description
objscale provides computational tools for analyzing the scaling properties of objects in 2D binary arrays. The package consolidates methods for calculating size distributions and fractal dimensions that account for finite domain effects and complex boundary conditions. Originally developed for atmospheric science applications, these methods apply broadly to any field where object scaling properties matter.
The package implements methods from two main papers:
- DeWitt & Garrett (2024) - finite domain effects in size distributions
- DeWitt et al. (2025) - fractal dimensions for cloud field characterization
See the interactive scaling explorer to visualize how the correlation dimension is computed.
Key Functions
finite_array_powerlaw_exponent
Calculate power-law exponents for size distributions while accounting for finite domain truncation effects. Essential for accurate scaling analysis in bounded domains.
individual_fractal_dimension
Fractal dimension of individual objects using the perimeter-area relationship, with proper handling of interior holes and resolution effects.
individual_correlation_dimension
Correlation dimension of a single object. Isolates the Nth largest structure in an array (after removing border-touching structures) and computes its correlation dimension.
ensemble_correlation_dimension
Correlation dimension for characterizing the collective scaling properties of object ensembles. Uses point-pair correlation analysis across multiple length scales.
ensemble_box_dimension
Box-counting dimension for object ensembles. New analyses should prefer ensemble_correlation_dimension. Counts boxes containing object boundaries at varying spatial scales.
Installation
pip install objscale
Documentation
Complete API reference, detailed examples, and usage guides are available at objscale.readthedocs.io.
Agent Skill (Highly Recommended for Agents)
An agent skill is included in this repository. For Claude Code:
mkdir -p ~/.claude/skills/objscale
cp agent-skills/objscale/SKILL.md ~/.claude/skills/objscale/
Codex:
mkdir -p ~/.codex/skills/objscale
cp agent-skills/objscale/SKILL.md ~/.codex/skills/objscale/
Quick Example
import objscale
import numpy as np
# Create binary array (e.g., cloud mask, percolation lattice)
arrays = [(np.random.random((1000, 1000)) < 0.3).astype(int) for _ in range(4)]
# Size distribution with finite domain corrections
(exponent, error), (log10_sizes, log10_counts) = objscale.finite_array_powerlaw_exponent(
arrays, 'area', return_counts=True
)
# Ensemble fractal dimensions
corr_dim, corr_error = objscale.ensemble_correlation_dimension(arrays)
box_dim, box_error = objscale.ensemble_box_dimension(arrays)
# Individual object analysis
ind_dim, ind_error = objscale.individual_fractal_dimension(arrays)
Features
- Finite domain corrections: Proper handling of truncation effects at domain boundaries as recommended by DeWitt & Garrett (2024)
- Multiple size metrics: Area, perimeter, width, height, nested perimeter
- Arbitrary boundaries: Support for NaN-demarcated non-rectangular domains
- Individual and Ensemble methods: Characterize both individual and collective properties of object fields
- Performance optimized: Numba acceleration for computational efficiency. Can handle billions of individual objects on a mid-range laptop.
Requirements
- Python ≥ 3.8
- NumPy ≥ 1.20.0
- SciPy ≥ 1.7.0
- scikit-image ≥ 0.18.0
- Numba ≥ 0.56.0
Available Functions
Fractal Dimensions
individual_fractal_dimension- Fractal dimension of individual objects (perimeter-area scaling)individual_correlation_dimension- Correlation dimension of a single objectensemble_correlation_dimension- Correlation dimension for object ensemblesensemble_box_dimension- Box-counting dimension for object ensembles
Size Distributions
finite_array_powerlaw_exponent- Power-law exponents with finite domain correctionsfinite_array_size_distribution- Size distributions with truncation analysisarray_size_distribution- Basic size distribution for single arrays
Object Analysis
get_structure_areas- Calculate areas of structures (O(n), fast)get_structure_perimeters- Calculate perimeters of structures (O(n), fast)get_structure_height_width- Calculate height and width of structuresget_structure_props- Calculate perimeter, area, width, height of structures (wrapper)get_every_boundary_perimeter- Perimeters of every boundary including nested holestotal_perimeter- Total perimeter of all objectstotal_number- Count number of structuresisolate_nth_largest_structure- Extract the Nth largest connected structureremove_structures_touching_border_nan- Remove border-touching structuresremove_structure_holes- Fill holes in structureslabel_size- Label each structure with its size valuelabel_periodic_boundaries- Merge labels across periodic boundariesclear_border_adjacent- Clear structures touching array edges
Utilities
coarsen_array- Coarsen array resolution by averaginglinear_regression- Linear regression with error estimatesencase_in_value- Add border of specified value around arrayget_coords_of_boundaries- Find boundary pixel coordinates (toroidal topology)get_locations_from_pixel_sizes- Convert pixel size arrays to cumulative locationsset_num_threads- Set number of threads for parallel computations
For detailed parameter descriptions and usage examples, see the full documentation or use help(objscale.function_name) or objscale.function_name? in IPython/Jupyter.
Support Statement
This package consolidates research code developed over several years. While functional and tested, it should be considered research software with limited ongoing support. Users are encouraged to understand the underlying methods through the referenced papers before applying to their data.
References
If you use this package, please cite:
DeWitt, T. D. and Garrett, T. J.: Finite domains cause bias in measured and modeled distributions of cloud sizes, Atmos. Chem. Phys., 24, 8457–8472, https://doi.org/10.5194/acp-24-8457-2024, 2024.
Author
Thomas D. DeWitt University of Utah Department of Atmospheric Sciences
Sonnet 4 with Claude Code Anthropic
License
MIT License
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 objscale-1.2.0.tar.gz.
File metadata
- Download URL: objscale-1.2.0.tar.gz
- Upload date:
- Size: 28.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
54480a1642d592529875de3f5d73101f5499bc9b03d41f05dafda081a742ca36
|
|
| MD5 |
c5bea5307c2f4efa8be60585a2a84d9e
|
|
| BLAKE2b-256 |
4ebe6581e86e2ea3ae2b91d7648d6a7c705c5d7a4e99dd09c7422f55bd591690
|
File details
Details for the file objscale-1.2.0-py3-none-any.whl.
File metadata
- Download URL: objscale-1.2.0-py3-none-any.whl
- Upload date:
- Size: 28.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
46ad2c24e79e45e86c87b288eaf2e9670469bff8383282c96460ee3c771f951e
|
|
| MD5 |
e94d9d1e3ec3bf17a519f03d633ad173
|
|
| BLAKE2b-256 |
4b69a188921467cb9b005703e93c90ca10241bc82591cf9002b7411f7eccc5b2
|