Skip to main content

Computational Adjoint-Based Shape Optimization and Optimal Control Software

Project description

https://raw.githubusercontent.com/sblauth/cashocs/main/logos/cashocs_banner.jpg https://img.shields.io/pypi/v/cashocs?style=flat-square https://img.shields.io/conda/vn/conda-forge/cashocs?style=flat-square https://img.shields.io/pypi/pyversions/cashocs?style=flat-square https://img.shields.io/badge/DOI-10.5281%2Fzenodo.4035939-informational?style=flat-square https://img.shields.io/pypi/l/cashocs?color=informational&style=flat-square https://img.shields.io/pypi/dm/cashocs?color=informational&style=flat-square

https://img.shields.io/github/actions/workflow/status/sblauth/cashocs/tests.yml?branch=main&label=tests&style=flat-square https://img.shields.io/codecov/c/gh/sblauth/cashocs?color=brightgreen&style=flat-square https://img.shields.io/codacy/grade/4debea4be12c495391e1310025851e55?style=flat-square https://readthedocs.org/projects/cashocs/badge/?version=latest&style=flat-square https://img.shields.io/badge/code%20style-black-000000.svg?style=flat-square

cashocs is a finite element software for the automated solution of shape optimization and optimal control problems. It is used to solve problems in fluid dynamics and multiphysics contexts. Its name is an acronym for computational adjoint-based shape optimization and optimal control software and the software is written in Python.

Introduction

cashocs is based on the finite element package FEniCS and uses its high-level unified form language UFL to treat general PDE constrained optimization problems, in particular, shape optimization and optimal control problems.

For some applications and further information about cashocs, we also refer to the website Fluid Dynamical Shape Optimization with cashocs.

Note, that we assume that you are (at least somewhat) familiar with PDE constrained optimization and FEniCS. For a introduction to these topics, we can recommend the textbooks

However, the cashocs tutorial also gives many references either to the underlying theory of PDE constrained optimization or to relevant demos and documentation of FEniCS.

An overview over cashocs and its capabilities can be found in Blauth - cashocs: A Computational, Adjoint-Based Shape Optimization and Optimal Control Software. Moreover, note that the full cashocs documentation is available at https://cashocs.readthedocs.io/en/latest.

Installation

Via conda-forge

cashocs is available via the anaconda package manager, and you can install it with

conda install -c conda-forge cashocs

Alternatively, you might want to create a new, clean conda environment with the command

conda create -n <ENV_NAME> -c conda-forge cashocs

where <ENV_NAME> is the desired name of the new environment.

Manual Installation

  • First, install FEniCS, version 2019.1. Note that FEniCS should be compiled with PETSc and petsc4py.

  • Then, install meshio, with a h5py version that matches the HDF5 version used in FEniCS, and matplotlib. The version of meshio should be at least 4, but for compatibility it is recommended to use meshio 4.4.

  • You might also want to install Gmsh, version 4.8. cashocs does not necessarily need this to work properly, but it is required for the remeshing functionality.

  • You can install cashocs via the PYPI as follows

    pip3 install cashocs
  • You can install the newest (development) version of cashocs with

    pip3 install git+https://github.com/sblauth/cashocs.git
  • To get the latest (development) version of cashocs, clone this repository with git and install it with pip

    git clone https://github.com/sblauth/cashocs.git
    cd cashocs
    pip3 install .

Usage

The complete cashocs documentation is available here https://cashocs.readthedocs.io/en/latest. For a detailed introduction, see the cashocs tutorial. The python source code for the demo programs is located inside the “demos” folder.

Citing

If you use cashocs for your research, please cite the following papers

cashocs: A Computational, Adjoint-Based Shape Optimization and Optimal Control Software
Sebastian Blauth
SoftwareX, Volume 13, 2021
https://doi.org/10.1016/j.softx.2020.100646

as well as

Version 2.0 - cashocs: A Computational, Adjoint-Based Shape Optimization and Optimal Control Software
Sebastian Blauth
SoftwareX, Volume 24, 2023
https://doi.org/10.1016/j.softx.2023.101577

Additionally, if you are using the nonlinear conjugate gradient methods for shape optimization implemented in cashocs, please cite the following paper

Nonlinear Conjugate Gradient Methods for PDE Constrained Shape Optimization Based on Steklov--Poincaré-Type Metrics
Sebastian Blauth
SIAM Journal on Optimization, Volume 31, Issue 3, 2021
https://doi.org/10.1137/20M1367738

If you are using the space mapping methods for shape optimization, please cite the paper

Space Mapping for PDE Constrained Shape Optimization
Sebastian Blauth
SIAM Journal on Optimization, Volume 33, Issue 3, 2023
https://doi.org/10.1137/22M1515665

and if you are using the topology optimization methods implemented in cashocs, please cite the paper

Quasi-Newton Methods for Topology Optimization Using a Level-Set Method
Sebastian Blauth and Kevin Sturm
Structural and Multidisciplinary Optimization, Volume 66, 2023
https://doi.org/10.1007/s00158-023-03653-2

If you are using BibTeX, you can use the following entries

@Article{Blauth2021cashocs,
  author   = {Sebastian Blauth},
  journal  = {SoftwareX},
  title    = {{cashocs: A Computational, Adjoint-Based Shape Optimization and Optimal Control Software}},
  year     = {2021},
  issn     = {2352-7110},
  pages    = {100646},
  volume   = {13},
  doi      = {https://doi.org/10.1016/j.softx.2020.100646},
  keywords = {PDE constrained optimization, Adjoint approach, Shape optimization, Optimal control},
}
@Article{Blauth2023Version,
  author   = {Sebastian Blauth},
  journal  = {SoftwareX},
  title    = {{Version 2.0 - cashocs: A Computational, Adjoint-Based Shape Optimization and Optimal Control Software}},
  year     = {2023},
  issn     = {2352-7110},
  pages    = {101577},
  volume   = {24},
  doi      = {https://doi.org/10.1016/j.softx.2023.101577},
  keywords = {PDE constrained optimization, Shape optimization, Topology optimization, Space mapping},
}
@Article{Blauth2021Nonlinear,
  author   = {Sebastian Blauth},
  journal  = {SIAM J. Optim.},
  title    = {{Nonlinear Conjugate Gradient Methods for PDE Constrained Shape Optimization Based on Steklov-Poincaré-Type Metrics}},
  year     = {2021},
  number   = {3},
  pages    = {1658--1689},
  volume   = {31},
  doi      = {10.1137/20M1367738},
  fjournal = {SIAM Journal on Optimization},
}
@Article{Blauth2023Space,
  author   = {Blauth, Sebastian},
  journal  = {SIAM J. Optim.},
  title    = {{Space Mapping for PDE Constrained Shape Optimization}},
  year     = {2023},
  issn     = {1052-6234,1095-7189},
  number   = {3},
  pages    = {1707--1733},
  volume   = {33},
  doi      = {10.1137/22M1515665},
  fjournal = {SIAM Journal on Optimization},
  mrclass  = {49Q10 (35Q93 49M41 65K05)},
  mrnumber = {4622415},
}
@Article{Blauth2023Quasi,
  author   = {Blauth, Sebastian and Sturm, Kevin},
  journal  = {Struct. Multidiscip. Optim.},
  title    = {{Quasi-Newton methods for topology optimization using a level-set method}},
  year     = {2023},
  issn     = {1615-147X,1615-1488},
  number   = {9},
  pages    = {203},
  volume   = {66},
  doi      = {10.1007/s00158-023-03653-2},
  fjournal = {Structural and Multidisciplinary Optimization},
  mrclass  = {99-06},
  mrnumber = {4635978},
}

License

cashocs is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

cashocs is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with cashocs. If not, see https://www.gnu.org/licenses/.

Contact / About

I’m Sebastian Blauth, a scientific employee at Fraunhofer ITWM. I have developed this project as part of my PhD thesis. If you have any questions / suggestions / feedback, etc., you can contact me via sebastian.blauth@itwm.fraunhofer.de. For more information, visit my website at https://sblauth.github.io/.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cashocs-2.1.2.tar.gz (265.7 kB view details)

Uploaded Source

Built Distribution

cashocs-2.1.2-py3-none-any.whl (407.9 kB view details)

Uploaded Python 3

File details

Details for the file cashocs-2.1.2.tar.gz.

File metadata

  • Download URL: cashocs-2.1.2.tar.gz
  • Upload date:
  • Size: 265.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for cashocs-2.1.2.tar.gz
Algorithm Hash digest
SHA256 128c025882b7f6a0d2da6104c61911c15e748ff41f82ff79ed39c974d31106a9
MD5 daea3e9420b3320158a174bd63ee8642
BLAKE2b-256 6abe1703c580ada6836d206071d6f58480188c7c006f732eaa61c3908eff0da0

See more details on using hashes here.

File details

Details for the file cashocs-2.1.2-py3-none-any.whl.

File metadata

  • Download URL: cashocs-2.1.2-py3-none-any.whl
  • Upload date:
  • Size: 407.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for cashocs-2.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 70b0e1b93c4721b02a64b67dba1147bb846464a16f6797543865c04c9b3f4a33
MD5 207d3dc74132fa7e6e6ccf58d3ae5477
BLAKE2b-256 d109c9116d041cedd3d5b75088f3b7c7672a48a0fdfe6cad273826f27a11c14e

See more details on using hashes here.

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