Merge pull request #1225 from adrianVmariano/master

Additional gear fixes
This commit is contained in:
Revar Desmera 2023-07-30 22:34:44 -07:00 committed by GitHub
commit 3284950b3b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -154,10 +154,10 @@ function _inherit_gear_thickness(thickness) =
// } // }
// Continues: // Continues:
// In order for the gear teeth to fit together, and to allow space for lubricant, the valleys of the teeth // In order for the gear teeth to fit together, and to allow space for lubricant, the valleys of the teeth
// are made deeper by the `clearance` distance. // are made deeper by the `clearance` distance. This defaults to `module/4`.
// Figure(2D,Med,NoAxes,VPT=[5.62512,-1.33268,-0.0144912],VPR=[0,0,0],VPD=126): The clearance is extra space at the tooth valley that separates the tooth tip (in green) from the tooth valley below it. // Figure(2D,Med,NoAxes,VPT=[5.62512,-1.33268,-0.0144912],VPR=[0,0,0],VPD=126): The clearance is extra space at the tooth valley that separates the tooth tip (in green) from the tooth valley below it.
// intersection(){ // intersection(){
// rack2d(mod=5, teeth=10, height=15, pressure_angle=14.5); // rack2d(mod=5, teeth=10, bottom=15, pressure_angle=14.5);
// rect([35,20]); // rect([35,20]);
// } // }
// color("lightgreen")render() // color("lightgreen")render()
@ -176,7 +176,7 @@ function _inherit_gear_thickness(thickness) =
// teeth may interfere with each other. This may require undercutting the gear teeth to create space, which weakens the teeth. // teeth may interfere with each other. This may require undercutting the gear teeth to create space, which weakens the teeth.
// Figure(2D,Med,NoAxes,VPT=[0.042845,6.5338,-0.0144912],VPR=[0,0,0],VPD=126): The green gear with only five teeth has a severe undercut, which weakens its teeth. This undercut is necessary to avoid interference with the teeth from the other gear during rotation. Note that the yellow rack tooth is deep into the undercut space. // Figure(2D,Med,NoAxes,VPT=[0.042845,6.5338,-0.0144912],VPR=[0,0,0],VPD=126): The green gear with only five teeth has a severe undercut, which weakens its teeth. This undercut is necessary to avoid interference with the teeth from the other gear during rotation. Note that the yellow rack tooth is deep into the undercut space.
// ang=16; // ang=16;
// rack2d(mod=5, teeth=3, height=15, clearance=.00001, pressure_angle=14.5); // rack2d(mod=5, teeth=3, bottom=15, pressure_angle=14.5, rounding=0);
// left(2*PI*pitch_radius(mod=5, teeth=5)*ang/360) // left(2*PI*pitch_radius(mod=5, teeth=5)*ang/360)
// color("lightgreen") // color("lightgreen")
// back(gear_dist(mod=5, teeth1=5, profile_shift1=0, teeth2=0)) // back(gear_dist(mod=5, teeth1=5, profile_shift1=0, teeth2=0))
@ -216,7 +216,7 @@ function _inherit_gear_thickness(thickness) =
// back(gear_dist(mod=5, teeth1=5, teeth2=0,pressure_angle=14.5)) // back(gear_dist(mod=5, teeth1=5, teeth2=0,pressure_angle=14.5))
// zrot(ang2) // zrot(ang2)
// spur_gear2d(mod=5, teeth=5, pressure_angle=14.5, shaft_diam=2); // spur_gear2d(mod=5, teeth=5, pressure_angle=14.5, shaft_diam=2);
// rack2d(teeth=4, height=15, mod=5, pressure_angle=14.5); // rack2d(teeth=4, bottom=15, mod=5, pressure_angle=14.5);
// Subsection: Helical Gears // Subsection: Helical Gears
// Helicals gears are a modification of spur gears. They can replace spur gears in any application. The teeth are cut // Helicals gears are a modification of spur gears. They can replace spur gears in any application. The teeth are cut
// following a slanted, helical path. The angled teeth engage more gradually than spur gear teeth, so they run more smoothly // following a slanted, helical path. The angled teeth engage more gradually than spur gear teeth, so they run more smoothly
@ -360,7 +360,7 @@ function _inherit_gear_thickness(thickness) =
// profile_shift = 0; // profile_shift = 0;
// d = gear_dist(circ_pitch=circ_pitch,teeth,0,profile_shift1=profile_shift); // d = gear_dist(circ_pitch=circ_pitch,teeth,0,profile_shift1=profile_shift);
// back(d) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift); // back(d) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift);
// rack(circ_pitch, teeth=3, thickness=thick, height=5, orient=BACK); // rack(circ_pitch, teeth=3, thickness=thick, orient=BACK);
// color("black") up(thick/2) linear_extrude(height=0.1) { // color("black") up(thick/2) linear_extrude(height=0.1) {
// back(d) dashed_stroke(circle(r=pr), width=strokewidth, closed=true); // back(d) dashed_stroke(circle(r=pr), width=strokewidth, closed=true);
// dashed_stroke([[-7.5,0],[7.5,0]], width=strokewidth); // dashed_stroke([[-7.5,0],[7.5,0]], width=strokewidth);
@ -370,7 +370,7 @@ function _inherit_gear_thickness(thickness) =
// profile_shift = 0.59; // profile_shift = 0.59;
// d = gear_dist(circ_pitch=circ_pitch,teeth,0,profile_shift1=profile_shift); // d = gear_dist(circ_pitch=circ_pitch,teeth,0,profile_shift1=profile_shift);
// back(d) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift); // back(d) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift);
// rack(circ_pitch, teeth=3, thickness=thick, height=5, orient=BACK); // rack(circ_pitch, teeth=3, thickness=thick, orient=BACK);
// color("black") up(thick/2) linear_extrude(height=0.1) { // color("black") up(thick/2) linear_extrude(height=0.1) {
// back(d) // back(d)
// dashed_stroke(circle(r=pr), width=strokewidth, closed=true); // dashed_stroke(circle(r=pr), width=strokewidth, closed=true);
@ -401,7 +401,7 @@ function _inherit_gear_thickness(thickness) =
// color("#77f") right(d13) zrot(a3) spur_gear(circ_pitch,n3,thickness,hole); // color("#77f") right(d13) zrot(a3) spur_gear(circ_pitch,n3,thickness,hole);
// color("#fc7") left(d14) zrot(a4) spur_gear(circ_pitch,n4,thickness,hole,hide=n4-3); // color("#fc7") left(d14) zrot(a4) spur_gear(circ_pitch,n4,thickness,hole,hide=n4-3);
// color("#ccc") fwd(d1r) right(circ_pitch*$t) // color("#ccc") fwd(d1r) right(circ_pitch*$t)
// rack(pitch=circ_pitch,teeth=n5,thickness=thickness,height=rack_base,anchor=CENTER,orient=BACK); // rack(pitch=circ_pitch,teeth=n5,thickness=thickness,width=rack_base,anchor=CENTER,orient=BACK);
// Example(NoAxes,VPT=[1.13489,-4.48517,1.04995],VPR=[55,0,25],VPD=139.921): Helical gears meshing with non-parallel shafts // Example(NoAxes,VPT=[1.13489,-4.48517,1.04995],VPR=[55,0,25],VPD=139.921): Helical gears meshing with non-parallel shafts
// ang1 = 30; // ang1 = 30;
// ang2 = 10; // ang2 = 10;
@ -483,7 +483,7 @@ function spur_gear(
PA = _inherit_gear_pa(pressure_angle), PA = _inherit_gear_pa(pressure_angle),
helical = _inherit_gear_helical(helical, invert=!internal), helical = _inherit_gear_helical(helical, invert=!internal),
thickness = _inherit_gear_thickness(thickness), thickness = _inherit_gear_thickness(thickness),
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)) profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical))
) )
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(thickness) && thickness>0) assert(is_finite(thickness) && thickness>0)
@ -557,7 +557,7 @@ module spur_gear(
PA = _inherit_gear_pa(pressure_angle); PA = _inherit_gear_pa(pressure_angle);
helical = _inherit_gear_helical(helical, invert=!internal); helical = _inherit_gear_helical(helical, invert=!internal);
thickness = _inherit_gear_thickness(thickness); thickness = _inherit_gear_thickness(thickness);
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)); profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical));
checks = checks =
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(thickness) && thickness>0) assert(is_finite(thickness) && thickness>0)
@ -691,7 +691,7 @@ module spur_gear(
// } // }
// module the_rack() { // module the_rack() {
// $fn=72; // $fn=72;
// rack2d(circ_pitch, teeth=3, height=5); // rack2d(circ_pitch, teeth=3);
// up(0.1) color("black") // up(0.1) color("black")
// dashed_stroke([[-7.5,0],[7.5,0]], width=strokewidth); // dashed_stroke([[-7.5,0],[7.5,0]], width=strokewidth);
// } // }
@ -748,7 +748,7 @@ function spur_gear2d(
circ_pitch = _inherit_gear_pitch("spur_gear2d()", pitch, circ_pitch, diam_pitch, mod), circ_pitch = _inherit_gear_pitch("spur_gear2d()", pitch, circ_pitch, diam_pitch, mod),
PA = _inherit_gear_pa(pressure_angle), PA = _inherit_gear_pa(pressure_angle),
helical = _inherit_gear_helical(helical, invert=!internal), helical = _inherit_gear_helical(helical, invert=!internal),
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)) profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical))
) )
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(shaft_diam) && shaft_diam>=0) assert(is_finite(shaft_diam) && shaft_diam>=0)
@ -808,7 +808,7 @@ module spur_gear2d(
circ_pitch = _inherit_gear_pitch("spur_gear2d()", pitch, circ_pitch, diam_pitch, mod); circ_pitch = _inherit_gear_pitch("spur_gear2d()", pitch, circ_pitch, diam_pitch, mod);
PA = _inherit_gear_pa(pressure_angle); PA = _inherit_gear_pa(pressure_angle);
helical = _inherit_gear_helical(helical, invert=!internal); helical = _inherit_gear_helical(helical, invert=!internal);
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)); profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical));
checks = checks =
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(shaft_diam) && shaft_diam>=0) assert(is_finite(shaft_diam) && shaft_diam>=0)
@ -915,7 +915,7 @@ module ring_gear(
PA = _inherit_gear_pa(pressure_angle); PA = _inherit_gear_pa(pressure_angle);
helical = _inherit_gear_helical(helical); helical = _inherit_gear_helical(helical);
thickness = _inherit_gear_thickness(thickness); thickness = _inherit_gear_thickness(thickness);
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)); profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical));
checks = checks =
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(thickness) && thickness>0) assert(is_finite(thickness) && thickness>0)
@ -1028,7 +1028,7 @@ module ring_gear2d(
circ_pitch = _inherit_gear_pitch("ring_gear2d()",pitch, circ_pitch, diam_pitch, mod); circ_pitch = _inherit_gear_pitch("ring_gear2d()",pitch, circ_pitch, diam_pitch, mod);
PA = _inherit_gear_pa(pressure_angle); PA = _inherit_gear_pa(pressure_angle);
helical = _inherit_gear_helical(helical); helical = _inherit_gear_helical(helical);
profile_shift = default(profile_shift, auto_profile_shift(teeth,PA)); profile_shift = default(profile_shift, auto_profile_shift(teeth,PA,helical));
checks = checks =
assert(is_integer(teeth) && teeth>3) assert(is_integer(teeth) && teeth>3)
assert(is_finite(backing) && backing>0) assert(is_finite(backing) && backing>0)
@ -1052,7 +1052,7 @@ module ring_gear2d(
clearance = clearance, clearance = clearance,
backlash = backlash, backlash = backlash,
profile_shift = profile_shift, profile_shift = profile_shift,
internal = true internal = true
); );
} }
children(); children();
@ -1066,32 +1066,38 @@ module ring_gear2d(
// Topics: Gears, Parts // Topics: Gears, Parts
// See Also: rack2d(), spur_gear(), spur_gear2d(), bevel_gear() // 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=], [clearance=], [helical=]) [ATTACHMENTS]; // rack(pitch, teeth, thickness, [base|bottom=|width=], [helical=], [pressure_angle=], [backlash=], [clearance=]) [ATTACHMENTS];
// rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash]=, [clearance=], [helical=]) [ATTACHMENTS]; // rack(mod=, teeth=, thickness=, [base=|bottom=|width=], [helical=], [pressure_angle=], [backlash]=, [clearance=]) [ATTACHMENTS];
// Usage: As a Function // Usage: As a Function
// vnf = rack(pitch, teeth, thickness, height, [pressure_angle=], [backlash=], [clearance=], [helical=]); // vnf = rack(pitch, teeth, thickness, [base|bottom=|width=], [helical=], [pressure_angle=], [backlash=], [clearance=]);
// vnf = rack(mod=, teeth=, thickness=, height=, [pressure_angle=], [backlash=], [clearance=], [helical=]); // vnf = rack(mod=, teeth=, thickness=, [base=|bottom=|width=], [helical=], [pressure_angle=], [backlash=], [clearance=]);
// 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 helical rack meshes with a gear with the opposite // A rack can mesh with any gear that has the same `pitch` and `pressure_angle`. A helical rack meshes with a gear with the opposite
// helical angle. The rack appears oriented with // helical angle. The rack appears oriented with
// its teeth pointed UP, which makes it easy to use the `orient=` argument to point the rack in the direction you require. // its teeth pointed UP, so it will need to be oriented to mesh with gears.
// The pitch line of the rack is aligned with the x axis. // The pitch line of the rack is aligned with the x axis.
// When called as a function, returns a 3D [VNF](vnf.scad) for the rack. // When called as a function, returns a 3D [VNF](vnf.scad) for the rack.
// When called as a module, creates a 3D rack shape. // When called as a module, creates a 3D rack shape.
// .
// By default the rack has a backing whose height is equal to the height of the teeth. You can specify a different backing size
// or you can specify the total width of the rack (from the bottom of the rack to tooth tips) or the
// bottom point of the rack, which is the distance from the pitch line to the bottom of the rack.
// Arguments: // Arguments:
// pitch = The pitch, or distance in mm between teeth along the rack. Matches up with circular pitch on a spur gear. Default: 5 // pitch = The pitch, or distance in mm between teeth along the rack. Matches up with circular pitch on a spur gear. Default: 5
// teeth = Total number of teeth along the rack. Default: 20 // teeth = Total number of teeth along the rack. Default: 20
// thickness = Thickness of rack in mm (affects each tooth). Default: 5 // thickness = Thickness of rack in mm (affects each tooth). Default: 5
// height = Distance from the pitch line of the rack to the back (bottom) of the rack. Default: 10 // backing = Distance from bottom of rack to the roots of the rack's teeth. (Alternative to bottom or width.) Default: height of rack teeth
// --- // ---
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20 // bottom = Distance from rack's pitch line (the x-axis) to the bottom of the rack. (Alternative to backing or width)
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0 // width = Distance from base of rack to tips of teeth (alternative to bottom and backing).
// clearance = Clearance gap at the bottom of the inter-tooth valleys. // mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth.
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
// helical = The angle of the rack teeth away from perpendicular to the rack length. Used to match helical spur gear pinions. Default: 0 // helical = The angle of the rack teeth away from perpendicular to the rack length. Used to match helical spur gear pinions. Default: 0
// profile_shift = Profile shift factor x. // profile_shift = Profile shift factor x.
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter. // pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20
// mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth. // backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0
// clearance = Clearance gap at the bottom of the inter-tooth valleys. Default: module/4
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP` // orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
@ -1106,33 +1112,41 @@ module ring_gear2d(
// "root-right" = At the base of the teeth, at the right end of the rack. // "root-right" = At the base of the teeth, at the right end of the rack.
// "root-back" = At the base of the teeth, at the back of the rack. // "root-back" = At the base of the teeth, at the back of the rack.
// "root-front" = At the base of the teeth, at the front of the rack. // "root-front" = At the base of the teeth, at the front of the rack.
// Example(NoScale,VPR=[60,0,325],VPD=130): // Example(NoScales,VPR=[60,0,325],VPD=130):
// rack(pitch=5, teeth=10, thickness=5, height=5, pressure_angle=20); // rack(pitch=5, teeth=10, thickness=5);
// Example(NoScale,VPT=[0.317577,3.42688,7.83665],VPR=[27.7,0,359.8],VPD=139.921): Rack for Helical Gear // Example(NoScales,VPT=[0.317577,3.42688,7.83665],VPR=[27.7,0,359.8],VPD=139.921): Rack for Helical Gear
// rack(pitch=5, teeth=10, thickness=5, height=5, helical=30); // rack(pitch=5, teeth=10, thickness=5, backing=5, helical=30);
// Example(NoScale): Metric Rack, oriented BACK to align with a gear in default orientation // Example(NoScales): Metric Rack, oriented BACK to align with a gear in default orientation
// rack(mod=2, teeth=10, thickness=5, height=5, pressure_angle=14.5,orient=BACK); // rack(mod=2, teeth=10, thickness=5, bottom=5, pressure_angle=14.5,orient=BACK);
// Example(NoScale,Anim,VPT=[0,0,12],VPD=100,Frames=18): Rack and Pinion // Example(NoScales,Anim,VPT=[0,0,12],VPD=100,Frames=18): Rack and Pinion with helical teeth
// teeth1 = 16; teeth2 = 16; // teeth1 = 16; teeth2 = 16;
// pitch = 5; thick = 5; helical = 30; // pitch = 5; thick = 5; helical = 30;
// pr = pitch_radius(pitch, teeth2, helical=helical); // pr = pitch_radius(pitch, teeth2, helical=helical);
// pos = 3*(1-2*abs($t-1/2))-1.5; // pos = 3*(1-2*abs($t-1/2))-1.5;
// right(pr*2*PI/teeth2*pos) // right(pr*2*PI/teeth2*pos)
// rack(pitch, teeth1, thickness=thick, height=5, helical=helical); // rack(pitch, teeth1, thickness=thick, helical=helical);
// up(pr) // up(pr)
// spur_gear( // spur_gear(
// pitch, teeth2, // pitch, teeth2,
// thickness=thick, // thickness = thick,
// helical=-helical, // helical = -helical,
// shaft_diam=5, // shaft_diam = 5,
// orient=BACK, // orient = BACK,
// gear_spin=180-pos*360/teeth2); // gear_spin = 180-pos*360/teeth2);
// Example(NoAxes,VPT=[-7.10396,-9.70691,3.50121],VPR=[60.2,0,325],VPD=213.262): Skew axis helical gear and rack engagement.
// mod=5; teeth=8; helical1=17.5; helical2=22.5;
// d = gear_dist_skew(mod=mod, teeth, 0, helical1,helical2);
// rack(mod=mod, teeth=5, thickness=30, helical=helical2, orient=FWD);
// color("lightblue")
// yrot(-helical1-helical2) fwd(d)
// spur_gear(mod=mod, teeth=teeth, helical=helical1, gear_spin=180/teeth, thickness=30);
module rack( module rack(
pitch, pitch,
teeth, teeth,
thickness, thickness,
height = 10, backing,
width, bottom,
pressure_angle, pressure_angle,
backlash = 0.0, backlash = 0.0,
clearance, clearance,
@ -1153,7 +1167,6 @@ module rack(
checks= checks=
assert(is_integer(teeth) && teeth>0) assert(is_integer(teeth) && teeth>0)
assert(is_finite(thickness) && thickness>0) assert(is_finite(thickness) && thickness>0)
assert(is_finite(height) && height>0)
assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.") assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.")
assert(clearance==undef || (is_finite(clearance) && clearance>=0)) assert(clearance==undef || (is_finite(clearance) && clearance>=0))
assert(is_finite(backlash) && backlash>=0) assert(is_finite(backlash) && backlash>=0)
@ -1164,6 +1177,16 @@ module rack(
trans_pitch = pitch / cos(helical); trans_pitch = pitch / cos(helical);
a = _adendum(pitch, profile_shift); a = _adendum(pitch, profile_shift);
d = _dedendum(pitch, clearance, profile_shift); d = _dedendum(pitch, clearance, profile_shift);
bottom = is_def(bottom) ?
assert(is_finite(bottom) && bottom>d, "bottom is invalid or too small for teeth")
bottom
: is_def(width) ?
assert(is_finite(width) && width>a+d, "Width is invalid or too small for teeth")
width - a
: is_def(backing) ?
assert(all_positive([backing]), "Backing must be a positive value")
backing+d
: 2*d+a; // default case
l = teeth * trans_pitch; l = teeth * trans_pitch;
anchors = [ anchors = [
named_anchor("tip", [0,0,a], BACK), named_anchor("tip", [0,0,a], BACK),
@ -1177,7 +1200,7 @@ module rack(
named_anchor("root-front", [0,-thickness/2,-d], DOWN), named_anchor("root-front", [0,-thickness/2,-d], DOWN),
named_anchor("root-back", [0, thickness/2,-d], UP), named_anchor("root-back", [0, thickness/2,-d], UP),
]; ];
size = [l, thickness, 2*height]; size = [l, thickness, 2*bottom];
attachable(anchor,spin,orient, size=size, anchors=anchors) { attachable(anchor,spin,orient, size=size, anchors=anchors) {
right(gear_travel) right(gear_travel)
skew(sxy=-tan(helical)) xrot(90) { skew(sxy=-tan(helical)) xrot(90) {
@ -1185,7 +1208,7 @@ module rack(
rack2d( rack2d(
pitch = pitch, pitch = pitch,
teeth = teeth, teeth = teeth,
height = height, bottom=bottom,
pressure_angle = PA, pressure_angle = PA,
backlash = backlash, backlash = backlash,
clearance = clearance, clearance = clearance,
@ -1203,7 +1226,7 @@ function rack(
pitch, pitch,
teeth, teeth,
thickness, thickness,
height = 10, backing, bottom, width,
pressure_angle, pressure_angle,
backlash = 0.0, backlash = 0.0,
clearance, clearance,
@ -1225,7 +1248,6 @@ function rack(
) )
assert(is_integer(teeth) && teeth>0) assert(is_integer(teeth) && teeth>0)
assert(is_finite(thickness) && thickness>0) assert(is_finite(thickness) && thickness>0)
assert(is_finite(height) && height>0)
assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.") assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.")
assert(clearance==undef || (is_finite(clearance) && clearance>=0)) assert(clearance==undef || (is_finite(clearance) && clearance>=0))
assert(is_finite(backlash) && backlash>=0) assert(is_finite(backlash) && backlash>=0)
@ -1237,11 +1259,21 @@ function rack(
trans_pitch = pitch / cos(helical), trans_pitch = pitch / cos(helical),
a = _adendum(pitch, profile_shift), a = _adendum(pitch, profile_shift),
d = _dedendum(pitch, clearance, profile_shift), d = _dedendum(pitch, clearance, profile_shift),
bottom = is_def(bottom) ?
assert(is_finite(bottom) && bottom>d, "bottom is invalid or too small for teeth")
bottom
: is_def(width) ?
assert(is_finite(width) && width>a+d, "Width is invalid or too small for teeth")
width - a
: is_def(backing) ?
assert(all_positive([backing]), "Backing must be a positive value")
backing+d
: 2*d+a, // default case
l = teeth * trans_pitch, l = teeth * trans_pitch,
path = rack2d( path = rack2d(
pitch = pitch, pitch = pitch,
teeth = teeth, teeth = teeth,
height = height, bottom=bottom,
pressure_angle = PA, pressure_angle = PA,
backlash = backlash, backlash = backlash,
clearance = clearance, clearance = clearance,
@ -1254,7 +1286,7 @@ function rack(
if (helical) skew(sxy=-tan(helical)) if (helical) skew(sxy=-tan(helical))
]), ]),
out = apply(m, vnf), out = apply(m, vnf),
size = [l, thickness, 2*height], size = [l, thickness, 2*bottom],
anchors = [ anchors = [
named_anchor("tip", [0,0,a], BACK), named_anchor("tip", [0,0,a], BACK),
named_anchor("tip-left", [-l/2,0,a], LEFT), named_anchor("tip-left", [-l/2,0,a], LEFT),
@ -1278,49 +1310,55 @@ function rack(
// Topics: Gears, Parts // Topics: Gears, Parts
// See Also: rack(), spur_gear(), spur_gear2d(), bevel_gear() // See Also: rack(), spur_gear(), spur_gear2d(), bevel_gear()
// Usage: As a Module // Usage: As a Module
// rack2d(pitch, teeth, height, [pressure_angle=], [backlash=], [clearance=]) [ATTACHMENTS]; // rack2d(pitch, teeth, [base|bottom=|width=], [pressure_angle=], [backlash=], [clearance=]) [ATTACHMENTS];
// rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=], [clearance=]) [ATTACHMENTS]; // rack2d(mod=, teeth=, [base=|bottom=|width=], [pressure_angle=], [backlash=], [clearance=]) [ATTACHMENTS];
// Usage: As a Function // Usage: As a Function
// path = rack2d(pitch, teeth, height, [pressure_angle=], [backlash=], [clearance=]); // path = rack2d(pitch, teeth, [base|bottom=|width=], [pressure_angle=], [backlash=], [clearance=]);
// path = rack2d(mod=, teeth=, height=, [pressure_angle=], [backlash=], [clearance=]); // path = rack2d(mod=, teeth=, [base=|bottom=|width=], [pressure_angle=], [backlash=], [clearance=]);
// Description: // Description:
// This is used to create a 2D rack, which is a linear bar with teeth that a gear can roll along. // Create a 2D rack, 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 spur gear or helical gear that has the same `pitch` and `pressure_angle`.
// When called as a function, returns a 2D path for the outline of the rack. // When called as a function, returns a 2D path for the outline of the rack.
// When called as a module, creates a 2D rack shape. // When called as a module, creates a 2D rack shape.
// .
// By default the rack has a backing whose height is equal to the height of the teeth. You can specify a different backing size
// or you can specify the total width of the rack (from the bottom of the rack to tooth tips) or the
// bottom point of the rack, which is the distance from the pitch line to the bottom of the rack.
// Arguments: // Arguments:
// pitch = The pitch, or distance in mm between teeth along the rack. Matches up with circular pitch on a spur gear. Default: 5 // pitch = The pitch, or distance in mm between teeth along the rack. Matches up with circular pitch on a spur gear. Default: 5
// teeth = Total number of teeth along the rack // teeth = Total number of teeth along the rack
// height = Height of rack in mm, from pitch line to back of rack. // backing = Distance from bottom of rack to the roots of the rack's teeth. (Alternative to bottom or width.) Default: height of rack teeth
// --- // ---
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. // bottom = Distance from rack's pitch line (the x-axis) to the bottom of the rack. (Alternative to backing or width)
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle // width = Distance from base of rack to tips of teeth (alternative to bottom and backing).
// clearance = Clearance gap at the bottom of the inter-tooth valleys. // mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth.
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
// helical = The angle of the rack teeth away from perpendicular to the rack length. Stretches out the tooth shapes. Used to match helical spur gear pinions. Default: 0 // helical = The angle of the rack teeth away from perpendicular to the rack length. Stretches out the tooth shapes. Used to match helical spur gear pinions. Default: 0
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees.
// profile_shift = Profile shift factor x for tooth shape. // profile_shift = Profile shift factor x for tooth shape.
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle
// clearance = Clearance gap at the bottom of the inter-tooth valleys. Default: module/4
// gear_travel = The distance the rack should be moved by linearly. Default: 0 // gear_travel = The distance the rack should be moved by linearly. Default: 0
// rounding = If true, rack tips and valleys are slightly rounded. Default: true // rounding = If true, rack tips and valleys are slightly rounded. Default: true
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
// mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth.
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER` // anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0` // spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// Extra Anchors: // Extra Anchors:
// "adendum" = At the tips of the teeth, at the center of rack. // "tip" = At the tips of the teeth, at the center of rack.
// "adendum-left" = At the tips of the teeth, at the left end of the rack. // "tip-left" = At the tips of the teeth, at the left end of the rack.
// "adendum-right" = At the tips of the teeth, at the right end of the rack. // "tip-right" = At the tips of the teeth, at the right end of the rack.
// "dedendum" = At the height of the teeth, at the center of rack. // "root" = At the height of the teeth, at the center of rack.
// "dedendum-left" = At the height of the teeth, at the left end of the rack. // "root-left" = At the height of the teeth, at the left end of the rack.
// "dedendum-right" = At the height of the teeth, at the right end of the rack. // "root-right" = At the height of the teeth, at the right end of the rack.
// Example(2D): // Example(2D):
// rack2d(pitch=5, teeth=10, height=10, pressure_angle=20); // rack2d(pitch=5, teeth=10);
// Example(2D): Called as a Function // Example(2D): Called as a Function
// path = rack2d(pitch=8, teeth=8, height=10, pressure_angle=20); // path = rack2d(pitch=8, teeth=8, pressure_angle=25);
// polygon(path); // polygon(path);
function rack2d( function rack2d(
pitch, pitch,
teeth, teeth,
height = 10, backing,
pressure_angle, pressure_angle,
backlash = 0, backlash = 0,
clearance, clearance,
@ -1329,6 +1367,7 @@ function rack2d(
circ_pitch, circ_pitch,
diam_pitch, diam_pitch,
mod, mod,
width, bottom,
gear_travel = 0, gear_travel = 0,
rounding = true, rounding = true,
anchor = CENTER, anchor = CENTER,
@ -1339,18 +1378,27 @@ function rack2d(
helical = _inherit_gear_helical(helical) helical = _inherit_gear_helical(helical)
) )
assert(is_integer(teeth) && teeth>0) assert(is_integer(teeth) && teeth>0)
assert(is_finite(height) && height>0)
assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.") assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.")
assert(clearance==undef || (is_finite(clearance) && clearance>=0)) assert(clearance==undef || (is_finite(clearance) && clearance>=0))
assert(is_finite(backlash) && backlash>=0) assert(is_finite(backlash) && backlash>=0)
assert(is_finite(helical) && abs(helical)<90) assert(is_finite(helical) && abs(helical)<90)
assert(is_finite(profile_shift) && abs(profile_shift)<1) assert(is_finite(profile_shift) && abs(profile_shift)<1)
assert(is_finite(gear_travel)) assert(is_finite(gear_travel))
assert(num_defined([width,backing,bottom])<=1, "Can define only one of width, backing and bottom")
let( let(
adendum = _adendum(pitch, profile_shift), adendum = _adendum(pitch, profile_shift),
dedendum = _dedendum(pitch, clearance, profile_shift) dedendum = _dedendum(pitch, clearance, profile_shift),
bottom = is_def(bottom) ?
assert(is_finite(bottom) && bottom>dedendum, "bottom is invalid or too small for teeth")
bottom
: is_def(width) ?
assert(is_finite(width) && width>adendum+dedendum, "Width is invalid or too small for teeth")
width - adendum
: is_def(backing) ?
assert(all_positive([backing]), "Backing must be a positive value")
backing+dedendum
: 2*dedendum+adendum // default case
) )
assert(dedendum < height, "height= is not large enough.")
let( let(
trans_pitch = pitch / cos(helical), trans_pitch = pitch / cos(helical),
trans_pa = atan(tan(PA)/cos(helical)), trans_pa = atan(tan(PA)/cos(helical)),
@ -1389,18 +1437,18 @@ function rack2d(
each apply(m,tooth) each apply(m,tooth)
], ],
path = right(gear_travel, p=[ path = right(gear_travel, p=[
[path2[0].x, -height], [path2[0].x, -bottom],
each path2, each path2,
[last(path2).x, -height], [last(path2).x, -bottom],
]), ]),
size=[l,2*height], size=[l,2*bottom],
anchors = [ anchors = [
named_anchor("adendum", [ 0, adendum,0], BACK), named_anchor("tip", [ 0, adendum,0], BACK),
named_anchor("adendum-left", [-l/2, adendum,0], LEFT), named_anchor("tip-left", [-l/2, adendum,0], LEFT),
named_anchor("adendum-right", [ l/2, adendum,0], RIGHT), named_anchor("tip-right", [ l/2, adendum,0], RIGHT),
named_anchor("dedendum", [ 0,-dedendum,0], BACK), named_anchor("root", [ 0,-dedendum,0], BACK),
named_anchor("dedendum-left", [-l/2,-dedendum,0], LEFT), named_anchor("root-left", [-l/2,-dedendum,0], LEFT),
named_anchor("dedendum-right", [ l/2,-dedendum,0], RIGHT), named_anchor("root-right", [ l/2,-dedendum,0], RIGHT),
] ]
) reorient(anchor,spin, two_d=true, size=size, anchors=anchors, p=path); ) reorient(anchor,spin, two_d=true, size=size, anchors=anchors, p=path);
@ -1409,7 +1457,8 @@ function rack2d(
module rack2d( module rack2d(
pitch, pitch,
teeth, teeth,
height = 10, backing,
width, bottom,
pressure_angle, pressure_angle,
backlash = 0.0, backlash = 0.0,
clearance, clearance,
@ -1418,7 +1467,7 @@ module rack2d(
gear_travel = 0, gear_travel = 0,
circ_pitch, circ_pitch,
diam_pitch, diam_pitch,
mod, mod, rounding=true,
anchor = CENTER, anchor = CENTER,
spin = 0 spin = 0
) { ) {
@ -1427,35 +1476,46 @@ module rack2d(
helical = _inherit_gear_helical(helical); helical = _inherit_gear_helical(helical);
checks = checks =
assert(is_integer(teeth) && teeth>0) assert(is_integer(teeth) && teeth>0)
assert(is_finite(height) && height>0)
assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.") assert(is_finite(PA) && PA>=0 && PA<90, "Bad pressure_angle value.")
assert(clearance==undef || (is_finite(clearance) && clearance>=0)) assert(clearance==undef || (is_finite(clearance) && clearance>=0))
assert(is_finite(backlash) && backlash>=0) assert(is_finite(backlash) && backlash>=0)
assert(is_finite(helical) && abs(helical)<90) assert(is_finite(helical) && abs(helical)<90)
assert(is_finite(profile_shift) && abs(profile_shift)<1) assert(is_finite(profile_shift) && abs(profile_shift)<1)
assert(is_finite(gear_travel)); assert(is_finite(gear_travel))
assert(num_defined([width,backing,bottom])<=1, "Can define only one of width, backing and bottom");
trans_pitch = pitch / cos(helical); trans_pitch = pitch / cos(helical);
a = _adendum(pitch, profile_shift); a = _adendum(pitch, profile_shift);
d = _dedendum(pitch, clearance, profile_shift); d = _dedendum(pitch, clearance, profile_shift);
bottom = is_def(bottom) ?
assert(is_finite(bottom) && bottom>d, "bottom is invalid or too small for teeth")
bottom
: is_def(width) ?
assert(is_finite(width) && width>a+d, "Width is invalid or too small for teeth")
width - a
: is_def(backing) ?
assert(all_positive([backing]), "Backing must be a positive value")
backing+d
: 2*d+a; // default case
l = teeth * trans_pitch; l = teeth * trans_pitch;
path = rack2d( path = rack2d(
pitch = pitch, pitch = pitch,
teeth = teeth, teeth = teeth,
height = height, bottom=bottom,
pressure_angle = PA, pressure_angle = PA,
backlash = backlash, backlash = backlash,
clearance = clearance, clearance = clearance,
helical = helical, helical = helical,
rounding=rounding,
profile_shift= profile_shift profile_shift= profile_shift
); );
size = [l, 2*height]; size = [l, 2*bottom];
anchors = [ anchors = [
named_anchor("adendum", [ 0, a,0], BACK), named_anchor("tip", [ 0, a,0], BACK),
named_anchor("adendum-left", [-l/2, a,0], LEFT), named_anchor("tip-left", [-l/2, a,0], LEFT),
named_anchor("adendum-right", [ l/2, a,0], RIGHT), named_anchor("tip-right", [ l/2, a,0], RIGHT),
named_anchor("dedendum", [ 0,-d,0], BACK), named_anchor("root", [ 0,-d,0], BACK),
named_anchor("dedendum-left", [-l/2,-d,0], LEFT), named_anchor("root-left", [-l/2,-d,0], LEFT),
named_anchor("dedendum-right", [ l/2,-d,0], RIGHT), named_anchor("root-right", [ l/2,-d,0], RIGHT),
]; ];
attachable(anchor,spin, two_d=true, size=size, anchors=anchors) { attachable(anchor,spin, two_d=true, size=size, anchors=anchors) {
right(gear_travel) polygon(path); right(gear_travel) polygon(path);
@ -1465,7 +1525,6 @@ module rack2d(
// Function&Module: bevel_gear() // Function&Module: bevel_gear()
// Synopsis: Creates a straight or spiral bevel gear. // Synopsis: Creates a straight or spiral bevel gear.
// SynTags: Geom, VNF // SynTags: Geom, VNF
@ -1513,7 +1572,7 @@ module rack2d(
// shaft_diam = Diameter of the hole in the center, in mm. Module use only. Default: 0 (no shaft hole) // shaft_diam = Diameter of the hole in the center, in mm. Module use only. Default: 0 (no shaft hole)
// hide = Number of teeth to delete to make this only a fraction of a circle. Default: 0 // hide = Number of teeth to delete to make this only a fraction of a circle. Default: 0
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20 // pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20
// clearance = Clearance gap at the bottom of the inter-tooth valleys. // clearance = Clearance gap at the bottom of the inter-tooth valleys. Default: module/4
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0 // backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0
// cutter_radius = Radius of spiral arc for teeth. If 0, then gear will not be spiral. Default: 0 // cutter_radius = Radius of spiral arc for teeth. If 0, then gear will not be spiral. Default: 0
// spiral_angle = The base angle for spiral teeth. Default: 0 // spiral_angle = The base angle for spiral teeth. Default: 0
@ -1768,7 +1827,7 @@ module bevel_gear(
// left_handed = If true, the gear returned will have a left-handed spiral. Default: false // left_handed = If true, the gear returned will have a left-handed spiral. Default: false
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20 // pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0 // backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0
// clearance = Clearance gap at the bottom of the inter-tooth valleys. // clearance = Clearance gap at the bottom of the inter-tooth valleys. Default: module/4
// profile_shift = Profile shift factor x. // profile_shift = Profile shift factor x.
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter. // diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
// mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth. // mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth.
@ -1932,7 +1991,7 @@ module worm(
// left_handed = If true, the gear returned will have a left-handed spiral. Default: false // left_handed = If true, the gear returned will have a left-handed spiral. Default: false
// pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20 // pressure_angle = Controls how straight or bulged the tooth sides are. In degrees. Default: 20
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0 // backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle. Default: 0
// clearance = Clearance gap at the bottom of the inter-tooth valleys. // clearance = Clearance gap at the bottom of the inter-tooth valleys. Default: module/4
// profile_shift = Profile shift factor x. // profile_shift = Profile shift factor x.
// slices = The number of vertical slices to refine the curve of the worm throat. Default: 10 // slices = The number of vertical slices to refine the curve of the worm throat. Default: 10
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter. // diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
@ -2515,7 +2574,7 @@ function _adendum(
/// The depth of the gear tooth valley, below the pitch radius. /// The depth of the gear tooth valley, below the pitch radius.
/// Arguments: /// Arguments:
/// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm. /// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
/// clearance = If given, sets the clearance between meshing teeth. /// clearance = If given, sets the clearance between meshing teeth. Default: module/4
/// profile_shift = Profile shift factor x. /// profile_shift = Profile shift factor x.
/// --- /// ---
/// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter. /// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
@ -2610,7 +2669,7 @@ function pitch_radius(
// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm. // circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
// teeth = The number of teeth on the gear. // teeth = The number of teeth on the gear.
// --- // ---
// clearance = If given, sets the clearance between meshing teeth. // clearance = If given, sets the clearance between meshing teeth. Default: module/4
// profile_shift = Profile shift factor x. // profile_shift = Profile shift factor x.
// internal = If true, calculate for an internal gear. // internal = If true, calculate for an internal gear.
// helical = The helical angle (from vertical) of the teeth on the gear. Default: 0 // helical = The helical angle (from vertical) of the teeth on the gear. Default: 0
@ -2656,7 +2715,7 @@ function outer_radius(circ_pitch, teeth, clearance, internal=false, helical=0, p
/// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm. /// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
/// teeth = The number of teeth on the gear. /// teeth = The number of teeth on the gear.
/// --- /// ---
/// clearance = If given, sets the clearance between meshing teeth. /// clearance = If given, sets the clearance between meshing teeth. Default: module/4
/// internal = If true, calculate for an internal gear. /// internal = If true, calculate for an internal gear.
/// helical = The helical angle (from vertical) of the teeth on the gear. Default: 0 /// helical = The helical angle (from vertical) of the teeth on the gear. Default: 0
/// profile_shift = Profile shift factor x. /// profile_shift = Profile shift factor x.
@ -2766,7 +2825,7 @@ function bevel_pitch_angle(teeth, mate_teeth, drive_angle=90) =
// --- // ---
// 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 fit 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. Default: module/4
// mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth. // mod = The metric module/modulus of the gear, or mm of pitch diameter per tooth.
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter. // diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
// Example: // Example:
@ -2808,7 +2867,8 @@ function worm_gear_thickness(circ_pitch, teeth, worm_diam, worm_arc=60, crowning
// Description: // Description:
// Calculate the distance between the centers of two spur gears gears or helical gears with parallel axes, // Calculate the distance between the centers of two spur gears gears or helical gears with parallel axes,
// taking into account profile shifting and helical angle. You can give the helical angle as either positive or negative. // taking into account profile shifting and helical angle. You can give the helical angle as either positive or negative.
// Set the tooth count to zero to use a rack. // If you set one of the tooth counts to zero than that gear will be treated as a rack and the distance returned is the
// distance between the rack's pitch line and the gear's center.
// Arguments: // Arguments:
// teeth1 = Total number of teeth in the first gear. If given 0, we assume this is a rack or worm. // teeth1 = Total number of teeth in the first gear. If given 0, we assume this is a rack or worm.
// teeth2 = Total number of teeth in the second gear. If given 0, we assume this is a rack or worm. // teeth2 = Total number of teeth in the second gear. If given 0, we assume this is a rack or worm.
@ -2843,13 +2903,14 @@ function worm_gear_thickness(circ_pitch, teeth, worm_diam, worm_arc=60, crowning
// Example(2D): Profile shifted gear and a rack // Example(2D): Profile shifted gear and a rack
// mod=3; teeth=8; // mod=3; teeth=8;
// d = gear_dist(mod=mod, teeth, 0); // d = gear_dist(mod=mod, teeth, 0);
// rack2d(mod=mod, teeth=5, height=9); // rack2d(mod=mod, teeth=5, bottom=9);
// back(d) spur_gear2d(mod=mod, teeth=teeth, gear_spin=180/teeth); // back(d) spur_gear2d(mod=mod, teeth=teeth, gear_spin=180/teeth);
// Example(VPT=[-0.0608489,1.3772,-3.68839],VPR=[63.4,0,29.7],VPD=113.336): Profile shifted helical gear and rack // Example(VPT=[-0.0608489,1.3772,-3.68839],VPR=[63.4,0,29.7],VPD=113.336): Profile shifted helical gear and rack
// mod=3; teeth=8; helical=29; // mod=3; teeth=8; helical=29;
// d = gear_dist(mod=mod, teeth, 0, helical); // d = gear_dist(mod=mod, teeth, 0, helical);
// rack(mod=mod, teeth=5, height=9, helical=helical, orient=FWD); // rack(mod=mod, teeth=5, helical=helical, orient=FWD);
// fwd(d) spur_gear(mod=mod, teeth=teeth, helical=-helical, gear_spin=180/teeth); // color("lightblue")
// fwd(d) spur_gear(mod=mod, teeth=teeth, helical=-helical, gear_spin=180/teeth);
function gear_dist( function gear_dist(
teeth1, teeth1,
teeth2, teeth2,
@ -2865,8 +2926,8 @@ function gear_dist(
assert(teeth1>0 || teeth2>0, "One of the teeth counts must be nonzero") assert(teeth1>0 || teeth2>0, "One of the teeth counts must be nonzero")
let( let(
mod = module_value(mod=mod,circ_pitch= circ_pitch, diam_pitch=diam_pitch), mod = module_value(mod=mod,circ_pitch= circ_pitch, diam_pitch=diam_pitch),
profile_shift1 = default(profile_shift1, teeth1>0? auto_profile_shift(teeth1,pressure_angle,helical) : 0), profile_shift1 = default(profile_shift1, auto_profile_shift(teeth1,pressure_angle,helical)),
profile_shift2 = default(profile_shift2, teeth2>0? auto_profile_shift(teeth2,pressure_angle,helical) : 0) profile_shift2 = default(profile_shift2, auto_profile_shift(teeth2,pressure_angle,helical))
) )
teeth1==0 || teeth2==0? pitch_radius(mod=mod, teeth=teeth1+teeth2, helical=helical) + (profile_shift1+profile_shift2)*mod teeth1==0 || teeth2==0? pitch_radius(mod=mod, teeth=teeth1+teeth2, helical=helical) + (profile_shift1+profile_shift2)*mod
: :
@ -2924,7 +2985,11 @@ function gear_dist_skew(teeth1,teeth2,helical1,helical2,profile_shift1,profile_s
let( let(
profile_shift1 = default(profile_shift1, auto_profile_shift(teeth1,pressure_angle,helical1)), profile_shift1 = default(profile_shift1, auto_profile_shift(teeth1,pressure_angle,helical1)),
profile_shift2 = default(profile_shift2, auto_profile_shift(teeth2,pressure_angle,helical2)), profile_shift2 = default(profile_shift2, auto_profile_shift(teeth2,pressure_angle,helical2)),
mod = module_value(circ_pitch=circ_pitch, diam_pitch=diam_pitch, mod=mod), mod = module_value(circ_pitch=circ_pitch, diam_pitch=diam_pitch, mod=mod)
)
teeth1==0 || teeth2==0? pitch_radius(mod=mod, teeth=teeth1+teeth2, helical=teeth1?helical1:helical2) + (profile_shift1+profile_shift2)*mod
:
let(
pa_normal_eff = _working_normal_pressure_angle_skew(teeth1,profile_shift1,helical1,teeth2,profile_shift2,helical2,pressure_angle), pa_normal_eff = _working_normal_pressure_angle_skew(teeth1,profile_shift1,helical1,teeth2,profile_shift2,helical2,pressure_angle),
dist_adj = 0.5*(teeth1/cos(helical1)^3+teeth2/cos(helical2)^3)*(cos(pressure_angle)/cos(pa_normal_eff)-1) dist_adj = 0.5*(teeth1/cos(helical1)^3+teeth2/cos(helical2)^3)*(cos(pressure_angle)/cos(pa_normal_eff)-1)
) )
@ -2943,45 +3008,17 @@ function _working_normal_pressure_angle_skew(teeth1,profile_shift1,helical1, tee
// Usage: // Usage:
// ang = gear_skew_angle(mod=|diam_pitch=|circ_pitch=, teeth1, teeth2, helical1, helical2, [profile_shift1], [profile_shift2], [pressure_angle=] // ang = gear_skew_angle(mod=|diam_pitch=|circ_pitch=, teeth1, teeth2, helical1, helical2, [profile_shift1], [profile_shift2], [pressure_angle=]
// Description: // Description:
// Compute the correct skew angle between the axes of two profile shifted helical gears. When profile shifting is zero // Compute the correct skew angle between the axes of two profile shifted helical gears. When profile shifting is zero, or when one of
// this angle is simply the sum of the helical angles of the two gears. // the gears is a rack, this angle is simply the sum of the helical angles of the two gears. But with profile shifted gears, a small
// correction to the skew angle is needed for proper meshing.
// Example: // Example(Med,NoAxes,VPT=[-2.62091,2.01048,-1.31405],VPR=[55,0,25],VPD=74.4017): These gears are auto profile shifted and as a result, do not mesh at the sum of their helical angles, but at 2.5 degrees more.
// circ_pitch=5; teeth1=5; teeth2=7; ha1=45; ha2=30; thick=10; // circ_pitch=5; teeth1=12; teeth2=7; ha1=25; ha2=30; thick=10;
// d = gear_dist_skew(circ_pitch=circ_pitch, teeth1, teeth2, ha1, ha2);
/* // ang = gear_skew_angle(circ_pitch=circ_pitch, teeth1, teeth2, helical1=ha1, helical2=ha2); // Returns 57.7
// left(d/2)
circ_pitch=5; teeth1=10; teeth2=14; ha1=45; ha2=30; thick=10; // spur_gear(circ_pitch, teeth1, helical=ha1, thickness=thick, gear_spin=-90);
d = .4+gear_dist_skew(circ_pitch=circ_pitch, teeth1, teeth2, helical1=ha1, helical2=ha2);//,profile_shift1=0,profile_shift2=0)+2; // right(d/2) color("lightblue")
d0 = gear_dist_skew(circ_pitch=circ_pitch, teeth1, teeth2, helical1=ha1, helical2=ha2,profile_shift1=0,profile_shift2=0); // xrot(ang) spur_gear(circ_pitch, teeth2, helical=ha2, thickness=thick, gear_spin=90-180/teeth2);
echo(d=d,d0);
ang = gear_skew_angle(circ_pitch=circ_pitch, teeth1, teeth2, helical1=ha1, helical2=ha2);
echo(ang=ang);
color_overlaps()
{
// left(d/2) spur_gear(circ_pitch, teeth1, helical=ha1, thickness=thick, gear_spin=-90);
// right(d/2) xrot(ang) spur_gear(circ_pitch, teeth2, helical=ha2, thickness=thick, gear_spin=90-180/teeth2);
left(d/2) spur_gear(circ_pitch, teeth1, helical=ha1, thickness=thick);
right(d/2) xrot(ang) spur_gear(circ_pitch, teeth2, helical=ha2, thickness=thick,gear_spin=180/teeth2);
}
*/
/*
mod=3; teeth1=15; ha1=20; ps1=0.4;
teeth2=24; ha2=30; ps2=0.2;
thick=20;
d = gear_dist_skew(mod=mod, teeth1, teeth2, ha1, ha2, ps1,ps2);
echo(d=d);
ang = gear_skew_angle(mod=mod, teeth1, teeth2, ha1, ha2, ps1, ps2);
echo(ang=ang);
color_overlaps(){
left(d/2) spur_gear(mod=mod, teeth=teeth1, helical=ha1, thickness=thick, gear_spin=-90,profile_shift=ps1);
right(d/2) xrot(ang) spur_gear(mod=mod, teeth=teeth2, helical=ha2, thickness=thick, gear_spin=90-180/teeth2,profile_shift=ps2);
}
*/
function gear_skew_angle(teeth1,teeth2,helical1,helical2,profile_shift1,profile_shift2,pressure_angle=20, mod, circ_pitch, diam_pitch) = function gear_skew_angle(teeth1,teeth2,helical1,helical2,profile_shift1,profile_shift2,pressure_angle=20, mod, circ_pitch, diam_pitch) =
assert(all_nonnegative([teeth1,teeth2]),"Must give nonnegative values for teeth") assert(all_nonnegative([teeth1,teeth2]),"Must give nonnegative values for teeth")
@ -2989,15 +3026,13 @@ function gear_skew_angle(teeth1,teeth2,helical1,helical2,profile_shift1,profile_
let( let(
profile_shift1 = default(profile_shift1, auto_profile_shift(teeth1,pressure_angle,helical1)), profile_shift1 = default(profile_shift1, auto_profile_shift(teeth1,pressure_angle,helical1)),
profile_shift2 = default(profile_shift2, auto_profile_shift(teeth2,pressure_angle,helical2)) profile_shift2 = default(profile_shift2, auto_profile_shift(teeth2,pressure_angle,helical2))
,fe=echo(ingsaps=profile_shift1,profile_shift2)
) )
// profile_shift1==0 && profile_shift2==0 ? helical1+helical2 profile_shift1==0 && profile_shift2==0 ? helical1+helical2
// : : teeth1==0 || teeth2==0 ? helical1+helical2
let( : let(
mod = module_value(mod=mod, circ_pitch=circ_pitch, diam_pitch=diam_pitch), mod = module_value(mod=mod, circ_pitch=circ_pitch, diam_pitch=diam_pitch),
a = gear_dist_skew(mod=mod,teeth1,teeth2,helical1,helical2,profile_shift1,profile_shift2,pressure_angle=pressure_angle), a = gear_dist_skew(mod=mod,teeth1,teeth2,helical1,helical2,profile_shift1,profile_shift2,pressure_angle=pressure_angle),
b = gear_dist_skew(mod=mod,teeth1,teeth2,helical1,helical2,0,0,pressure_angle=pressure_angle), b = gear_dist_skew(mod=mod,teeth1,teeth2,helical1,helical2,0,0,pressure_angle=pressure_angle),
fdase= echo(a=a,b=b),
d1 = 2*pitch_radius(mod=mod,teeth=teeth1,helical=helical1), d1 = 2*pitch_radius(mod=mod,teeth=teeth1,helical=helical1),
d2 = 2*pitch_radius(mod=mod,teeth=teeth2,helical=helical2), d2 = 2*pitch_radius(mod=mod,teeth=teeth2,helical=helical2),
dw1 = 2*a*d1/(d1+d2), dw1 = 2*a*d1/(d1+d2),