mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Merge pull request #1213 from adrianVmariano/master
replace mesh_radius with gear_dist
This commit is contained in:
commit
2921095633
3 changed files with 210 additions and 121 deletions
292
gears.scad
292
gears.scad
|
@ -83,21 +83,21 @@ function _inherit_gear_thickness(thickness) =
|
|||
// Section: Involute Spur Gears
|
||||
// The simplest gear form is the involute spur gear, which is an extrusion of a two dimensional form.
|
||||
// Figure(Med,NoAxes): Involute Spur Gear
|
||||
// spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25);
|
||||
// spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25);
|
||||
// Continues:
|
||||
// The term "involute" refers to the shape of the teeth: the curves of the teeth involutes of circles,
|
||||
// which are curves that optimize gear performance.
|
||||
// Figure(2D,Med,NoAxes): The three marked circles are key references on gear teeth. The gear teeth are perpendicular to the base circle, as shown by the blue line, which is tangent to the base of the tooth. The pressure angle is the angle the tooth makes with the pitch circle. In this example, the pressure angle is 20 degrees, marked by the red lines.
|
||||
// The term "involute" refers to the shape of the teeth: the curves of the teeth involutes of circles,
|
||||
// which are curves that optimize gear performance.
|
||||
// Figure(2D,Med,NoAxes,VPD=[8.20073,73.8041,0],VPR=[0,0,0],VPD=150.196): The three marked circles are key references on gear teeth. The pitch circle, which is roughly in the middle of the teeth, is the reference used to define the pitch of teeth on the gear. The pressure angle is the angle the tooth makes with the pitch circle. In this example, the pressure angle is 20 degrees as shown by the red lines.
|
||||
// $fn=128;
|
||||
// intersection(){
|
||||
// spur_gear2d(mod=5,teeth=30,pressure_angle=20);
|
||||
// back(82)rect([45, 20],anchor=BACK);
|
||||
// }
|
||||
// color("black"){
|
||||
// stroke(arc(r=_base_radius(mod=5,teeth=30),angle=[70,110]),width=.25);
|
||||
// stroke(arc(r=_root_radius(mod=5,teeth=30),angle=[70,110]),width=.25);
|
||||
// stroke(arc(r=pitch_radius(mod=5,teeth=30),angle=[70,110]),width=.25);
|
||||
// stroke(arc(r=outer_radius(mod=5,teeth=30),angle=[70,110]),width=.25);
|
||||
// back(65)right(25)text("base circle",size=2.5);
|
||||
// back(63.5)right(24.2)text("root circle",size=2.5);
|
||||
// back(69.5)right(26.5)text("pitch circle",size=2.5);
|
||||
// back(74)right(28)text("outer circle",size=2.5);
|
||||
// }
|
||||
|
@ -132,25 +132,25 @@ function _inherit_gear_thickness(thickness) =
|
|||
// increase the force that tries to push the gears apart, and hence the load on the gear axles. The current standard pressure
|
||||
// angle is 20 degrees. It replaces an old 14.5 degree standard.
|
||||
// Figure(2D,Med,NoAxes): Teeth of the same size with different pressure angles. Note that 20 deg is the industry standard.
|
||||
// pang = [30,20,14.5];
|
||||
// ycopies(n=3,spacing=25){
|
||||
// pang = [30,20,14.5];
|
||||
// ycopies(n=3,spacing=25){
|
||||
// intersection(){
|
||||
// spur_gear2d(mod=5,teeth=30,pressure_angle=pang[$idx]);
|
||||
// back(82)rect([45, 20],anchor=BACK);
|
||||
// }
|
||||
// back(68)right(26)text(str(pang[$idx]), size=6.5);
|
||||
// }
|
||||
// }
|
||||
// Continues:
|
||||
// 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.
|
||||
// Figure(2D,Med,NoAxes): The clearance is extra space at the tooth valley that separates the tooth tip (in green) from the tooth valley below it. the gap between the top of the tooth (in green) and the bot
|
||||
// Figure(2D,Med,NoAxes,VPD=[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. the gap between the top of the tooth (in green) and the bot
|
||||
// intersection(){
|
||||
// rack2d(mod=5, teeth=10, height=15,clearance=undef,pressure_angle=14.5);
|
||||
// rect([35,20]);
|
||||
// }
|
||||
// color("lightgreen")render()
|
||||
// intersection(){
|
||||
// back(mesh_radius(mod=5, teeth=146,profile_shift=0))
|
||||
// back(gear_dist(mod=5, teeth1=146,teeth2=0,profile_shift1=0))
|
||||
// spur_gear2d(mod=5, teeth=146,clearance=undef,profile_shift=0,pressure_angle=14.5);
|
||||
// rect([45,20]);
|
||||
// }
|
||||
|
@ -161,11 +161,11 @@ function _inherit_gear_thickness(thickness) =
|
|||
// Continues:
|
||||
// Another clearance requirement can present a serious problem when the number of teeth is low. As the gear rotates, the
|
||||
// teeth may interfere with each other. This may require undercutting the gear teeth to create space, which weakens the teeth.
|
||||
// Figure(2D,Med,NoAxes): 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,VPD=[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;
|
||||
// rack2d(mod=5, teeth=3, height=15,clearance=.00001,pressure_angle=14.5);
|
||||
// left(2*PI*pitch_radius(mod=5, teeth=5)*ang/360)
|
||||
// color("lightgreen")back(mesh_radius(mod=5, teeth=5,profile_shift=0))zrot(ang)spur_gear2d(mod=5, teeth=5,clearance=.00001,profile_shift=0,pressure_angle=14.5);
|
||||
// color("lightgreen")back(gear_dist(mod=5, teeth1=5,profile_shift1=0,teeth2=0))zrot(ang)spur_gear2d(mod=5, teeth=5,clearance=.00001,profile_shift=0,pressure_angle=14.5);
|
||||
// Subsection: Corrected Gears and Profile Shifting
|
||||
// A solution to the problem of undercutting is to use profile shifting. Profile shifting uses a different portion of the
|
||||
// involute curve to form the gear teeth, and this adjustment to the tooth form can eliminate undercutting, while
|
||||
|
@ -180,16 +180,16 @@ function _inherit_gear_thickness(thickness) =
|
|||
// By default, the gear modules produce corrected gears. You can override this by specifying the profile shift
|
||||
// yourself. A small undercut maybe acceptable, for example: a rule of thumb indicates that gears as small as 14
|
||||
// teeth are OK with a 20 degree pressure angle, because the undercut is too small to weaken the teeth significantly.
|
||||
// Figure(2D,Med,NoAxes): Basic five tooth gear form on the left. Corrected gear with profile shifting on the right. The profile shifted teeth lack the weak undercut section. The axis of the corrected gear is shifted away from the mating rack.
|
||||
// Figure(2D,Med,NoAxes,VPD=[1.33179,10.6532,-0.0144912],VPR=[0,0,0],VPD=155.556): Basic five tooth gear form on the left. Corrected gear with profile shifting on the right. The profile shifted teeth lack the weak undercut section. The axis of the corrected gear is shifted away from the mating rack.
|
||||
// $fn=32;
|
||||
// ang1=-20;
|
||||
// ang2=20;
|
||||
// left(2*PI*pitch_radius(mod=5, teeth=5)*ang1/360)
|
||||
// left(3*5*PI/2)
|
||||
// back(mesh_radius(mod=5,teeth=5,profile_shift=0))zrot(ang1){spur_gear2d(mod=5, teeth=5, profile_shift=0, pressure_angle=14.5);color("black")circle(r=1);}
|
||||
// back(gear_dist(mod=5,teeth1=5,profile_shift1=0,teeth2=0))zrot(ang1){spur_gear2d(mod=5, teeth=5, profile_shift=0, pressure_angle=14.5);color("black")circle(r=1);}
|
||||
// left(2*PI*pitch_radius(mod=5, teeth=5)*ang2/360)
|
||||
// right(3*5*PI/2)
|
||||
// back(mesh_radius(mod=5,teeth=5))zrot(ang2){spur_gear2d(mod=5, teeth=5, pressure_angle=14.5);color("black")circle(r=1);}
|
||||
// back(gear_dist(mod=5,teeth1=5,teeth2=0))zrot(ang2){spur_gear2d(mod=5, teeth=5, pressure_angle=14.5);color("black")circle(r=1);}
|
||||
// rack2d(teeth=4, height=15, mod=5);
|
||||
// Section: Helical Gears
|
||||
// Helicals gears are a modification of spur gears. They can replace spur gears in any application. The teeth are cut
|
||||
|
@ -201,19 +201,24 @@ function _inherit_gear_thickness(thickness) =
|
|||
// Continues:
|
||||
// Helical gears have the same compatibility requirements as spur gears, with the additional requirement that
|
||||
// the helical angles must be opposite each other, so a gear with a helical angle of 25 must mesh with one
|
||||
// that has an angle of -25. The separation between gears also has an additional correction that depends on the helical angle,
|
||||
// so it will be different from a spur gear with the same parameters.
|
||||
// Figure(Anim,Frames=10): Meshing compatible helical gears
|
||||
// that has an angle of -25. The separation between gears also has an additional correction that depends on the cosine of
|
||||
// the helical angle, so it will be different from a spur gear with the same parameters. This can allow you to
|
||||
// make much bigger spacing adjustments than are possible with profile shifting---without changing the tooth count.
|
||||
// The effective pressure angle of helical gears is larger than the nominal pressure angle. This can make it possible
|
||||
// to avoid undercutting without having to use profile shifting, so smaller tooth count gears can be more effective
|
||||
// using the helical form.
|
||||
// Figure(Anim,Frames=10,VPD=[43.8006,15.9214,3.52727],VPR=[62.3,0,20.3],VPD=446.129): Meshing compatible helical gears
|
||||
// zrot($t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=-29);
|
||||
// right(2*mesh_radius(mod=5,teeth=18,helical=-29))zrot(360/18/2)zrot(-$t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=29);
|
||||
// right(gear_dist(mod=5,teeth1=18,teeth2=18,helical=29))
|
||||
// zrot(360/18/2)zrot(-$t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=29);
|
||||
// Continues:
|
||||
// Helical gears can mesh in a second manner that is different from spur gears at skew, or crossed axis. These are also
|
||||
// sometimes called "screw gears". In fact, the general requirement for two helical gears to mesh is that the angle
|
||||
// between the gears' axes must equal the sum of the helical angles of the two gears, thus for parallel axes, the helical
|
||||
// angles must sum to zero.
|
||||
// Figure(Anim,Frames=10): Two helical gears with 22.5 degree helical angle meshing with their axes at a 45 degree angle.
|
||||
// color("lightblue") zrot($t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=22.5);
|
||||
// right(2*mesh_radius(mod=5,teeth=18,helical=22.5))xrot(45)zrot(360/18/2)zrot(-$t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=22.5);
|
||||
// Figure(Anim,Frames=10): NOT WORKING NOW Two helical gears with 22.5 degree helical angle meshing with their axes at a 45 degree angle.
|
||||
// //color("lightblue") zrot($t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=22.5);
|
||||
// // right(2*mesh_radius(mod=5,teeth=18,helical=22.5))xrot(45)zrot(360/18/2)zrot(-$t*360/18)spur_gear(mod=5,teeth=18,pressure_angle=20,thickness=25,helical=22.5);
|
||||
// Section: Herringbone Gears
|
||||
// The herringbone gear addresses the problem of axial forces that afflict helical gears by having one section that slopes to the
|
||||
// right and another that slopes to the left. Herringbone gears also have the advantage of being self-aligning.
|
||||
|
@ -249,7 +254,7 @@ function _inherit_gear_thickness(thickness) =
|
|||
// .
|
||||
// The module `spur_gear()` gives a gear in
|
||||
// the XY plane, centered on the origin, with one tooth centered on the positive Y axis. The most
|
||||
// important function is `mesh_radius()`, which tells how far apart to space gears that are meshing, and
|
||||
// important function is `gear_dist()`, which tells how far apart to space gears that are meshing, and
|
||||
// `outer_radius()`, which gives the size of the region filled by the gear. A gear has a "pitch
|
||||
// circle", which is an invisible circle that cuts through the middle of each tooth (though not the
|
||||
// exact center). In order for two gears to mesh, their pitch circles should just touch. So the
|
||||
|
@ -305,31 +310,32 @@ function _inherit_gear_thickness(thickness) =
|
|||
// circ_pitch=5, teeth=20, thickness=10, shaft_diam=5,
|
||||
// helical=30, herringbone=true, slices=5
|
||||
// );
|
||||
// Example(Big): Effects of Profile Shifting.
|
||||
// Example(2D,Big): Effects of Profile Shifting.
|
||||
// circ_pitch=5; teeth=7; thick=10; shaft=5; strokewidth=0.2;
|
||||
// pr = pitch_radius(circ_pitch, teeth);
|
||||
// left(10) {
|
||||
// profile_shift = 0;
|
||||
// mr = mesh_radius(circ_pitch,teeth,profile_shift=profile_shift);
|
||||
// back(mr) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift);
|
||||
// d = gear_dist(circ_pitch,teeth,0,profile_shift1=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);
|
||||
// color("black") up(thick/2) linear_extrude(height=0.1) {
|
||||
// back(mr) 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);
|
||||
// }
|
||||
// }
|
||||
// right(10) {
|
||||
// profile_shift = 0.59;
|
||||
// mr = mesh_radius(circ_pitch,teeth,profile_shift=profile_shift);
|
||||
// back(mr) spur_gear(circ_pitch, teeth, thick, shaft, profile_shift=profile_shift);
|
||||
// d = gear_dist(circ_pitch,teeth,0,profile_shift1=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);
|
||||
// color("black") up(thick/2) linear_extrude(height=0.1) {
|
||||
// back(mr)
|
||||
// back(d)
|
||||
// dashed_stroke(circle(r=pr), width=strokewidth, closed=true);
|
||||
// dashed_stroke([[-7.5,0],[7.5,0]], width=strokewidth);
|
||||
// }
|
||||
// }
|
||||
// Example(Anim,Frames=8,VPT=[0,30,0],VPR=[0,0,0],VPD=300): Assembly of Gears
|
||||
// $fn=12;
|
||||
// n1 = 11; //red gear number of teeth
|
||||
// n2 = 20; //green gear
|
||||
// n3 = 6; //blue gear
|
||||
|
@ -339,52 +345,50 @@ function _inherit_gear_thickness(thickness) =
|
|||
// thickness = 6;
|
||||
// hole = 3;
|
||||
// rack_base = 12;
|
||||
// r1 = mesh_radius(circ_pitch,n1);
|
||||
// r2 = mesh_radius(circ_pitch,n2);
|
||||
// r3 = mesh_radius(circ_pitch,n3);
|
||||
// r4 = mesh_radius(circ_pitch,n4);
|
||||
// r5 = mesh_radius(circ_pitch,n5);
|
||||
// d12 = gear_dist(circ_pitch,teeth1=n1,teeth2=n2);
|
||||
// d13 = gear_dist(circ_pitch,teeth1=n1,teeth2=n3);
|
||||
// d14 = gear_dist(circ_pitch,teeth1=n1,teeth2=n4);
|
||||
// d1r = gear_dist(circ_pitch,teeth1=n1,teeth2=0);
|
||||
// a1 = $t * 360 / n1;
|
||||
// a2 = -$t * 360 / n2 + 180/n2;
|
||||
// a3 = -$t * 360 / n3 - 3*90/n3;
|
||||
// a4 = -$t * 360 / n4 - 3.5*180/n4;
|
||||
// color("#f77") zrot(a1) spur_gear(circ_pitch,n1,thickness,hole);
|
||||
// color("#7f7") back(r1+r2) zrot(a2) spur_gear(circ_pitch,n2,thickness,hole);
|
||||
// color("#77f") right(r1+r3) zrot(a3) spur_gear(circ_pitch,n3,thickness,hole);
|
||||
// color("#fc7") left(r1+r4) zrot(a4) spur_gear(circ_pitch,n4,thickness,hole,hide=n4-3);
|
||||
// color("#ccc") fwd(r1) right(circ_pitch*$t)
|
||||
// color("#7f7") back(d12) zrot(a2) spur_gear(circ_pitch,n2,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("#ccc") fwd(d1r) right(circ_pitch*$t)
|
||||
// rack(pitch=circ_pitch,teeth=n5,thickness=thickness,height=rack_base,anchor=CENTER,orient=BACK);
|
||||
// Example: Helical gears meshing with non-parallel shafts
|
||||
// ang1 = 30;
|
||||
// ang2 = 10;
|
||||
// circ_pitch = 5;
|
||||
// n = 20;
|
||||
// r1 = mesh_radius(circ_pitch,n,helical=ang1);
|
||||
// r2 = mesh_radius(circ_pitch,n,helical=ang2);
|
||||
// left(r1) spur_gear(
|
||||
// circ_pitch, teeth=n, thickness=10,
|
||||
// shaft_diam=5, helical=ang1, slices=12,
|
||||
// gear_spin=-90
|
||||
// );
|
||||
// right(r2)
|
||||
// xrot(ang1+ang2)
|
||||
// spur_gear(
|
||||
// circ_pitch=circ_pitch, teeth=n, thickness=10,
|
||||
// shaft_diam=5, helical=ang2, slices=12,
|
||||
// gear_spin=90-180/n
|
||||
// );
|
||||
// Example: Helical gears meshing with non-parallel shafts BROKEN
|
||||
// // ang1 = 30;
|
||||
// // ang2 = 10;
|
||||
// // circ_pitch = 5;
|
||||
// // n = 20;
|
||||
// // r1 = mesh_radius(circ_pitch,n,helical=ang1);
|
||||
// // r2 = mesh_radius(circ_pitch,n,helical=ang2);
|
||||
// // left(r1) spur_gear(
|
||||
// // circ_pitch, teeth=n, thickness=10,
|
||||
// // shaft_diam=5, helical=ang1, slices=12,
|
||||
// // gear_spin=-90
|
||||
// // );
|
||||
// // right(r2)
|
||||
// // xrot(ang1+ang2)
|
||||
// // spur_gear(
|
||||
// // circ_pitch=circ_pitch, teeth=n, thickness=10,
|
||||
// // shaft_diam=5, helical=ang2, slices=12,
|
||||
// // gear_spin=90-180/n
|
||||
// // );
|
||||
// Example(Anim,Frames=36,VPT=[0,0,0],VPR=[55,0,25],VPD=375): Planetary Gear Assembly
|
||||
// rteeth=56; pteeth=16; cteeth=24;
|
||||
// circ_pitch=5; thick=10; pa=20;
|
||||
// cr = mesh_radius(circ_pitch,cteeth);
|
||||
// pr = mesh_radius(circ_pitch,pteeth);
|
||||
// gd = gear_dist(circ_pitch, cteeth, pteeth);
|
||||
// ring_gear(
|
||||
// circ_pitch=circ_pitch,
|
||||
// teeth=rteeth,
|
||||
// thickness=thick,
|
||||
// pressure_angle=pa);
|
||||
// for (a=[0:3]) {
|
||||
// zrot($t*90+a*90) back(cr+pr) {
|
||||
// zrot($t*90+a*90) back(gd) {
|
||||
// color("green")
|
||||
// spur_gear(
|
||||
// circ_pitch=circ_pitch,
|
||||
|
@ -403,7 +407,7 @@ function _inherit_gear_thickness(thickness) =
|
|||
// thickness=thick,
|
||||
// shaft_diam=5,
|
||||
// pressure_angle=pa);
|
||||
|
||||
//
|
||||
function spur_gear(
|
||||
circ_pitch,
|
||||
teeth,
|
||||
|
@ -600,7 +604,7 @@ module spur_gear(
|
|||
// returns a 2D region for the 2D involute spur gear. Normally, you should just specify the
|
||||
// first 2 parameters `circ_pitch` and `teeth`, and let the rest be default values.
|
||||
// Meshing gears must match in `circ_pitch`, `pressure_angle`, and `helical`, and be separated by
|
||||
// the sum of their meshing radii, which can be found with `mesh_radius()`.
|
||||
// the distance given by {{gear_dist()}}.
|
||||
// Arguments:
|
||||
// circ_pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
|
||||
// teeth = Total number of teeth around the spur gear.
|
||||
|
@ -633,7 +637,7 @@ module spur_gear(
|
|||
// module the_gear(profile_shift=0) {
|
||||
// $fn=72;
|
||||
// pr = pitch_radius(circ_pitch,teeth);
|
||||
// mr = mesh_radius(circ_pitch,teeth,profile_shift=profile_shift);
|
||||
// mr = gear_dist(circ_pitch,teeth,profile_shift1=profile_shift,teeth2=0);
|
||||
// back(mr) {
|
||||
// spur_gear2d(circ_pitch, teeth, shaft_diam=shaft, profile_shift=profile_shift);
|
||||
// up(0.1) color("black")
|
||||
|
@ -651,14 +655,13 @@ module spur_gear(
|
|||
// Example(2D): Planetary Gear Assembly
|
||||
// rteeth=56; pteeth=16; cteeth=24;
|
||||
// circ_pitch=5; pa=20;
|
||||
// cr = mesh_radius(circ_pitch, cteeth);
|
||||
// pr = mesh_radius(circ_pitch, pteeth);
|
||||
// gd = gear_dist(circ_pitch, cteeth,pteeth);
|
||||
// ring_gear2d(
|
||||
// circ_pitch=circ_pitch,
|
||||
// teeth=rteeth,
|
||||
// pressure_angle=pa);
|
||||
// for (a=[0:3]) {
|
||||
// zrot(a*90) back(cr+pr) {
|
||||
// zrot(a*90) back(gd) {
|
||||
// color("green")
|
||||
// spur_gear2d(
|
||||
// circ_pitch=circ_pitch,
|
||||
|
@ -2736,66 +2739,148 @@ function worm_gear_thickness(circ_pitch, teeth, worm_diam, worm_arc=60, crowning
|
|||
) thickness;
|
||||
|
||||
|
||||
// Function: mesh_radius()
|
||||
// Function: gear_dist()
|
||||
// Synopsis: Returns the distance between two gear centers.
|
||||
// Topics: Gears, Parts
|
||||
// See Also: worm(), worm_gear(), pitch_radius(), outer_radius()
|
||||
// Usage:
|
||||
// dist = mesh_radius(pitch, teeth, [helical=], [profile_shift=], [pressure_angle=]);
|
||||
// dist = mesh_radius(mod=, teeth=, [helical=], [profile_shift=], [pressure_angle=]);
|
||||
// dist = gear_dist(pitch, teeth1, teeth2, [helical=], [profile_shift=], [pressure_angle=]);
|
||||
// dist = gear_dist(mod=, teeth=, [helical=], [profile_shift=], [pressure_angle=]);
|
||||
// Description:
|
||||
// Calculate the distance between the centers of two gears.
|
||||
// Calculate the distance between the centers of two gears with parallel axes, taking into account
|
||||
// profile shifting and helical angles.
|
||||
// Arguments:
|
||||
// pitch = The circular pitch, or distance between teeth around the pitch circle, in mm. Default: 5
|
||||
// teeth = 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.
|
||||
// ---
|
||||
// helical = The helical angle (from vertical) of the teeth on the first gear. Default: 0
|
||||
// profile_shift = Profile shift factor x for the first gear. Default: 0
|
||||
// helical = The absolute value of the helical angle (from vertical) of the teeth on the gears. Default: 0
|
||||
// profile_shift1 = Profile shift factor x for the first gear. Default: 0
|
||||
// profile_shift2 = Profile shift factor x for the second gear. Default: 0
|
||||
// pressure_angle = The pressure angle of the gear.
|
||||
// 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.
|
||||
// Example(2D):
|
||||
// pitch=5; teeth1=7; teeth2=24;
|
||||
// mr1 = mesh_radius(pitch, teeth1);
|
||||
// mr2 = mesh_radius(pitch, teeth2);
|
||||
// left(mr1) spur_gear2d(pitch, teeth1, gear_spin=-90);
|
||||
// right(mr2) spur_gear2d(pitch, teeth2, gear_spin=90-180/teeth2);
|
||||
// Example: Non-parallel Helical Gears
|
||||
// pitch=5; teeth1=15; teeth2=24; ha1=45; ha2=30; thick=10;
|
||||
// mr1 = mesh_radius(pitch, teeth1, helical=ha1);
|
||||
// mr2 = mesh_radius(pitch, teeth2, helical=ha2);
|
||||
// left(mr1) spur_gear(pitch, teeth1, helical=ha1, thickness=thick, gear_spin=-90);
|
||||
// right(mr2) xrot(ha1+ha2) spur_gear(pitch, teeth2, helical=ha2, thickness=thick, gear_spin=90-180/teeth2);
|
||||
// d = gear_dist(pitch, teeth1, teeth2);
|
||||
// spur_gear2d(pitch, teeth1, gear_spin=-90);
|
||||
// right(d) spur_gear2d(pitch, teeth2, gear_spin=90-180/teeth2);
|
||||
// Example: Non-parallel Helical Gears BROKEN
|
||||
// //pitch=5; teeth1=15; teeth2=24; ha1=45; ha2=30; thick=10;
|
||||
// //d = mesh_radius(pitch, teeth1, teeth2, helical=ha1);
|
||||
// //mr2 = mesh_radius(pitch, teeth2, helical=ha2);
|
||||
// //left(mr1) spur_gear(pitch, teeth1, helical=ha1, thickness=thick, gear_spin=-90);
|
||||
// //right(mr2) xrot(ha1+ha2) spur_gear(pitch, teeth2, helical=ha2, thickness=thick, gear_spin=90-180/teeth2);
|
||||
// Example(2D): Disable Auto Profile Shifting on the Small Gear
|
||||
// pitch=5; teeth1=7; teeth2=24;
|
||||
// mr1 = mesh_radius(pitch, teeth1, profile_shift=0);
|
||||
// mr2 = mesh_radius(pitch, teeth2);
|
||||
// left(mr1) spur_gear2d(pitch, teeth1, profile_shift=0, gear_spin=-90);
|
||||
// right(mr2) spur_gear2d(pitch, teeth2, gear_spin=90-180/teeth2);
|
||||
// d = gear_dist(pitch, teeth1, teeth2, profile_shift1=0);
|
||||
// spur_gear2d(pitch, teeth1, profile_shift=0, gear_spin=-90);
|
||||
// right(d) spur_gear2d(pitch, teeth2, gear_spin=90-180/teeth2);
|
||||
// Example(2D): Manual Profile Shifting
|
||||
// pitch=5; teeth1=7; teeth2=24; ps1 = 0.5; ps2 = -0.2;
|
||||
// mr1 = mesh_radius(pitch, teeth1, profile_shift=ps1);
|
||||
// mr2 = mesh_radius(pitch, teeth2, profile_shift=ps2);
|
||||
// left(mr1) spur_gear2d(pitch, teeth1, profile_shift=ps1, gear_spin=-90);
|
||||
// right(mr2) spur_gear2d(pitch, teeth2, profile_shift=ps2, gear_spin=90-180/teeth2);
|
||||
// d = gear_dist(pitch, teeth1, teeth2, profile_shift1=ps1, profile_shift2=ps2);
|
||||
// spur_gear2d(pitch, teeth1, profile_shift=ps1, gear_spin=-90);
|
||||
// right(d) spur_gear2d(pitch, teeth2, profile_shift=ps2, gear_spin=90-180/teeth2);
|
||||
|
||||
function mesh_radius(
|
||||
function gear_dist(
|
||||
circ_pitch,
|
||||
teeth,
|
||||
teeth1,
|
||||
teeth2,
|
||||
helical=0,
|
||||
profile_shift,
|
||||
profile_shift1,
|
||||
profile_shift2,
|
||||
pressure_angle=20,
|
||||
diam_pitch,
|
||||
mod,
|
||||
pitch
|
||||
) =
|
||||
let(
|
||||
circ_pitch = circular_pitch(pitch, mod, circ_pitch, diam_pitch),
|
||||
profile_shift = default(profile_shift, teeth>0? auto_profile_shift(teeth,pressure_angle) : 0),
|
||||
mod = circ_pitch / PI,
|
||||
pr = teeth>0? pitch_radius(circ_pitch, teeth, helical) : 0,
|
||||
r = pr + profile_shift * mod
|
||||
) r;
|
||||
mod = circular_pitch(pitch, mod, circ_pitch, diam_pitch)/PI,
|
||||
profile_shift1 = default(profile_shift1, teeth1>0? auto_profile_shift(teeth1,pressure_angle,helical) : 0),
|
||||
profile_shift2 = default(profile_shift2, teeth2>0? auto_profile_shift(teeth2,pressure_angle,helical) : 0),
|
||||
pa_eff = _working_pressure_angle(teeth1,profile_shift1,teeth2,profile_shift2,pressure_angle,helical),
|
||||
pa_transv = atan(tan(pressure_angle)/cos(helical))
|
||||
)
|
||||
mod*(teeth1+teeth2)*cos(pa_transv)/cos(pa_eff)/cos(helical)/2;
|
||||
|
||||
function _invol(a) = tan(a) - a*PI/180;
|
||||
|
||||
function _working_pressure_angle(teeth1,profile_shift1, teeth2, profile_shift2, pressure_angle, helical) =
|
||||
let(
|
||||
pressure_angle = atan(tan(pressure_angle)/cos(helical)),
|
||||
rhs = 2*(profile_shift1+profile_shift2)/(teeth1+teeth2)*cos(helical)*tan(pressure_angle) + _invol(pressure_angle),
|
||||
pa_eff = root_find(function (x) _invol(x)-rhs, 5, 75)
|
||||
)
|
||||
pa_eff;
|
||||
|
||||
|
||||
// Function: gear_dist_skew()
|
||||
// Usage:
|
||||
// d = gear_dist_skew(circ_pitch, teeth1, profile_shift1, h
|
||||
// Description:
|
||||
// Calculate the distance between two helical gears that mesh with non-parallel axes, taking into account
|
||||
// profile shift and the helical angles.
|
||||
function gear_dist_skew(mod,teeth1,profile_shift1=0, helical1, teeth2, profile_shift2=0, helical2, pressure_angle=20) =
|
||||
let(
|
||||
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),
|
||||
ff=echo(y=dist_adj,pa_normal_eff)
|
||||
)
|
||||
mod*(teeth1/2/cos(helical1)+teeth2/2/cos(helical2)+dist_adj);
|
||||
|
||||
|
||||
function _working_normal_pressure_angle_skew(teeth1,profile_shift1,helical1, teeth2, profile_shift2, helical2, pressure_angle) =
|
||||
let(
|
||||
rhs = 2*(profile_shift1+profile_shift2)/(teeth1/cos(helical1)^3+teeth2/cos(helical2)^3)*tan(pressure_angle) + inv(pressure_angle),
|
||||
fdaseee= echo(rhs=rhs),
|
||||
pa_eff_normal = root_find(function (x) inv(x)-rhs, 5, 75)
|
||||
)
|
||||
pa_eff_normal;
|
||||
|
||||
|
||||
// Function: gear_skew_angle()
|
||||
// Usage:
|
||||
// ang = gear_skew_angle(....
|
||||
// Description:
|
||||
// Compute the correct skew angle between the axes of two helical gears.
|
||||
function gear_skew_angle(mod,teeth1,profile_shift1,helical1,teeth2, profile_shift2,helical2,pressure_angle=20)=
|
||||
profile_shift1==0 && profile_shift2==0 ? helical1+helical2
|
||||
:
|
||||
let(
|
||||
//mod = circular_pitch(pitch, mod, circ_pitch, diam_pitch)/PI,
|
||||
a = gear_dist_skew(mod,teeth1,profile_shift1,helical1,teeth2, profile_shift2,helical2,pressure_angle),
|
||||
d1 = 2*pitch_radius(mod=mod,teeth=teeth1,helical=helical1),
|
||||
d2 = 2*pitch_radius(mod=mod,teeth=teeth2,helical=helical2),
|
||||
dw1 = 2*a*d1/(d1+d2),
|
||||
dw2 = 2*a*d2/(d1+d2),
|
||||
beta1 = atan(dw1/d1*tan(helical1)),
|
||||
beta2 = atan(dw2/d2*tan(helical2))
|
||||
)
|
||||
beta1+beta2;
|
||||
|
||||
|
||||
|
||||
|
||||
// Function: get_profile_shift()
|
||||
// Usage:
|
||||
// total_shift = get_profile_shift(desired,....)
|
||||
// Description:
|
||||
// Compute the total profile shift, split between two gears, needed to place those gears with a specified separation.
|
||||
// If the requested separation is impossible, returns nan. Note that the profile shift returned may also be impractically
|
||||
// large.
|
||||
// Arguments:
|
||||
// circ_pitch = circular pitch of gear teeth
|
||||
// teeth1 = number of teeth on first gear
|
||||
// teeth2 = number of teeth on second gear
|
||||
// pressure_angle = normal pressure angle of gear teeth. Default: 20
|
||||
// mod = gear module, an alternative to circ_pitch for giving gear size
|
||||
// diam_pitch = specify dimetral pitch
|
||||
function get_profile_shift(desired,circ_pitch,teeth1,teeth2,pressure_angle=20,mod,diam_pitch,pitch) =
|
||||
let(
|
||||
mod = circular_pitch(pitch, mod, circ_pitch, diam_pitch)/PI,
|
||||
pa_eff = acos(mod*(teeth1+teeth2)*cos(pressure_angle)/2/desired)
|
||||
)
|
||||
(_invol(pa_eff)-_invol(pressure_angle))/2/tan(pressure_angle) * (teeth1+teeth2);
|
||||
|
||||
|
||||
// Function: auto_profile_shift()
|
||||
|
@ -2810,10 +2895,11 @@ function mesh_radius(
|
|||
// Arguments:
|
||||
// teeth = Total number of teeth in the gear.
|
||||
// pressure_angle = The pressure angle of the gear.
|
||||
// helical = helical angle
|
||||
// ---
|
||||
// min_teeth = If given, the minimum number of teeth on a gear that has acceptable undercut.
|
||||
|
||||
function auto_profile_shift(teeth, pressure_angle=20, min_teeth) =
|
||||
function auto_profile_shift(teeth, pressure_angle=20, helical, min_teeth) =
|
||||
let(
|
||||
min_teeth = is_undef(min_teeth)
|
||||
? 2 / pow(sin(pressure_angle),2)
|
||||
|
|
15
math.scad
15
math.scad
|
@ -1560,13 +1560,6 @@ function _poly_roots(p, pderiv, s, z, tol, i=0) =
|
|||
// eps = used to determine whether imaginary parts of roots are zero
|
||||
// tol = tolerance for the complex polynomial root finder
|
||||
|
||||
// The algorithm is based on Brent's method and is a combination of
|
||||
// bisection and inverse quadratic approximation, where bisection occurs
|
||||
// at every step, with refinement using inverse quadratic approximation
|
||||
// only when that approximation gives a good result. The detail
|
||||
// of how to decide when to use the quadratic came from an article
|
||||
// by Crenshaw on "The World's Best Root Finder".
|
||||
// https://www.embedded.com/worlds-best-root-finder/
|
||||
function real_roots(p,eps=undef,tol=1e-14) =
|
||||
assert( is_vector(p), "Invalid polynomial." )
|
||||
let( p = _poly_trim(p,eps=0) )
|
||||
|
@ -1602,6 +1595,14 @@ function real_roots(p,eps=undef,tol=1e-14) =
|
|||
// x0 = endpoint of interval to search for root
|
||||
// x1 = second endpoint of interval to search for root
|
||||
// tol = tolerance for solution. Default: 1e-15
|
||||
|
||||
// The algorithm is based on Brent's method and is a combination of
|
||||
// bisection and inverse quadratic approximation, where bisection occurs
|
||||
// at every step, with refinement using inverse quadratic approximation
|
||||
// only when that approximation gives a good result. The detail
|
||||
// of how to decide when to use the quadratic came from an article
|
||||
// by Crenshaw on "The World's Best Root Finder".
|
||||
// https://www.embedded.com/worlds-best-root-finder/
|
||||
function root_find(f,x0,x1,tol=1e-15) =
|
||||
let(
|
||||
y0 = f(x0),
|
||||
|
|
|
@ -139,7 +139,8 @@
|
|||
// threaded_rod(d, l|length, pitch, [internal=], ...) [ATTACHMENTS];
|
||||
// Description:
|
||||
// Constructs a standard ISO (metric) or UTS (English) threaded rod. These threads are close to triangular,
|
||||
// with a 60 degree thread angle. You can give the outer diameter and get the "basic form" or you can
|
||||
// with a 60 degree thread angle. You can give diameter value which specifies the outer diameter and will produce
|
||||
// the "basic form" or you can
|
||||
// set d to a triplet [d_min, d_pitch, d_major] where are parameters determined by the ISO and UTS specifications
|
||||
// that define clearance sizing for the threading. See screws.scad for how to make screws
|
||||
// using the specification parameters.
|
||||
|
@ -279,9 +280,10 @@ module threaded_rod(
|
|||
// threaded_nut(nutwidth, id, h|height|thickness, pitch,...) [ATTACHMENTS];
|
||||
// Description:
|
||||
// Constructs a hex nut or square nut for an ISO (metric) or UTS (English) threaded rod.
|
||||
// The inner diameter is measured from the bottom of the threads.
|
||||
// Arguments:
|
||||
// nutwidth = flat to flat width of nut
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / l / length / thickness = height/thickness of nut.
|
||||
// pitch = Distance between threads, or zero for no threads.
|
||||
// ---
|
||||
|
@ -584,7 +586,7 @@ module trapezoidal_threaded_rod(
|
|||
// acme_threaded_nut().
|
||||
// Arguments:
|
||||
// nutwidth = flat to flat width of nut
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / l / length / thickness = height/thickness of nut.
|
||||
// pitch = Thread spacing.
|
||||
// ---
|
||||
|
@ -806,7 +808,7 @@ module acme_threaded_rod(
|
|||
// Constructs a hexagonal or square nut for an ACME threaded screw rod.
|
||||
// Arguments:
|
||||
// nutwidth = flat to flat width of nut.
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / l / length / thickness = height/thickness of nut.
|
||||
// tpi = threads per inch
|
||||
// ---
|
||||
|
@ -1135,7 +1137,7 @@ module buttress_threaded_rod(
|
|||
// Constructs a hexagonal or square nut for a simple buttress threaded screw rod.
|
||||
// Arguments:
|
||||
// nutwidth = diameter of the nut.
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / l / length / thickness = height/thickness of nut.
|
||||
// pitch = Thread spacing.
|
||||
// ---
|
||||
|
@ -1331,7 +1333,7 @@ module square_threaded_rod(
|
|||
// Constructs a hexagonal or square nut for a square profile threaded screw rod.
|
||||
// Arguments:
|
||||
// nutwidth = diameter of the nut.
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / l / length / thickness = height/thickness of nut.
|
||||
// pitch = Length between threads.
|
||||
// ---
|
||||
|
@ -1865,7 +1867,7 @@ module generic_threaded_rod(
|
|||
// See {{generic_threaded_rod()}} for details on the profile specification.
|
||||
// Arguments:
|
||||
// nutwidth = outer dimension of nut from flat to flat.
|
||||
// id = diameter of threaded rod to screw onto.
|
||||
// id = inner diameter of threaded hole, measured from bottom of threads
|
||||
// h / height / thickness = height/thickness of nut.
|
||||
// pitch = Thread spacing.
|
||||
// profile = Thread profile.
|
||||
|
@ -2086,7 +2088,7 @@ module _nutshape(nutwidth, h, shape, bevel1, bevel2)
|
|||
// back(3)text("angle",size=4,halign="center");
|
||||
// }
|
||||
// Arguments:
|
||||
// d = Inside base diameter of threads. Default: 10
|
||||
// d = Base diameter of threads. Default: 10
|
||||
// pitch = Distance between threads. Default: 2
|
||||
// ---
|
||||
// thread_depth = Depth of threads from top to bottom.
|
||||
|
|
Loading…
Reference in a new issue