SBArchOpt

SBArchOpt: Surrogate-Based Architecture Optimization - Published in JOSS (2023)

https://github.com/jbussemaker/sbarchopt

Science Score: 100.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
    Found CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 6 DOI reference(s) in README and JOSS metadata
  • Academic publication links
    Links to: joss.theoj.org
  • Committers with academic emails
    1 of 3 committers (33.3%) from academic institutions
  • Institutional organization owner
  • JOSS paper metadata
    Published in Journal of Open Source Software

Keywords

architecture multi-objective optimization sbo system

Scientific Fields

Economics Social Sciences - 40% confidence
Last synced: 4 months ago · JSON representation ·

Repository

Surrogate-Based Architecture Optimization toolbox

Basic Info
Statistics
  • Stars: 16
  • Watchers: 2
  • Forks: 4
  • Open Issues: 2
  • Releases: 13
Topics
architecture multi-objective optimization sbo system
Created almost 3 years ago · Last pushed 5 months ago
Metadata Files
Readme License Citation

README.md

SBArchOpt Logo

SBArchOpt: Surrogate-Based Architecture Optimization

Tests PyPI License JOSS Documentation 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.11 conda activate opt

Then install the package: conda install "numpy<2.0" 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.

Citing

If you use SBArchOpt in your work, please cite it:

Bussemaker, J.H., (2023). SBArchOpt: Surrogate-Based Architecture Optimization. Journal of Open Source Software, 8(89), 5564, DOI: 10.21105/joss.05564

Bussemaker, J.H., et al., (2024). Surrogate-Based Optimization of System Architectures Subject to Hidden Constraints. In AIAA AVIATION 2024 FORUM. Las Vegas, NV, USA. DOI: 10.2514/6.2024-4401

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 into the dev branch

Adding Documentation

pip install -r requirements-docs.txt mkdocs serve

Refer to mkdocs and mkdocstrings documentation for more information.

Owner

  • Login: jbussemaker
  • Kind: user

Researcher at the German Aerospace Center (DLR).

JOSS Publication

SBArchOpt: Surrogate-Based Architecture Optimization
Published
September 07, 2023
Volume 8, Issue 89, Page 5564
Authors
Jasper H. Bussemaker ORCID
Institute of System Architectures in Aeronautics, German Aerospace Center (DLR), Hamburg, Germany
Editor
Vissarion Fisikopoulos ORCID
Tags
optimization engineering system architecture optimization MBSE surrogate-based optimization Bayesian optimization multi-objective optimization

Citation (CITATION.cff)

cff-version: "1.2.0"
authors:
- family-names: Bussemaker
  given-names: Jasper H.
  orcid: "https://orcid.org/0000-0002-5421-6419"
doi: 10.5281/zenodo.8318765
message: If you use this software, please cite our article in the
  Journal of Open Source Software.
preferred-citation:
  authors:
  - family-names: Bussemaker
    given-names: Jasper H.
    orcid: "https://orcid.org/0000-0002-5421-6419"
  date-published: 2023-09-07
  doi: 10.21105/joss.05564
  issn: 2475-9066
  issue: 89
  journal: Journal of Open Source Software
  publisher:
    name: Open Journals
  start: 5564
  title: "SBArchOpt: Surrogate-Based Architecture Optimization"
  type: article
  url: "https://joss.theoj.org/papers/10.21105/joss.05564"
  volume: 8
title: "SBArchOpt: Surrogate-Based Architecture Optimization"

GitHub Events

Total
  • Release event: 3
  • Watch event: 2
  • Push event: 9
  • Pull request event: 5
  • Create event: 3
Last Year
  • Release event: 3
  • Watch event: 2
  • Push event: 9
  • Pull request event: 5
  • Create event: 3

Committers

Last synced: 5 months ago

All Time
  • Total Commits: 407
  • Total Committers: 3
  • Avg Commits per committer: 135.667
  • Development Distribution Score (DDS): 0.076
Past Year
  • Commits: 12
  • Committers: 1
  • Avg Commits per committer: 12.0
  • Development Distribution Score (DDS): 0.0
Top Committers
Name Email Commits
Jasper Bussemaker j****r@d****e 376
Paul-Saves p****s@a****r 20
relf r****e@o****r 11
Committer Domains (Top 20 + Academic)

Issues and Pull Requests

Last synced: 4 months ago

All Time
  • Total issues: 7
  • Total pull requests: 25
  • Average time to close issues: 1 day
  • Average time to close pull requests: 9 days
  • Total issue authors: 2
  • Total pull request authors: 5
  • Average comments per issue: 1.71
  • Average comments per pull request: 0.32
  • Merged pull requests: 20
  • Bot issues: 0
  • Bot pull requests: 1
Past Year
  • Issues: 0
  • Pull requests: 5
  • Average time to close issues: N/A
  • Average time to close pull requests: about 5 hours
  • Issue authors: 0
  • Pull request authors: 2
  • Average comments per issue: 0
  • Average comments per pull request: 0.0
  • Merged pull requests: 4
  • Bot issues: 0
  • Bot pull requests: 1
Top Authors
Issue Authors
  • athulpg007 (5)
  • vissarion (1)
Pull Request Authors
  • jbussemaker (26)
  • Paul-Saves (8)
  • relf (2)
  • dependabot[bot] (1)
  • danielskatz (1)
Top Labels
Issue Labels
Pull Request Labels
dependencies (1) github_actions (1)

Dependencies

.github/workflows/publish.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
  • pypa/gh-action-pypi-publish release/v1 composite
.github/workflows/tests.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
.github/workflows/tests_basic.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
.github/workflows/tests_slow.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
pyproject.toml pypi
requirements-assignment.txt pypi
  • assign_enc *
requirements-docs.txt pypi
  • mkdocs *
  • mkdocs-jupyter *
  • mkdocs-material *
  • mkdocstrings *
requirements-hebo.txt pypi
requirements-ota.txt pypi
  • open_turb_arch pymoo_optional
requirements-tests.txt pypi
  • matplotlib * test
  • pytest * test
  • testbook * test
setup.py pypi
  • ConfigSpace *
  • cached-property *
  • deprecated *
  • more-itertools *
  • numpy *
  • pandas *
  • pymoo *
  • scipy *