Skip to main content

build123d Part extended for CI/CD automation

Project description

Partomatic

Partomatic is an attempt to build an automatable ecosystem for generating parametric models through automation -- making CI/CD automation possible for your 3d models.

The Partomatic philosophy

In the software world, CI/CD technologies are taken for granted. They allow large-scale distributed systems to deploy updates automatically and smoothly. These systems allow an automated flow that takes updated code submitted by a developer, executes tests & validations, and then automated global deployment. Without these technologies the internet as we know it could not operate.

3d Modeling tools are great at creating models, but they don’t make it easy to deploy, generate, and distribute multiple parts. Build123d is a powerful library, but it leaves the creation of final parts up to the developer.

For a large project with many related and interlocking parts, this can make releasing a new version a project in and of itself. Partomatic allows for those designs to be parametric. For example, a wheel might support many different bearings, or come in multiple diameters or thicknesses. Instead of hard coding the saving of each of those STL files, Partomatic allows you to define parameters and file-naming instructions to allow a relatively simple build script to read through multiple configuration files and save each of those STL files in a folder structure and file-naming standard that you define.

Partomatic enables parametric modeling and standardizes some build automation for a part.

Installation

Install partomatic using pip:

pip install partomatic

This will automatically install partomatic and its dependencies.

If you want browser-based configuration/preview UIs, install optional web UI extras:

pip install partomatic[webui]

For the standalone configuration editor only, you can also use:

pip install partomatic[gui]

Parametric Modeling

Parametric 3D modeling is a method of creating 3D models where the geometry is defined by parameters, allowing for easy adjustment by simply changing the values of these parameters. This approach enables the creation of flexible and reusable designs that can be quickly adapted to different requirements.

Using the partomatic library gives you built in support for loading parameters from YAML files -- YAML is a very human, readable format -- someone without any technology background can look at a yaml file that looks like:

wheel:
    radius: 20
    thickness: 4
    bearing:
        diameter: 5
        thickness: 4

and understand how this represents these related parts

Partomatic Components

There are 3 primary components to the partomatic library:

  • AutomatablePart — This dataclass represents a build123d part with augmentation to control the location of the part as well as the file name
  • PartomaticConfig — This dataclass handles loading parameters from yaml strings or files.
  • Partomatic — This is the base class for generating, displaying, and exporting 3d objects based on the parameters loaded in the _config member variable, which is a PartomaticConfig object.

Partomatic also provides runtime helpers for interactive workflows:

  • launch_preview(viewer_host="127.0.0.1", viewer_port=3939) compiles and displays parts in OCP viewer and blocks until Ctrl+C.
  • launch_configurator(...) opens a combined config + preview web app (NiceGUI), with YAML load/save and export actions.

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

partomatic-0.6.0.tar.gz (47.0 kB view details)

Uploaded Source

Built Distribution

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

partomatic-0.6.0-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

File details

Details for the file partomatic-0.6.0.tar.gz.

File metadata

  • Download URL: partomatic-0.6.0.tar.gz
  • Upload date:
  • Size: 47.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for partomatic-0.6.0.tar.gz
Algorithm Hash digest
SHA256 69a0e76998b344ad2ad8426a082e57282b6b8ed113001de770ddd0beba207dc6
MD5 3bf556fe3deed9d8e1b03a7189f9ed4c
BLAKE2b-256 bf71d681f77234646d2c9106b0142529852860f71f21c204cea4b0368a67c820

See more details on using hashes here.

File details

Details for the file partomatic-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: partomatic-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 23.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for partomatic-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c36721c8fab6a8c919998483553f946463f4b7789d5e83c587c81ff56541c860
MD5 44826865560c36aaa8b00772108d94a1
BLAKE2b-256 43aec31d09370381f09f3421158a995c00997c3fbacacf9a99b208152cbcc386

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