Skip to main content

Parametrized hierarchical spaces with flexible priors and transformations.

Project description

ParameterSpace

Actions Status PyPI - Wheel PyPI - Python Version License: Apache-2.0 Code style: black

Contents:

About

A package to define parameter spaces consisting of mixed types (continuous, integer, categorical) with conditions and priors. It allows for easy specification of the parameters and their dependencies. The ParameterSpace object can then be used to sample random configurations from the prior and convert any valid configuration into a numerical representation. This numerical representation has the following properties:

  • it results in a Numpy ndarray of type float64
  • transformed representation between 0 and 1 (uniform) including integers, ordinal and categorical parameters
  • inactive parameters are masked as numpy.nan values

This allows to easily use optimizers that expect continuous domains to be used on more complicated problems because parameterspace can convert any numerical vector representation inside the unit hypercube into a valid configuration. The function might not be smooth, but for robust methods (like genetic algorithms/evolutionary strategies) this might still be valuable.

This software is a research prototype. The software is not ready for production use. It has neither been developed nor tested for a specific use case. However, the license conditions of the applicable Open Source licenses allow you to adapt the software to your needs. Before using it in a safety relevant setting, make sure that the software fulfills your requirements and adjust it according to any applicable safety standards (e.g. ISO 26262).

Documentation

Visit boschresearch.github.io/parameterspace

Installation

The parameterspace package can be installed from pypi.org:

pip install parameterspace

Development

Prerequisites

Setup environment

To install the package and its dependencies for development run:

poetry install

Optionally install pre-commit hooks to check code standards before committing changes:

poetry run pre-commit install

Running Tests

The tests are located in the ./tests folder. The pytest framework is used for running them. To run the tests:

poetry run pytest ./tests

Building Documentation

To built documentation run from the repository root:

poetry run mkdocs build --clean

For serving it locally while working on the documentation run:

poetry run mkdocs serve

Architectural Decision Records

Parameter Names

In the context of naming parameters and using their name to fix them to constant values or condition on them via lambda expressions, facing that only valid Python variable names can be used in conditions, and that fixing parameters that do not have a valid parameter name can only be done like fix(**{"invalid-variable:name": "const"}) we decided for requiring all parameter names to be valid Python variable names to achieve early failure and communication of that convention to avoid surprises when fixing and using conditions down the line, accepting that this rules out common parameter names like lambda and might require explicit translation between from and to contexts that require incompatible names (e.g. predefined benchmarks).

License

parameterspace is open-sourced under the Apache-2.0 license. See the LICENSE file for details.

For a list of other open source components included in parameterspace, see the file 3rd-party-licenses.txt.

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

parameterspace-0.10.1.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

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

parameterspace-0.10.1-py3-none-any.whl (37.1 kB view details)

Uploaded Python 3

File details

Details for the file parameterspace-0.10.1.tar.gz.

File metadata

  • Download URL: parameterspace-0.10.1.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.13.2 Linux/6.8.0-1021-azure

File hashes

Hashes for parameterspace-0.10.1.tar.gz
Algorithm Hash digest
SHA256 4c6cf5b1d5d30a04655f2b9bbdba6423b2ca2783a9fe4caf693024ec95ea926c
MD5 9c40523ff98bd3a009cf38a52705a47c
BLAKE2b-256 54516405a33ebd53aab480bc64a499a1f87f3e9c49170b9a34a1de38364f0319

See more details on using hashes here.

File details

Details for the file parameterspace-0.10.1-py3-none-any.whl.

File metadata

  • Download URL: parameterspace-0.10.1-py3-none-any.whl
  • Upload date:
  • Size: 37.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.1 CPython/3.13.2 Linux/6.8.0-1021-azure

File hashes

Hashes for parameterspace-0.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 978dc5985b960d96a225617fe9b161331b8a78da299cdd5ceaf43a5b168c038b
MD5 c703e4f6f8b2e34d0422c688a6fd3c81
BLAKE2b-256 5e651c8fa11a9c25e99d7a0abc7b82f45a57b5b43b30423bee00c3835d0646f9

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