Skip to main content

SBArchOpt: Surrogate-Based Architecture Optimization

Project description

SBArchOpt: Surrogate-Based Architecture Optimization

Tests PyPI License status

GitHub Repository | Documentation

SBArchOpt (es-bee-ARK-opt) provides a set of classes and interfaces for applying Surrogate-Based Optimization (SBO) for system architecture optimization problems:

  • Expensive black-box problems: evaluating one candidate architecture might be computationally expensive
  • Mixed-discrete design variables: categorical architectural decisions mixed with continuous sizing variables
  • Hierarchical design variables: decisions can deactivate/activate (parts of) downstream decisions
  • Multi-objective: stemming from conflicting stakeholder needs
  • Subject to hidden constraints: simulation tools might not converge for all design points

Surrogate-Based Optimization (SBO) aims to accelerate convergence by fitting a surrogate model (e.g. regression, gaussian process, neural net) to the inputs (design variables) and outputs (objectives/constraints) to try to predict where interesting infill points lie. Potentially, SBO needs about one or two orders of magnitude less function evaluations than Multi-Objective Evolutionary Algorithms (MOEA's) like NSGA2. However, dealing with the specific challenges of architecture optimization, especially in a combination of the challenges, is not trivial. This library hopes to support in doing this.

The library provides:

  • A common interface for defining architecture optimization problems based on pymoo
  • Support in using Surrogate-Based Optimization (SBO) algorithms:
    • Implementation of a basic SBO algorithm
    • Connectors to various external SBO libraries
  • Analytical and realistic test problems that exhibit one or more of the architecture optimization challenges

Installation

First, create a conda environment (skip if you already have one):

conda create --name opt python=3.9
conda activate opt

Then install the package:

conda install numpy
pip install sb-arch-opt

Note: there are optional dependencies for the connected optimization frameworks and test problems. Refer to their documentation for dedicated installation instructions.

Documentation

Refer to the documentation for more background on SBArchOpt and how to implement architecture optimization problems. Test problem documentation can be found here: test problems

Optimization framework documentation:

See also the tutorials:

Contributing

The project is coordinated by: Jasper Bussemaker (jasper.bussemaker at dlr.de)

If you find a bug or have a feature request, please file an issue using the Github issue tracker. If you require support for using SBArchOpt or want to collaborate, feel free to contact me.

Contributions are appreciated too:

  • Fork the repository
  • Add your contributions to the fork
    • Update/add documentation
    • Add tests and make sure they pass (tests are run using pytest)
  • Read and sign the Contributor License Agreement (CLA) , and send it to the project coordinator
  • Issue a pull request

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

sb-arch-opt-1.1.3.tar.gz (117.6 kB view details)

Uploaded Source

Built Distribution

sb_arch_opt-1.1.3-py3-none-any.whl (166.9 kB view details)

Uploaded Python 3

File details

Details for the file sb-arch-opt-1.1.3.tar.gz.

File metadata

  • Download URL: sb-arch-opt-1.1.3.tar.gz
  • Upload date:
  • Size: 117.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.4

File hashes

Hashes for sb-arch-opt-1.1.3.tar.gz
Algorithm Hash digest
SHA256 ad2ea9af8349176bdad49938aa88dd232459ff92a3c504677f43b4cf94edf3f8
MD5 6ca6003982b175dd417ee9e8f380fa29
BLAKE2b-256 132805dd57965f122ee58b82e213b0baf0155b45849b902040c9d994cb41ca0c

See more details on using hashes here.

Provenance

File details

Details for the file sb_arch_opt-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: sb_arch_opt-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 166.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.4

File hashes

Hashes for sb_arch_opt-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 aa226e95d0df52d60e3af611b1cca257dd918147b74f1a899c2d37b7f591ae06
MD5 6e4486a7820f7986f1a46a7cf4138c52
BLAKE2b-256 62c2e94b5e9faa15a2cd3017a001b32baa28672f1bf4fb51b09b0db90132a43f

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page