Computational Adjoint-Based Shape Optimization and Optimal Control Software
Project description
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
- Optimal Control and general PDE constrained optimization
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 and Blauth - Version 2.0 - 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.
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 or later. 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. 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 paper
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
or use the following bibtex entry
@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},
}
For more details on how to cite cashocs please take a look at https://cashocs.readthedocs.io/en/stable/about/citing/.
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 researcher at Fraunhofer ITWM. I started developing cashocs during my PhD studies and have further developed and refined it as part of my employment at Fraunhofer ITWM. 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
Built Distribution
File details
Details for the file cashocs-2.3.1.tar.gz
.
File metadata
- Download URL: cashocs-2.3.1.tar.gz
- Upload date:
- Size: 278.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 34c2cd9e6805e7d1c964876b51ff959db10ad586b2c61c53591d8b473ff5516c |
|
MD5 | bbdd4b0643caab1b932035125abeac70 |
|
BLAKE2b-256 | 491ad371e5763284cb14cbe04692d6a5b39124377f72680c63a65752f5b5d5d8 |
Provenance
The following attestation bundles were made for cashocs-2.3.1.tar.gz
:
Publisher:
publish.yml
on sblauth/cashocs
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
cashocs-2.3.1.tar.gz
- Subject digest:
34c2cd9e6805e7d1c964876b51ff959db10ad586b2c61c53591d8b473ff5516c
- Sigstore transparency entry: 148609794
- Sigstore integration time:
- Predicate type:
File details
Details for the file cashocs-2.3.1-py3-none-any.whl
.
File metadata
- Download URL: cashocs-2.3.1-py3-none-any.whl
- Upload date:
- Size: 428.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 14dd0ccfadcd39b1f68f09e2e49550289e3eb4bd7a4b12f7f98a0bb910ded1e7 |
|
MD5 | 5de462a4b25976357432b5dfccb717b3 |
|
BLAKE2b-256 | c2c16152ba519690a74b263fbce224172f0c5f6d67374db1c718febcd072909d |
Provenance
The following attestation bundles were made for cashocs-2.3.1-py3-none-any.whl
:
Publisher:
publish.yml
on sblauth/cashocs
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
cashocs-2.3.1-py3-none-any.whl
- Subject digest:
14dd0ccfadcd39b1f68f09e2e49550289e3eb4bd7a4b12f7f98a0bb910ded1e7
- Sigstore transparency entry: 148609795
- Sigstore integration time:
- Predicate type: