Skip to main content

Hierarchical experiment configuration and dependency injection using pure Python dataclass factories.

Project description

configgle🤭

Tools for making configurable Python classes for A/B experiements.

Installation

python -m pip install configgle

Example

from configgle import Fig

class Model:
    class Config(Fig["Model"]):
        hidden_size: int = 256
        num_layers: int = 4

    def __init__(self, config: Config):
        self.config = config

# Create and modify config
config = Model.Config(hidden_size=512)

# Instantiate the parent class
model = config.make()
print(model.config.hidden_size)  # 512

Or use @autofig to auto-generate the Config from __init__:

from configgle import autofig

@autofig
class Model:
    def __init__(self, hidden_size: int = 256, num_layers: int = 4):
        self.hidden_size = hidden_size
        self.num_layers = num_layers

# Config is auto-generated from __init__ signature
model = Model.Config(hidden_size=512).make()
print(model.hidden_size)  # 512

References

Why another config library? There are great options out there, but they either focus more on YAML or wrapper objects. The goal with configgle is a UX that's just simple Python--standard dataclasses, hierarchical, and class-local. No external files, no new syntax to learn.

The following libraries span these ideas but none wholly combine them:

  • Hydra - Framework for elegantly configuring complex applications
  • OmegaConf - Flexible hierarchical configuration system
  • Confugue - Hierarchical configuration with YAML-based object instantiation (most similar to configgle, but uses YAML rather than pure Python)
  • Fiddle - Python-first configuration library for ML
  • Gin Config - Lightweight configuration framework for Python
  • Sacred - Tool to configure, organize, log and reproduce experiments
  • ml_collections - Python collections designed for ML use cases

Citing

If you find our work useful, please consider citing:

@misc{dillon2026configgle,
      title={Configgle - Hierarchical experiment configuration using pure Python dataclass factories and dependency injection.},
      author={Joshua V. Dillon},
      year={2026},
      howpublished={Github},
      url={https://github.com/jvdillon/configgle},
}

License

Apache License 2.0

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

configgle-0.2.1.tar.gz (150.0 kB view details)

Uploaded Source

Built Distribution

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

configgle-0.2.1-py3-none-any.whl (27.0 kB view details)

Uploaded Python 3

File details

Details for the file configgle-0.2.1.tar.gz.

File metadata

  • Download URL: configgle-0.2.1.tar.gz
  • Upload date:
  • Size: 150.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for configgle-0.2.1.tar.gz
Algorithm Hash digest
SHA256 44df2a9a2c43485e24da5872f24867ebac868293aa1e417b5b2c30dc7fda3974
MD5 33b5cc70af5b7ba78b1da5d2c5559943
BLAKE2b-256 7b770fd0506809be3dc48a18cf2da6877fbca888e5803c92548bae977839990d

See more details on using hashes here.

File details

Details for the file configgle-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: configgle-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 27.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for configgle-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 413d4d23bd8ac00302a8112755f71235baf9039b820d843aa13a5da479871a95
MD5 7bb8a6c46fffcaf191e35f2606ecf2a1
BLAKE2b-256 1a809eac1aa69fd3aa54921bd853fbca0b4a9d8e7745c002a11518faf0ad0ee5

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