Skip to main content

A lightweight, flexible Python library for topology optimization built on top of Scikit Libraries

Project description

PyPI version License: Apache-2.0 DOI status Python Version PyPI Downloads CI CI

🧠 Scikit Topt

A lightweight, flexible Python library for topology optimization built on top of Scikit Libraries

Documentation

Scikit-Topt Documentation

Examples and Features

Example 1 : Single Load Condition

Optimization Process Pull-Down-0 Optimization Process Pull-Down-1

Example 2 : Multiple Load Condition

multi-load-condition multi-load-condition-distribution

Example 3 : Heat Conduction

heat-conduction heat-conduction

Progress Report

multi-load-condition-progress

Features

To contribute to the open-source community and education—which I’ve always benefited from—I decided to start this project.

The currently supported features are as follows:

  • Coding with Python
  • easy installation with pip/poetry
  • Implement FEA on unstructured mesh using scikit-fem
  • Structural Analysis / Heat Conduction Analysis
  • Topology optimization using the density method and its optimization algorithm
    • Optimality Criteria (OC) Method
    • (Log-Space) Modified OC Method
  • able to handle multiple force condition
  • High-performance computation using sparse matrices with Scipy and PyAMG
  • has a function to monitor the transition of parameters.

SetUp

You can install Scikit-Topt either via pip or Poetry.

Supported Python Versions

Scikit-Topt supports Python 3.10–3.13:

  • 3.10–3.12 — fully supported and tested
  • 3.13 — core topology optimization works normally,
    but VTK-based features (VTU export & image rendering using PyVista)
    are temporarily unavailable because VTK/PyVista do not yet provide wheels
    for Python 3.13.

You can still run the full optimization workflow on Python 3.13;
only visualization-related features are restricted.

Choose one of the following methods:

Using pip

pip install scikit-topt

With PETSc support:

pip install "scikit-topt[petsc4py]"

The legacy alias below is also available:

pip install "scikit-topt[petsc]"

Using poetry

poetry add scikit-topt

With PETSc support:

poetry add scikit-topt -E petsc4py

petsc4py requires a working PETSc installation. If PETSc is not already available on your system, install PETSc first and then install the extra above.

PETSc Runtime Setup

The petsc4py extra installs the Python bindings only. At runtime, PETSc shared libraries must also be discoverable by your Python environment.

Common environment variables are:

  • PETSC_DIR: PETSc installation root
  • PETSC_ARCH: PETSc build architecture name
  • LD_LIBRARY_PATH: shared-library search path on Linux

Typical Linux example:

export PETSC_DIR=/path/to/petsc
export PETSC_ARCH=arch-linux-c-opt
export LD_LIBRARY_PATH="$PETSC_DIR/$PETSC_ARCH/lib:$LD_LIBRARY_PATH"

If PETSc was installed by a package manager or a preconfigured HPC module, these variables may already be set for you. In that case, no extra manual setup is needed.

You can validate the runtime with:

python -c "from petsc4py import PETSc; print(PETSc.Sys.getVersion())"

If Scikit-Topt cannot load PETSc, first check that:

  • petsc4py imports successfully
  • the PETSc shared libraries are visible in your library search path
  • PETSC_DIR and PETSC_ARCH point to the same PETSc build used for petsc4py

Optional: Enable off-screen rendering

If you want to visualize the optimized density distribution with mesh as an image, you need to enable off-screen rendering using a virtual display.

On Debian/Ubuntu:

sudo apt install xvfb libgl1-mesa-glx

CentOS / RHL

sudo yum install xvfb libgl1-mesa-glx

Usage

See examples in example directory and README.md. README for Usage Examples

Algorithm for Optimization

Optimization Algorithms and Techniques are briefly summarized here.
Optimization Algorithms and Techniques

Contributing

We are happy to welcome any contributions to the library. You can contribute in various ways:

  • Reporting bugs, opening pull requests, or starting discussions via GitHub Issues
  • Writing new examples
  • Improving the tests
  • Enhancing the documentation or code readability doc

By contributing code to Scikit-Topt, you agree to release it under the Apache 2.0 License.

Acknowledgements

Standing on the shoulders of proverbial giants

This software does not exist in a vacuum. Scikit-Topt is standing on the shoulders of proverbial giants. In particular, I want to thank the following projects for constituting the technical backbone of the project:

  • Scipy
  • Scikit-fem
  • PyAMG
  • Numba
  • MeshIO
  • Matplotlib
  • PyVista
  • Topology Optimization Community

📖 Citation

If you use Scikit Topt in your research or software, please cite it as:

@article{Watanabe_Scikit-Topt_A_Python_2025,
author = {Watanabe, Kohei},
doi = {10.21105/joss.09092},
journal = {Journal of Open Source Software},
number = {116},
title = {{Scikit-Topt: A Python Library for Algorithm Development in Topology Optimization}},
volume = {10},
year = {2025}
}

ToDo

  • Set break point from the optimization loop
  • Add A feature to assign tags to nodes and cells
  • Add Level Set
  • Add other optimizers
    • Evolutionary Algorithms
    • MMA
  • Add Multiple BC Conditions
  • Add Unit Test

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

scikit_topt-0.3.9.tar.gz (87.9 kB view details)

Uploaded Source

Built Distribution

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

scikit_topt-0.3.9-py3-none-any.whl (101.4 kB view details)

Uploaded Python 3

File details

Details for the file scikit_topt-0.3.9.tar.gz.

File metadata

  • Download URL: scikit_topt-0.3.9.tar.gz
  • Upload date:
  • Size: 87.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for scikit_topt-0.3.9.tar.gz
Algorithm Hash digest
SHA256 808067d5a9b0ad3e3b6353ce789b5d9efa730c5a2976d8650de3db5c54b16df5
MD5 ca1807b4a627e59f9994aab402c7c4b0
BLAKE2b-256 d053d41a077ce43914e8dd4e534c9f0c8f33302048716e17f9eb49ced716b94b

See more details on using hashes here.

File details

Details for the file scikit_topt-0.3.9-py3-none-any.whl.

File metadata

  • Download URL: scikit_topt-0.3.9-py3-none-any.whl
  • Upload date:
  • Size: 101.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for scikit_topt-0.3.9-py3-none-any.whl
Algorithm Hash digest
SHA256 5eff0851a77ebebca1f6e0f9b1191df74ef334e40f7421116183909c797e2965
MD5 00231b2dfe9df530d72048842d87c142
BLAKE2b-256 dfa19b4012404cd69140e7efb622c63373715c762c9d39309e6fdd9e3a6172a8

See more details on using hashes here.

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