Skip to main content

A modular approach to topology optimization

Project description

pyMOTO | Modular Topology Optimization in Python

10.5281/zenodo.8138859 anaconda.org/aatmdelissen/pymoto pypi.org/project/pyMOTO

3D Thermal heat-sink topology optimization

This python library offers modular and easily reconfigurable code to perform topology optimization. Already many ingredients and variations of topology optimization are implemented! Examples are:

  • Density filtering, robust formulations
  • 2D and 3D topology optimization
  • Static and dynamic structural mechanics
  • Compliant mechanisms
  • Thermal and thermo-mechanic coupling
  • Stress constraints
  • Multigrid preconditioning with conjugate-gradient solver
  • Various optimizers suited for topology optimization, such as Optimality Criteria (OC), Method of Moving Asymptotes (MMA), and its Globally Convergent version (GCMMA)
  • And more...

3D Mechanical MBB beam topology optimization

In pymoto a topology optimization problem is broken down into reusable sub-components (called Modules), such as density filter, finite-element assembly, linear solve, linear algebra, etc. Next to behaving like a function would (e.g. filtering the density field), a Module also implements design sensitivities (i.e. derivatives or gradients with respect to the inputs of that Module) of that operation. These are required for efficiently solving the topology optimization problem, but are usually very cumbersome to implement on the whole optimization problem. With pymoto however, the partial sensitivities are already implemented in each Module. When modules are linked together in pymoto, the chain rule is used to calculate the total sensitivities of the optimization problem (backpropagation). In essence it is a semi-automatic way of calculating design sensitivities.

Due to the modularity of the framework, existing modules can be reused and connected in different configurations without having to worry about sensitivity correctness. This allows for great flexibility in rearranging the modules, enabling a whole range of topology optimization problems even with a limited set of modules. If any functionality is not supported in a Module within the default pymoto library, a user can easily extend the framework by creating custom modules.

Quick start installation

  1. Make sure you have Python running in some kind of virtual environment (e.g. uv, conda, miniconda, venv)
  2. Install the pymoto Python package (and its dependencies)
    • Option A (pip): Type pip install pymoto into your console to install (prepend with uv when using uv)
    • Option B (conda): If you are working with Conda, install by conda install -c aatmdelissen pymoto
  3. Optional: Install Intel MKL library for a fast linear solver with pip install mkl
    • This can also be achieved automatically by installing pymoto as pip install pymoto[fast]

After installation, pymoto can be used.

  • Examples can be found and downloaded from the pyMOTO examples gallery
  • Run the example by typing python ex_name_of_the_example.py in the console (prepend with uv run when using uv)

Citing pyMOTO

When your research uses pymoto, please consider citing our Zenodo entry in any publications: DOI:10.5281/zenodo.8138859.

Dependencies

  • numpy - Dense linear algebra and solvers
  • scipy - Sparse linear algebra and solvers
  • sympy - Symbolic differentiation for MathExpression module
  • Matplotlib - Plotting and visualisation
  • (optional) opt_einsum - Optimized function for EinSum module

For fast linear solvers for sparse matrices:

  • (optional) mkl - Use the Intel OneAPI PARDISO solver (recommended)
  • (optional) scikit-umfpack - Fast LU linear solver based on UMFPACK
  • (optional) scikit-sparse - Fast Cholesky solver based on CHOLMOD
  • (optional) cvxopt - Another fast Cholesky solver based on CHOLMOD

Note on linear solvers for sparse matrices: Scipy implements a version of LU which is quite slow. To increase the speed of the optimization, mkl is recommended as it contains PARDISO, which is a very robust and flexible solver for any matrix (symmetric, asymmetric, real, or complex). An alternative is scikit-umfpack which provides a fast LU factorization. For symmetric matrices a Cholesky factorization can be used (not provided with Scipy), by either installing scikit-sparse or cvxopt.

Contributing

For development, a local installation of pymoto can be done by first downloading/cloning the entire git repo, and then calling pip install -e . in the pymoto folder (of course from within your virtual environment). This allows making changes to the pymoto code without having to reinstall.

You are now ready for a contribution to pymoto.

  1. Check the issues page to see if the subject you want to improve is listed:
    • If an issue already exists, add your view to the problem as a comment and let us know you are working on this.
    • Open a new issue if it is not listed, and discuss your ideas.
  2. Create a new branch to work the code, the branch can also be in your own fork of the repo.
  3. Work that code.
  4. Make sure all tests are passed (by running pytest) and style is adhered
  5. Create a pull request describing your changes

Thanks for your contribution! We will have it reviewed for it to be merged with the main code.

License

pyMOTO is available under te MIT License.

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

pymoto-2.0.0.tar.gz (96.2 kB view details)

Uploaded Source

Built Distribution

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

pymoto-2.0.0-py3-none-any.whl (109.5 kB view details)

Uploaded Python 3

File details

Details for the file pymoto-2.0.0.tar.gz.

File metadata

  • Download URL: pymoto-2.0.0.tar.gz
  • Upload date:
  • Size: 96.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pymoto-2.0.0.tar.gz
Algorithm Hash digest
SHA256 c3ff9ef39b40944340f17318a47243d7b0342d87a5235c15ff2d5302718e098f
MD5 f3efd761f9c8690744bd8059bb32dd17
BLAKE2b-256 b3682b550556e3bf212e8abd2a4f499d391d09fd82eeb96e9d811a8feeb5847b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymoto-2.0.0.tar.gz:

Publisher: publish.yaml on aatmdelissen/pyMOTO

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pymoto-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: pymoto-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 109.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pymoto-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 82ab314f0d4425164bdad66009abaa9cfe4ac1ad7e75448a1ea660ef57617cff
MD5 6d8fff1e5c3039e284f0c29d10df8a68
BLAKE2b-256 7d758e55823acfd7ca8a49b21e1d552361d3a9fa0d48c89b72aaa5a07d81d832

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymoto-2.0.0-py3-none-any.whl:

Publisher: publish.yaml on aatmdelissen/pyMOTO

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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