- Documentation https://pymoto.readthedocs.io
- Examples gallery https://pymoto.readthedocs.io/en/latest/auto_examples/index.html
- Github repository https://github.com/aatmdelissen/pyMOTO
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...
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.
- Make sure you have Python running in some kind of virtual environment (e.g. uv, conda, miniconda, venv)
- Install the
pymotoPython package (and its dependencies)- Option A (pip): Type
pip install pymotointo your console to install (prepend withuvwhen usinguv) - Option B (conda): If you are working with Conda, install by
conda install -c aatmdelissen pymoto
- Option A (pip): Type
- Optional: Install Intel MKL library for a fast linear solver with
pip install mkl- This can also be achieved automatically by installing
pymotoaspip install pymoto[fast]
- This can also be achieved automatically by installing
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.pyin the console (prepend withuv runwhen usinguv)
When your research uses pymoto, please consider citing our Zenodo entry in any publications:
DOI:10.5281/zenodo.8138859.
- numpy - Dense linear algebra and solvers
- scipy - Sparse linear algebra and solvers
- sympy - Symbolic differentiation for
MathExpressionmodule - Matplotlib - Plotting and visualisation
- (optional) opt_einsum - Optimized function for
EinSummodule
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.
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.
- 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.
- Create a new branch to work the code, the branch can also be in your own fork of the repo.
- Work that code.
- Make sure all tests are passed (by running
pytest) and style is adhered - 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.
pyMOTO is available under te MIT License.

