Skip to main content

Unified worm gear calculator and CNC-ready 3D geometry generator

Project description

Wormgear

Worm gear design: engineering calculations to CNC-ready STEP files.

PyPI version License: MIT

Two Ways to Use

1. Web Calculator (No Installation)

https://wormgear.studio

Design worm gear pairs in your browser:

  • Calculate parameters from engineering constraints
  • Real-time validation (DIN 3975/DIN 3996)
  • Export JSON for geometry generation
  • Works on any device

2. Python Package (For 3D Geometry)

pip install wormgear

Generate CNC-ready STEP files:

# Design in browser at wormgear.studio, download JSON, then:
wormgear-geometry design.json

# Or generate with specific options:
wormgear-geometry design.json --profile ZK --globoid --worm-bore 8

Quick Examples

Command Line

# Basic generation (auto-sized bores and keyways)
wormgear-geometry design.json

# For 3D printing (convex tooth flanks)
wormgear-geometry design.json --profile ZK

# For CNC machining (straight flanks, default)
wormgear-geometry design.json --profile ZA

# Globoid worm (hourglass shape, better contact)
wormgear-geometry design.json --globoid

# Custom bore sizes
wormgear-geometry design.json --worm-bore 8 --wheel-bore 12

# View in VS Code (requires ocp-vscode extension)
wormgear-geometry design.json --view --no-save

Python API

from wormgear.calculator import design_from_module, validate_design
from wormgear.core import WormGeometry, WheelGeometry, BoreFeature, KeywayFeature
from wormgear.io import save_design_json

# Calculate parameters
design = design_from_module(module=2.0, ratio=30)
validation = validate_design(design)

if validation.valid:
    save_design_json(design, "design.json")

    # Generate 3D geometry
    worm = WormGeometry(
        params=design.worm,
        assembly_params=design.assembly,
        length=40.0,
        bore=BoreFeature(diameter=8.0),
        keyway=KeywayFeature()
    )
    worm.build()
    worm.export_step("worm.step")

Features

  • Engineering calculations per DIN 3975/DIN 3996
  • Validation with errors and warnings
  • Tooth profiles: ZA (CNC), ZK (3D printing), ZI (hobbing)
  • Worm types: Cylindrical, Globoid (hourglass)
  • Wheel generation: Helical or virtual hobbing
  • Features: Bores, keyways (DIN 6885), set screws, hubs
  • Output: Watertight STEP files for CAM/slicers

Requirements

  • Python 3.9+
  • build123d (installed automatically)

Note: build123d requires OpenCascade. Most platforms handle this automatically via pip, but see build123d installation if you encounter issues.

Design Workflow

  1. Design at wormgear.studio
  2. Download the JSON file
  3. Generate geometry: wormgear-geometry design.json
  4. Import STEP files into CAD/CAM software
  5. Manufacture via CNC or 3D printing

CLI Reference

wormgear-geometry design.json [OPTIONS]

Options:
  --profile {ZA,ZK,ZI}    Tooth profile (default: ZA)
  --globoid               Generate globoid (hourglass) worm
  --virtual-hobbing       Use virtual hobbing for wheel
  --worm-bore MM          Override worm bore diameter
  --wheel-bore MM         Override wheel bore diameter
  --no-bore               Generate solid parts (no bores)
  --no-keyway             Omit keyways
  --worm-length MM        Worm length (default: 40)
  --wheel-width MM        Wheel width (default: auto)
  -o, --output-dir DIR    Output directory
  --view                  View in OCP viewer
  --no-save               Don't save STEP files
  -h, --help              Show all options

Documentation

Background

Created for custom worm gear design in luthier (violin making) applications, where standard gears don't fit unusual envelope constraints. Extended to support CNC machining and 3D printing for makers and engineers.

License

MIT

Author

Paul Fremantle (@pzfreo)

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

wormgear-0.0.14.tar.gz (131.6 kB view details)

Uploaded Source

Built Distribution

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

wormgear-0.0.14-py3-none-any.whl (97.4 kB view details)

Uploaded Python 3

File details

Details for the file wormgear-0.0.14.tar.gz.

File metadata

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

File hashes

Hashes for wormgear-0.0.14.tar.gz
Algorithm Hash digest
SHA256 efb765b51e93228f1d738fbada2f24c20b197c7c25421b9d2c1d5b806fd0b20f
MD5 bcb4c8be16d6455cb29ca25c3c703203
BLAKE2b-256 4eb4d599d3b3ac2b5675febb57bb8d0b3178948bddb25de836c12b6fb5280e19

See more details on using hashes here.

Provenance

The following attestation bundles were made for wormgear-0.0.14.tar.gz:

Publisher: publish.yml on pzfreo/wormgear

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

File details

Details for the file wormgear-0.0.14-py3-none-any.whl.

File metadata

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

File hashes

Hashes for wormgear-0.0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 332382d0b86be9e6ec1ecf9e5c6331e721d7272c0fbc16939d39a8d98e1624af
MD5 cb71fdc58415e71fee4dc2d4dcf96721
BLAKE2b-256 53f4a43629a8b174415ac2d52c732f8873b7d1f0832639b640457d6c4afcaa62

See more details on using hashes here.

Provenance

The following attestation bundles were made for wormgear-0.0.14-py3-none-any.whl:

Publisher: publish.yml on pzfreo/wormgear

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