Skip to main content

Dictionary-based, multi-dimensional parameter space iteration

Project description

The paramspace package is an open-source project and Python package that makes it possible to conveniently define dictionary-based, multi-dimensional parameter spaces and iterate over them.

Why?

In Python, dictionaries provide a powerful tool to control program behaviour. Frequently, these configuration structures take the shape of highly nested dictionaries, where each hierarchical level holds the information required at that point of the program.

However, it is frequently desired to instantiate some program not with a single set of parameters but with a set of parameters. Especially for scientific purposes, e.g. numerical simulations, it is often required to perform many instantiations of the same program with different parameters, so-called parameter sweeps. For simple configuration structures, this can be easily achieved by basic control flow tools; however, this becomes increasingly difficult the more parameters are desired to be sweeped over or the further nested they are in the configuration hierarchy.

This is where the paramspace package comes in.

How?

At its core, the paramspace package supplies the ParamSpace class, which accepts a dictionary-like object. To define parameter dimensions, individual entries within that dictionary can be replaced by a ParamDim object, regardless of the position and nestedness within the dictionary. The parameter space is then the cartesian product of all parameter dimensions, each parameter opening a new dimension of the parameter space.

When iterating over the space, each returned value is a dictionary with one combination of parameters, ready to be passed on to run the desired program. This allows retaining a hierarchical configuration structure while at the same time being able to conveniently perform sweeps over parameters, e.g. to spawn simulations with.

Furthermore, the paramspace package integrates tightly with YAML, making it very simple to define multidimensional parameter spaces directly in a configuration file.

Learn More

For more information, visit the project page and have a look at the README: https://gitlab.com/blsqr/paramspace

For use of paramspace, see utopya or the Utopia Project.

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

paramspace-2.6.1.tar.gz (43.1 kB view details)

Uploaded Source

Built Distribution

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

paramspace-2.6.1-py3-none-any.whl (45.9 kB view details)

Uploaded Python 3

File details

Details for the file paramspace-2.6.1.tar.gz.

File metadata

  • Download URL: paramspace-2.6.1.tar.gz
  • Upload date:
  • Size: 43.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for paramspace-2.6.1.tar.gz
Algorithm Hash digest
SHA256 61a029d9080cc2b02ea696f20fa0cfbb7f2dd821aef4e0457405bac0880aea1b
MD5 647e171855fe24dcb6be397087db44e6
BLAKE2b-256 ab4568a9e553ddb3e4cc5af6c8953cd5655382d522b43619b54ab7fc7550e249

See more details on using hashes here.

File details

Details for the file paramspace-2.6.1-py3-none-any.whl.

File metadata

  • Download URL: paramspace-2.6.1-py3-none-any.whl
  • Upload date:
  • Size: 45.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for paramspace-2.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7d3e9d11a4f30f97e65dfb5f98d15de1f83e4cb74c9ec9ebf0fe93b32a62271d
MD5 279da192b37b4f7bbf2b5ebdfc01c461
BLAKE2b-256 da44ec8bd522543d02a09c814e86e6f6cec08db6d7d2f1d50a47de5392b4d471

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