mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-21 03:49:38 +00:00
Synopses, etc for gears.scad
This commit is contained in:
parent
0cb33055f3
commit
295d4e3c58
1 changed files with 47 additions and 27 deletions
74
gears.scad
74
gears.scad
|
@ -26,14 +26,15 @@
|
||||||
// Section: Gears
|
// Section: Gears
|
||||||
|
|
||||||
// Function&Module: spur_gear()
|
// Function&Module: spur_gear()
|
||||||
|
// Synopsis: Creates a spur gear shape.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: rack(), spur_gear(), spur_gear2d(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// spur_gear(pitch, teeth, thickness, [shaft_diam], [hide=], [pressure_angle=], [clearance=], [backlash=], [helical=], [slices=], [interior=]) [ATTACHMENTS];
|
// spur_gear(pitch, teeth, thickness, [shaft_diam], [hide=], [pressure_angle=], [clearance=], [backlash=], [helical=], [slices=], [interior=]) [ATTACHMENTS];
|
||||||
// spur_gear(mod=, teeth=, thickness=, [shaft_diam=], ...) [ATTACHMENTS];
|
// spur_gear(mod=, teeth=, thickness=, [shaft_diam=], ...) [ATTACHMENTS];
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// vnf = spur_gear(pitch, teeth, thickness, [shaft_diam], ...);
|
// vnf = spur_gear(pitch, teeth, thickness, [shaft_diam], ...);
|
||||||
// vnf = spur_gear(mod=, teeth=, thickness=, [shaft_diam], ...);
|
// vnf = spur_gear(mod=, teeth=, thickness=, [shaft_diam], ...);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: rack()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a (potentially helical) involute spur gear. The module `spur_gear()` gives an involute
|
// Creates a (potentially helical) involute spur gear. The module `spur_gear()` gives an involute
|
||||||
// spur gear, with reasonable defaults for all the parameters. Normally, you should just choose the
|
// spur gear, with reasonable defaults for all the parameters. Normally, you should just choose the
|
||||||
|
@ -191,14 +192,15 @@ module spur_gear(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: spur_gear2d()
|
// Function&Module: spur_gear2d()
|
||||||
|
// Synopsis: Creates a 2D spur gear shape.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: rack(), spur_gear(), spur_gear2d(), bevel_gear()
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// spur_gear2d(pitch, teeth, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]) [ATTACHMENTS];
|
// spur_gear2d(pitch, teeth, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]) [ATTACHMENTS];
|
||||||
// spur_gear2d(mod=, teeth=, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]) [ATTACHMENTS];
|
// spur_gear2d(mod=, teeth=, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]) [ATTACHMENTS];
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
// poly = spur_gear2d(pitch, teeth, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]);
|
// poly = spur_gear2d(pitch, teeth, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]);
|
||||||
// poly = spur_gear2d(mod=, teeth=, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]);
|
// poly = spur_gear2d(mod=, teeth=, [hide=], [pressure_angle=], [clearance=], [backlash=], [interior=]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: spur_gear()
|
|
||||||
// Description:
|
// Description:
|
||||||
// When called as a module, creates a 2D involute spur gear. When called as a function, returns a
|
// When called as a module, creates a 2D involute spur gear. When called as a function, returns a
|
||||||
// 2D path for the perimeter of a 2D involute spur gear. Normally, you should just specify the
|
// 2D path for the perimeter of a 2D involute spur gear. Normally, you should just specify the
|
||||||
|
@ -291,14 +293,15 @@ module spur_gear2d(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: rack()
|
// Function&Module: rack()
|
||||||
|
// Synopsis: Creates a gear rack shape.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: rack2d(), spur_gear(), spur_gear2d(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// rack(pitch, teeth, thickness, height, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
// rack(pitch, teeth, thickness, height, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
||||||
// rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash]=) [ATTACHMENTS];
|
// rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash]=) [ATTACHMENTS];
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// vnf = rack(pitch, teeth, thickness, height, [pressure_angle=], [backlash=]);
|
// vnf = rack(pitch, teeth, thickness, height, [pressure_angle=], [backlash=]);
|
||||||
// vnf = rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash=]);
|
// vnf = rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash=]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: spur_gear()
|
|
||||||
// Description:
|
// Description:
|
||||||
// This is used to create a 3D rack, which is a linear bar with teeth that a gear can roll along.
|
// This is used to create a 3D rack, which is a linear bar with teeth that a gear can roll along.
|
||||||
// A rack can mesh with any gear that has the same `pitch` and `pressure_angle`.
|
// A rack can mesh with any gear that has the same `pitch` and `pressure_angle`.
|
||||||
|
@ -439,14 +442,15 @@ function rack(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: rack2d()
|
// Function&Module: rack2d()
|
||||||
|
// Synopsis: Creates a 2D gear rack shape.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: rack(), spur_gear(), spur_gear2d(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// path = rack2d(pitch, teeth, height, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
// path = rack2d(pitch, teeth, height, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
||||||
// path = rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
// path = rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=]) [ATTACHMENTS];
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// path = rack2d(pitch, teeth, height, [pressure_angle=], [backlash=]);
|
// path = rack2d(pitch, teeth, height, [pressure_angle=], [backlash=]);
|
||||||
// path = rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=]);
|
// path = rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: spur_gear2d()
|
|
||||||
// Description:
|
// Description:
|
||||||
// This is used to create a 2D rack, which is a linear bar with teeth that a gear can roll along.
|
// This is used to create a 2D rack, which is a linear bar with teeth that a gear can roll along.
|
||||||
// A rack can mesh with any gear that has the same `pitch` and `pressure_angle`.
|
// A rack can mesh with any gear that has the same `pitch` and `pressure_angle`.
|
||||||
|
@ -561,12 +565,13 @@ module rack2d(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: bevel_gear()
|
// Function&Module: bevel_gear()
|
||||||
|
// Synopsis: Creates a possibly spiral beveled gear shape.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: rack(), rack2d(), spur_gear(), spur_gear2d(), bevel_pitch_angle(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// bevel_gear(pitch|mod, teeth, face_width, pitch_angle, [shaft_diam], [hide], [pressure_angle], [clearance], [backlash], [cutter_radius], [spiral_angle], [slices], [interior]);
|
// bevel_gear(pitch|mod, teeth, face_width, pitch_angle, [shaft_diam], [hide], [pressure_angle], [clearance], [backlash], [cutter_radius], [spiral_angle], [slices], [interior]);
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// vnf = bevel_gear(pitch|mod, teeth, face_width, pitch_angle, [hide], [pressure_angle], [clearance], [backlash], [cutter_radius], [spiral_angle], [slices], [interior]);
|
// vnf = bevel_gear(pitch|mod, teeth, face_width, pitch_angle, [hide], [pressure_angle], [clearance], [backlash], [cutter_radius], [spiral_angle], [slices], [interior]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: bevel_pitch_angle()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a (potentially spiral) bevel gear. The module `bevel_gear()` gives a bevel gear, with
|
// Creates a (potentially spiral) bevel gear. The module `bevel_gear()` gives a bevel gear, with
|
||||||
// reasonable defaults for all the parameters. Normally, you should just choose the first 4
|
// reasonable defaults for all the parameters. Normally, you should just choose the first 4
|
||||||
|
@ -817,12 +822,13 @@ module bevel_gear(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: worm()
|
// Function&Module: worm()
|
||||||
|
// Synopsis: Creates a worm shape that will mate with a worm gear.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: worm(), worm_gear(), rack(), rack2d(), spur_gear(), spur_gear2d(), bevel_pitch_angle(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// worm(pitch|mod, d, l, [starts], [left_handed], [pressure_angle], [backlash], [clearance]);
|
// worm(pitch|mod, d, l, [starts], [left_handed], [pressure_angle], [backlash], [clearance]);
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// vnf = worm(pitch|mod, d, l, [starts], [left_handed], [pressure_angle], [backlash], [clearance]);
|
// vnf = worm(pitch|mod, d, l, [starts], [left_handed], [pressure_angle], [backlash], [clearance]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: worm_gear()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a worm shape that can be matched to a worm gear.
|
// Creates a worm shape that can be matched to a worm gear.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -934,12 +940,13 @@ module worm(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: worm_gear()
|
// Function&Module: worm_gear()
|
||||||
|
// Synopsis: Creates a worm gear shape that will mate with a worm.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: worm(), worm_gear(), rack(), rack2d(), spur_gear(), spur_gear2d(), bevel_pitch_angle(), bevel_gear()
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// worm_gear(pitch|mod, teeth, worm_diam, [worm_starts], [crowning], [left_handed], [pressure_angle], [backlash], [slices], [clearance], [shaft_diam]);
|
// worm_gear(pitch|mod, teeth, worm_diam, [worm_starts], [crowning], [left_handed], [pressure_angle], [backlash], [slices], [clearance], [shaft_diam]);
|
||||||
// Usage: As a Function
|
// Usage: As a Function
|
||||||
// vnf = worm_gear(pitch|mod, teeth, worm_diam, [worm_starts], [crowning], [left_handed], [pressure_angle], [backlash], [slices], [clearance]);
|
// vnf = worm_gear(pitch|mod, teeth, worm_diam, [worm_starts], [crowning], [left_handed], [pressure_angle], [backlash], [slices], [clearance]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: worm()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a worm gear to match with a worm.
|
// Creates a worm gear to match with a worm.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -1227,9 +1234,11 @@ module _gear_tooth_profile(
|
||||||
|
|
||||||
|
|
||||||
// Function: circular_pitch()
|
// Function: circular_pitch()
|
||||||
|
// Synopsis: Returns tooth density expressed as "circular pitch".
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value()
|
||||||
// Usage:
|
// Usage:
|
||||||
// circp = circular_pitch(pitch|mod);
|
// circp = circular_pitch(pitch|mod);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Get tooth density expressed as "circular pitch".
|
// Get tooth density expressed as "circular pitch".
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -1244,9 +1253,11 @@ function circular_pitch(pitch=5, mod) =
|
||||||
|
|
||||||
|
|
||||||
// Function: diametral_pitch()
|
// Function: diametral_pitch()
|
||||||
|
// Synopsis: Returns tooth density expressed as "diametral pitch".
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value()
|
||||||
// Usage:
|
// Usage:
|
||||||
// dp = diametral_pitch(pitch|mod);
|
// dp = diametral_pitch(pitch|mod);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Get tooth density expressed as "diametral pitch".
|
// Get tooth density expressed as "diametral pitch".
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -1261,9 +1272,11 @@ function diametral_pitch(pitch=5, mod) =
|
||||||
|
|
||||||
|
|
||||||
// Function: pitch_value()
|
// Function: pitch_value()
|
||||||
|
// Synopsis: Returns circular pitch in mm from module/modulus.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value(), module_value()
|
||||||
// Usage:
|
// Usage:
|
||||||
// pitch = pitch_value(mod);
|
// pitch = pitch_value(mod);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Get circular pitch in mm from module/modulus. The circular pitch of a gear is the number of
|
// Get circular pitch in mm from module/modulus. The circular pitch of a gear is the number of
|
||||||
// millimeters per tooth around the pitch radius circle.
|
// millimeters per tooth around the pitch radius circle.
|
||||||
|
@ -1273,9 +1286,11 @@ function pitch_value(mod) = mod * PI;
|
||||||
|
|
||||||
|
|
||||||
// Function: module_value()
|
// Function: module_value()
|
||||||
|
// Synopsis: Returns tooth density expressed as "module" or "modulus" in millimeters.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value(), module_value()
|
||||||
// Usage:
|
// Usage:
|
||||||
// mod = module_value(pitch);
|
// mod = module_value(pitch);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Get tooth density expressed as "module" or "modulus" in millimeters. The module is the pitch
|
// Get tooth density expressed as "module" or "modulus" in millimeters. The module is the pitch
|
||||||
// diameter of the gear divided by the number of teeth on it. For example, a gear with a pitch
|
// diameter of the gear divided by the number of teeth on it. For example, a gear with a pitch
|
||||||
|
@ -1340,9 +1355,11 @@ function _dedendum(pitch=5, clearance, mod) =
|
||||||
|
|
||||||
|
|
||||||
// Function: pitch_radius()
|
// Function: pitch_radius()
|
||||||
|
// Synopsis: Returns the pitch radius for a gear.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value(), module_value(), outer_radius()
|
||||||
// Usage:
|
// Usage:
|
||||||
// pr = pitch_radius(pitch|mod, teeth);
|
// pr = pitch_radius(pitch|mod, teeth);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Calculates the pitch radius for the gear. Two mated gears will have their centers spaced apart
|
// Calculates the pitch radius for the gear. Two mated gears will have their centers spaced apart
|
||||||
// by the sum of the two gear's pitch radii.
|
// by the sum of the two gear's pitch radii.
|
||||||
|
@ -1364,9 +1381,11 @@ function pitch_radius(pitch=5, teeth=11, mod) =
|
||||||
|
|
||||||
|
|
||||||
// Function: outer_radius()
|
// Function: outer_radius()
|
||||||
|
// Synopsis: Returns the outer radius for a gear.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: spur_gear(), diametral_pitch(), circular_pitch(), pitch_value(), module_value(), pitch_radius(), outer_radius()
|
||||||
// Usage:
|
// Usage:
|
||||||
// or = outer_radius(pitch|mod, teeth, [clearance], [interior]);
|
// or = outer_radius(pitch|mod, teeth, [clearance], [interior]);
|
||||||
// Topics: Gears
|
|
||||||
// Description:
|
// Description:
|
||||||
// Calculates the outer radius for the gear. The gear fits entirely within a cylinder of this radius.
|
// Calculates the outer radius for the gear. The gear fits entirely within a cylinder of this radius.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -1440,12 +1459,13 @@ function _base_radius(pitch=5, teeth=11, pressure_angle=28, mod) =
|
||||||
|
|
||||||
|
|
||||||
// Function: bevel_pitch_angle()
|
// Function: bevel_pitch_angle()
|
||||||
|
// Synopsis: Returns the pitch cone angle for a bevel gear.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: bevel_gear(), pitch_radius(), outer_radius()
|
||||||
// Usage:
|
// Usage:
|
||||||
// ang = bevel_pitch_angle(teeth, mate_teeth, [drive_angle]);
|
// ang = bevel_pitch_angle(teeth, mate_teeth, [drive_angle]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: bevel_gear()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the correct pitch angle for a bevel gear with a given number of tooth, that is
|
// Returns the correct pitch cone angle for a bevel gear with a given number of teeth, that is
|
||||||
// matched to another bevel gear with a (possibly different) number of teeth.
|
// matched to another bevel gear with a (possibly different) number of teeth.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// teeth = Number of teeth that this gear has.
|
// teeth = Number of teeth that this gear has.
|
||||||
|
@ -1471,10 +1491,11 @@ function bevel_pitch_angle(teeth, mate_teeth, drive_angle=90) =
|
||||||
|
|
||||||
|
|
||||||
// Function: worm_gear_thickness()
|
// Function: worm_gear_thickness()
|
||||||
|
// Synopsis: Returns the thickness for a worm gear.
|
||||||
|
// Topics: Gears, Parts
|
||||||
|
// See Also: worm(), worm_gear(), pitch_radius(), outer_radius()
|
||||||
// Usage:
|
// Usage:
|
||||||
// thick = worm_gear_thickness(pitch|mod, teeth, worm_diam, [worm_arc], [crowning], [clearance]);
|
// thick = worm_gear_thickness(pitch|mod, teeth, worm_diam, [worm_arc], [crowning], [clearance]);
|
||||||
// Topics: Gears
|
|
||||||
// See Also: worm(), worm_gear()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Calculate the thickness of the worm gear.
|
// Calculate the thickness of the worm gear.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -1482,7 +1503,7 @@ function bevel_pitch_angle(teeth, mate_teeth, drive_angle=90) =
|
||||||
// teeth = Total number of teeth along the rack. Default: 30
|
// teeth = Total number of teeth along the rack. Default: 30
|
||||||
// worm_diam = The pitch diameter of the worm gear to match to. Default: 30
|
// worm_diam = The pitch diameter of the worm gear to match to. Default: 30
|
||||||
// worm_arc = The arc of the worm to mate with, in degrees. Default: 60 degrees
|
// worm_arc = The arc of the worm to mate with, in degrees. Default: 60 degrees
|
||||||
// crowning = The amount to oversize the virtual hobbing cutter used to make the teeth, to add a slight crowning to the teeth to make them fir the work easier. Default: 1
|
// crowning = The amount to oversize the virtual hobbing cutter used to make the teeth, to add a slight crowning to the teeth to make them fit the work easier. Default: 1
|
||||||
// clearance = Clearance gap at the bottom of the inter-tooth valleys.
|
// clearance = Clearance gap at the bottom of the inter-tooth valleys.
|
||||||
// mod = The metric module/modulus of the gear.
|
// mod = The metric module/modulus of the gear.
|
||||||
// Example:
|
// Example:
|
||||||
|
@ -1521,5 +1542,4 @@ function _gear_q7(f,r,b,r2,t,s) = _gear_q6(b,s,t,(1-f)*max(b,r)+f*r2); //
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
||||||
|
|
Loading…
Reference in a new issue