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.24.tar.gz (145.9 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.24-py3-none-any.whl (107.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: wormgear-0.0.24.tar.gz
  • Upload date:
  • Size: 145.9 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.24.tar.gz
Algorithm Hash digest
SHA256 e849291fff38eae9782f934bfa9cf03617e218791396acd6b9a68a01bbabc496
MD5 a3caf3675265c7462b55643f0fe2d207
BLAKE2b-256 b74eba90af64ffbfbd76e7c98df34c09e0539d33f6ce95c2e8b25589f4cacb7f

See more details on using hashes here.

Provenance

The following attestation bundles were made for wormgear-0.0.24.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.24-py3-none-any.whl.

File metadata

  • Download URL: wormgear-0.0.24-py3-none-any.whl
  • Upload date:
  • Size: 107.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.24-py3-none-any.whl
Algorithm Hash digest
SHA256 96fa2e3fa55262ef185e50fe62185d38bf6e2960df44469652ea87b47e596cb7
MD5 47c1a9ab3eb28cad9aa413b7646b8302
BLAKE2b-256 5380ccba4fcd19c8da3112e6bc61c3941e10bae8b2e6da18587bb61b763cf915

See more details on using hashes here.

Provenance

The following attestation bundles were made for wormgear-0.0.24-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