Skip to main content

Tool for climate data research

Project description

🌍 climatrix


Climatrix is a flexible toolbox for sampling and reconstructing climate datasets.

It provides utilities and an xarray accessor that simplifies the workflow of working with climate data arrays — from preprocessing to statistical sampling.


👤 Author


👥 Contributors


📌 Version

Important This is an alpha release – features are still evolving, and breaking changes may occur.


📚 Table of Contents


⚙️ Usage

Getting started and API reference are available in the official documentation.


🧪 Examples

🔍 Click to expand example: Accessing `climatrix` features
import climatrix as cm
import xarray as xr

my_dataset = "/file/to/netcdf.nc
cm_dset = xr.open_dataset(my_dataset).cm
📊 Click to expand example: Getting values of coordinate
import climatrix as cm
import xarray as xr

my_dataset = "/file/to/netcdf.nc"
cm_dset = xr.open_dataset(my_dataset).cm
print("Latitude values: ", cm_dset.latitude)
print("Time values: ", cm_dset.time)
📊 Subsetting by bounding box
import climatrix as cm
import xarray as xr

my_dataset = "/file/to/netcdf.nc
cm_dset = xr.open_dataset(my_dataset).cm
europe = cm_dset.cm.subset(north=71, south=36, west=-24, east=35)

🛠️ Features

  • 🧭 Easy access to coordinate data (similar to MetPy), using regex to locate lat/lon
  • 📊 Sampling of climate data, both uniformly and using normal-like distributions
  • 🔁 Reconstruction via:
    • IDW (Inverse Distance Weighting)
    • Ordinary Kriging
    • SIREN (Sinusoidal INR)
  • 🧪 Tools to compare reconstruction results
  • 📈 Plotting utilities for visualizing inputs and outputs
  • 🔧 Hyperparameter Optimization

🔧 Hyperparameter Optimization

Climatrix provides automated hyperparameter optimization for all reconstruction methods using Bayesian optimization. The HParamFinder class offers an intuitive interface for finding optimal parameters.

Quick Start

from climatrix.optim import HParamFinder

# Basic usage - optimize IDW parameters
finder = HParamFinder(train_dataset, validation_dataset, method="idw")
result = finder.optimize()
best_params = result['best_params']

# Use optimized parameters for reconstruction
optimized_reconstruction = train_dataset.reconstruct(
    target=test_domain,
    method="idw", 
    **best_params
)

Advanced Usage

# Optimize specific parameters only
finder = HParamFinder(
    train_dataset, validation_dataset,
    method="sinet",
    include=["lr", "batch_size"],     # Only optimize these parameters
    exclude=["k"],                    # Or exclude specific parameters  
    metric="rmse",                    # Optimization metric (mae, mse, rmse)
    explore=0.7,                      # Exploration vs exploitation (0-1)
    n_iters=50,                       # Total optimization iterations
    random_seed=123                   # For reproducible results
)

result = finder.optimize()
print(f"Best parameters: {result['best_params']}")
print(f"Best {result['metric_name']} score: {result['best_score']}")

Installation

The hyperparameter optimization feature requires the bayesian-optimization package:

pip install climatrix[optim]

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

👥 Contributing

The rules for contributing on the project are described in CONTRIBUTING file in details.


🙏 Citation

If you are using this software in scientific work, cite us:

@article{walczak2025climatrix,
  title={Climatrix: Xarray accessor for climate data sampling and reconstruction},
  author={Walczak, Jakub and {\.Z}yndul, Wojciech},
  journal={SoftwareX},
  volume={31},
  pages={102263},
  year={2025},
  publisher={Elsevier}
}

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

climatrix-1.0a21.tar.gz (6.0 MB view details)

Uploaded Source

Built Distribution

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

climatrix-1.0a21-py3-none-any.whl (134.4 kB view details)

Uploaded Python 3

File details

Details for the file climatrix-1.0a21.tar.gz.

File metadata

  • Download URL: climatrix-1.0a21.tar.gz
  • Upload date:
  • Size: 6.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for climatrix-1.0a21.tar.gz
Algorithm Hash digest
SHA256 907f9c40fc5e5d29e3e0ea6965e7a704eb3da8587cd07cca569a3c5346cebe67
MD5 9d99972dfadf5726e07dc3cc92cf41a9
BLAKE2b-256 943d2ca0780c5db440ea67593713d4e400c638dac55b6c1679ea62bf3346b6bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for climatrix-1.0a21.tar.gz:

Publisher: release_pypi.yml on jamesWalczak/climatrix

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file climatrix-1.0a21-py3-none-any.whl.

File metadata

  • Download URL: climatrix-1.0a21-py3-none-any.whl
  • Upload date:
  • Size: 134.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for climatrix-1.0a21-py3-none-any.whl
Algorithm Hash digest
SHA256 79ac0d8111d3c278f48b8e56ad37c976341a0afe390213eb2fc88a2896775b37
MD5 2ce39d13b5aa86c0ca814058e19e3542
BLAKE2b-256 21cb498ae2b5d0933e85299e75e4dfd35b0e5e2e3e160ee303fff4e9dcbfc6ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for climatrix-1.0a21-py3-none-any.whl:

Publisher: release_pypi.yml on jamesWalczak/climatrix

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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