discuss@lists.openscad.org

OpenSCAD general discussion Mailing-list

View all threads

hirth joint

AM
Adrian Mariano
Fri, Nov 8, 2024 5:37 PM

I implemented the method I suggested. It was pretty easy to do and works.
I do not understand your problem with skin.  How does it fail?  I construct
mine using vnf_vertex_array which is like skin without fancy point
alignment, and have no issues.  It shouldn’t matter how far apart the
profiles are or how different the scale. Skin just connects the points you
give it to make the polyhedron.

I do have a problem with rounding. The rounding isn’t at the right angle
which leads to a corner where it joins the

I thought the 2 tooth case was working for me but more thorough
investigation revealed problems in the case of skewed teeth. I’ll have to
ponder that.

On Fri, Nov 8, 2024 at 11:39 Bob Carlson bob@rjcarlson.com wrote:

That sounds promising. I tried a lot of stuff but not that and nothing
worked quite right. I’ve tweaked my code now to make the chamfer by
subtracting later. It’s quite easy. The other thing I did is make 2 half
tooth profiles instead of one whole. Now N = 2 works. I also found that
skin() did not work at low tooth counts and had to use a combination of
skin and hull. If two profiles are very different sizes and far apart, that
seemed to be the problem area. I use skin to make thin wafers then hull the
wafers together. I suppose some schemes where I generate many profiles
close together would work too.

Maybe after I finish this version I’m make one more trial of your idea.

-Bob

On Nov 7, 2024, at 15:13, Adrian Mariano avm4@cornell.edu wrote:

I think that to get this right you basically need to take the top point

of the triangle and one of the bottom points of the triangle in their
position projected onto the cylinder, represent in cartesian coordinates,
then interpolate appropriately between them by the chamfer fraction, then
convert back to spherical coordinates to extract the angles.  You can work
through those steps to get some complicated formula, but it looked messy.
I couldn't think of any simpler approach.

I implemented the method I suggested. It was pretty easy to do and works. I do not understand your problem with skin. How does it fail? I construct mine using vnf_vertex_array which is like skin without fancy point alignment, and have no issues. It shouldn’t matter how far apart the profiles are or how different the scale. Skin just connects the points you give it to make the polyhedron. I do have a problem with rounding. The rounding isn’t at the right angle which leads to a corner where it joins the I thought the 2 tooth case was working for me but more thorough investigation revealed problems in the case of skewed teeth. I’ll have to ponder that. On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com> wrote: > That sounds promising. I tried a lot of stuff but not that and nothing > worked quite right. I’ve tweaked my code now to make the chamfer by > subtracting later. It’s quite easy. The other thing I did is make 2 half > tooth profiles instead of one whole. Now N = 2 works. I also found that > skin() did not work at low tooth counts and had to use a combination of > skin and hull. If two profiles are very different sizes and far apart, that > seemed to be the problem area. I use skin to make thin wafers then hull the > wafers together. I suppose some schemes where I generate many profiles > close together would work too. > > Maybe after I finish this version I’m make one more trial of your idea. > > -Bob > > > On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu> wrote: > > > > I think that to get this right you basically need to take the top point > of the triangle and one of the bottom points of the triangle in their > position projected onto the cylinder, represent in cartesian coordinates, > then interpolate appropriately between them by the chamfer fraction, then > convert back to spherical coordinates to extract the angles. You can work > through those steps to get some complicated formula, but it looked messy. > I couldn't think of any simpler approach. > > > >
BC
Bob Carlson
Thu, Nov 14, 2024 11:25 PM

I’ve attached my code that I now believe is debugged and working reliably. It supports all the way down to N=2 (teeth). Depending on N it renders in .25 to .5 s. Preview is similar.

When N = 2 or 3 this is an edge condition that required a lot of testing and work. The other area that caused the most problems was when the “coned” argument was at or around half the tooth height (as measured at the outer radius.) Around this point any auxiliary shapes you use to add a base, add or subtract a chamfer etc, switch from concave to convex or vice versa.

One file is Customizer enabled and serves as the test platform for the second file where all the working code is. The test file also includes some visualization aids that I wrote to help see exactly what is going on.

A note about the anchors. They are all relative to the entire joint. This makes it easier to position both parts in a larger assembly in a way that insures the parts mesh exactly.

-Bob



On Nov 8, 2024, at 10:37, Adrian Mariano avm4@cornell.edu wrote:

I implemented the method I suggested. It was pretty easy to do and works.  I do not understand your problem with skin.  How does it fail?  I construct mine using vnf_vertex_array which is like skin without fancy point alignment, and have no issues.  It shouldn’t matter how far apart the profiles are or how different the scale. Skin just connects the points you give it to make the polyhedron.

I do have a problem with rounding. The rounding isn’t at the right angle which leads to a corner where it joins the

I thought the 2 tooth case was working for me but more thorough investigation revealed problems in the case of skewed teeth. I’ll have to ponder that.

On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com mailto:bob@rjcarlson.com> wrote:

That sounds promising. I tried a lot of stuff but not that and nothing worked quite right. I’ve tweaked my code now to make the chamfer by subtracting later. It’s quite easy. The other thing I did is make 2 half tooth profiles instead of one whole. Now N = 2 works. I also found that skin() did not work at low tooth counts and had to use a combination of skin and hull. If two profiles are very different sizes and far apart, that seemed to be the problem area. I use skin to make thin wafers then hull the wafers together. I suppose some schemes where I generate many profiles close together would work too.

Maybe after I finish this version I’m make one more trial of your idea.

-Bob

On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu mailto:avm4@cornell.edu> wrote:

I think that to get this right you basically need to take the top point of the triangle and one of the bottom points of the triangle in their position projected onto the cylinder, represent in cartesian coordinates, then interpolate appropriately between them by the chamfer fraction, then convert back to spherical coordinates to extract the angles.  You can work through those steps to get some complicated formula, but it looked messy.  I couldn't think of any simpler approach.

I’ve attached my code that I now believe is debugged and working reliably. It supports all the way down to N=2 (teeth). Depending on N it renders in .25 to .5 s. Preview is similar. When N = 2 or 3 this is an edge condition that required a lot of testing and work. The other area that caused the most problems was when the “coned” argument was at or around half the tooth height (as measured at the outer radius.) Around this point any auxiliary shapes you use to add a base, add or subtract a chamfer etc, switch from concave to convex or vice versa. One file is Customizer enabled and serves as the test platform for the second file where all the working code is. The test file also includes some visualization aids that I wrote to help see exactly what is going on. A note about the anchors. They are all relative to the entire joint. This makes it easier to position both parts in a larger assembly in a way that insures the parts mesh exactly. -Bob    > On Nov 8, 2024, at 10:37, Adrian Mariano <avm4@cornell.edu> wrote: > > I implemented the method I suggested. It was pretty easy to do and works. I do not understand your problem with skin. How does it fail? I construct mine using vnf_vertex_array which is like skin without fancy point alignment, and have no issues. It shouldn’t matter how far apart the profiles are or how different the scale. Skin just connects the points you give it to make the polyhedron. > > I do have a problem with rounding. The rounding isn’t at the right angle which leads to a corner where it joins the > > I thought the 2 tooth case was working for me but more thorough investigation revealed problems in the case of skewed teeth. I’ll have to ponder that. > > On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com <mailto:bob@rjcarlson.com>> wrote: >> That sounds promising. I tried a lot of stuff but not that and nothing worked quite right. I’ve tweaked my code now to make the chamfer by subtracting later. It’s quite easy. The other thing I did is make 2 half tooth profiles instead of one whole. Now N = 2 works. I also found that skin() did not work at low tooth counts and had to use a combination of skin and hull. If two profiles are very different sizes and far apart, that seemed to be the problem area. I use skin to make thin wafers then hull the wafers together. I suppose some schemes where I generate many profiles close together would work too. >> >> Maybe after I finish this version I’m make one more trial of your idea. >> >> -Bob >> >> > On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu <mailto:avm4@cornell.edu>> wrote: >> > >> > I think that to get this right you basically need to take the top point of the triangle and one of the bottom points of the triangle in their position projected onto the cylinder, represent in cartesian coordinates, then interpolate appropriately between them by the chamfer fraction, then convert back to spherical coordinates to extract the angles. You can work through those steps to get some complicated formula, but it looked messy. I couldn't think of any simpler approach. >> > >>
BC
Bob Carlson
Thu, Nov 14, 2024 11:34 PM

I forgot something. In _profileU(hs) there is code documented out that causes problems with skin. They show up in the tricky areas like N = 2 and coned = toothHeight/2.

-Bob

On Nov 14, 2024, at 16:25, Bob Carlson via Discuss discuss@lists.openscad.org wrote:

I’ve attached my code that I now believe is debugged and working reliably. It supports all the way down to N=2 (teeth). Depending on N it renders in .25 to .5 s. Preview is similar.

When N = 2 or 3 this is an edge condition that required a lot of testing and work. The other area that caused the most problems was when the “coned” argument was at or around half the tooth height (as measured at the outer radius.) Around this point any auxiliary shapes you use to add a base, add or subtract a chamfer etc, switch from concave to convex or vice versa.

One file is Customizer enabled and serves as the test platform for the second file where all the working code is. The test file also includes some visualization aids that I wrote to help see exactly what is going on.

A note about the anchors. They are all relative to the entire joint. This makes it easier to position both parts in a larger assembly in a way that insures the parts mesh exactly.

-Bob

<PastedGraphic-1.png>

<PastedGraphic-3.png>

<hirth.5.scad>
<hirth test.5.scad>

On Nov 8, 2024, at 10:37, Adrian Mariano avm4@cornell.edu wrote:

I implemented the method I suggested. It was pretty easy to do and works.  I do not understand your problem with skin.  How does it fail?  I construct mine using vnf_vertex_array which is like skin without fancy point alignment, and have no issues.  It shouldn’t matter how far apart the profiles are or how different the scale. Skin just connects the points you give it to make the polyhedron.

I do have a problem with rounding. The rounding isn’t at the right angle which leads to a corner where it joins the

I thought the 2 tooth case was working for me but more thorough investigation revealed problems in the case of skewed teeth. I’ll have to ponder that.

On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com mailto:bob@rjcarlson.com> wrote:

That sounds promising. I tried a lot of stuff but not that and nothing worked quite right. I’ve tweaked my code now to make the chamfer by subtracting later. It’s quite easy. The other thing I did is make 2 half tooth profiles instead of one whole. Now N = 2 works. I also found that skin() did not work at low tooth counts and had to use a combination of skin and hull. If two profiles are very different sizes and far apart, that seemed to be the problem area. I use skin to make thin wafers then hull the wafers together. I suppose some schemes where I generate many profiles close together would work too.

Maybe after I finish this version I’m make one more trial of your idea.

-Bob

On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu mailto:avm4@cornell.edu> wrote:

I think that to get this right you basically need to take the top point of the triangle and one of the bottom points of the triangle in their position projected onto the cylinder, represent in cartesian coordinates, then interpolate appropriately between them by the chamfer fraction, then convert back to spherical coordinates to extract the angles.  You can work through those steps to get some complicated formula, but it looked messy.  I couldn't think of any simpler approach.


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

I forgot something. In _profileU(hs) there is code documented out that causes problems with skin. They show up in the tricky areas like N = 2 and coned = toothHeight/2. -Bob > On Nov 14, 2024, at 16:25, Bob Carlson via Discuss <discuss@lists.openscad.org> wrote: > > I’ve attached my code that I now believe is debugged and working reliably. It supports all the way down to N=2 (teeth). Depending on N it renders in .25 to .5 s. Preview is similar. > > When N = 2 or 3 this is an edge condition that required a lot of testing and work. The other area that caused the most problems was when the “coned” argument was at or around half the tooth height (as measured at the outer radius.) Around this point any auxiliary shapes you use to add a base, add or subtract a chamfer etc, switch from concave to convex or vice versa. > > One file is Customizer enabled and serves as the test platform for the second file where all the working code is. The test file also includes some visualization aids that I wrote to help see exactly what is going on. > > A note about the anchors. They are all relative to the entire joint. This makes it easier to position both parts in a larger assembly in a way that insures the parts mesh exactly. > > -Bob > > <PastedGraphic-1.png> > > <PastedGraphic-3.png> > > > <hirth.5.scad> > <hirth test.5.scad> > > >> On Nov 8, 2024, at 10:37, Adrian Mariano <avm4@cornell.edu> wrote: >> >> I implemented the method I suggested. It was pretty easy to do and works. I do not understand your problem with skin. How does it fail? I construct mine using vnf_vertex_array which is like skin without fancy point alignment, and have no issues. It shouldn’t matter how far apart the profiles are or how different the scale. Skin just connects the points you give it to make the polyhedron. >> >> I do have a problem with rounding. The rounding isn’t at the right angle which leads to a corner where it joins the >> >> I thought the 2 tooth case was working for me but more thorough investigation revealed problems in the case of skewed teeth. I’ll have to ponder that. >> >> On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com <mailto:bob@rjcarlson.com>> wrote: >>> That sounds promising. I tried a lot of stuff but not that and nothing worked quite right. I’ve tweaked my code now to make the chamfer by subtracting later. It’s quite easy. The other thing I did is make 2 half tooth profiles instead of one whole. Now N = 2 works. I also found that skin() did not work at low tooth counts and had to use a combination of skin and hull. If two profiles are very different sizes and far apart, that seemed to be the problem area. I use skin to make thin wafers then hull the wafers together. I suppose some schemes where I generate many profiles close together would work too. >>> >>> Maybe after I finish this version I’m make one more trial of your idea. >>> >>> -Bob >>> >>> > On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu <mailto:avm4@cornell.edu>> wrote: >>> > >>> > I think that to get this right you basically need to take the top point of the triangle and one of the bottom points of the triangle in their position projected onto the cylinder, represent in cartesian coordinates, then interpolate appropriately between them by the chamfer fraction, then convert back to spherical coordinates to extract the angles. You can work through those steps to get some complicated formula, but it looked messy. I couldn't think of any simpler approach. >>> > >>> > > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org
AM
Adrian Mariano
Fri, Nov 15, 2024 12:24 AM

If you want to identify a specific case for reproducing a problem with
skin() I can take a look at it, but I couldn't find anything obviously
wrong in a brief bit of fiddling with parameters.

It's interesting how rather different our hirth joints can look for similar
parameters.  For 2 teeth, with no cone angle/distance they are pretty
similar:

[image: image.png]
but with an extreme cone setting (I was trying to set it to the tooth
height to create the problem you described) they are rather different:

[image: image.png]
Note that mine are symmetric in that a single module produces both halves
and you specify conical with an angle, and then use the negative angle to
make the mate.

On Thu, Nov 14, 2024 at 6:35 PM Bob Carlson bob@rjcarlson.com wrote:

I forgot something. In _profileU(hs) there is code documented out that
causes problems with skin. They show up in the tricky areas like N = 2 and
coned = toothHeight/2.

-Bob

On Nov 14, 2024, at 16:25, Bob Carlson via Discuss <
discuss@lists.openscad.org> wrote:

I’ve attached my code that I now believe is debugged and working reliably.
It supports all the way down to N=2 (teeth). Depending on N it renders in
.25 to .5 s. Preview is similar.

When N = 2 or 3 this is an edge condition that required a lot of testing
and work. The other area that caused the most problems was when the “coned”
argument was at or around half the tooth height (as measured at the outer
radius.) Around this point any auxiliary shapes you use to add a base, add
or subtract a chamfer etc, switch from concave to convex or vice versa.

One file is Customizer enabled and serves as the test platform for the
second file where all the working code is. The test file also includes some
visualization aids that I wrote to help see exactly what is going on.

A note about the anchors. They are all relative to the entire joint. This
makes it easier to position both parts in a larger assembly in a way that
insures the parts mesh exactly.

-Bob

<PastedGraphic-1.png>

<PastedGraphic-3.png>

<hirth.5.scad>
<hirth test.5.scad>

On Nov 8, 2024, at 10:37, Adrian Mariano avm4@cornell.edu wrote:

I implemented the method I suggested. It was pretty easy to do and works.
I do not understand your problem with skin.  How does it fail?  I construct
mine using vnf_vertex_array which is like skin without fancy point
alignment, and have no issues.  It shouldn’t matter how far apart the
profiles are or how different the scale. Skin just connects the points you
give it to make the polyhedron.

I do have a problem with rounding. The rounding isn’t at the right angle
which leads to a corner where it joins the

I thought the 2 tooth case was working for me but more thorough
investigation revealed problems in the case of skewed teeth. I’ll have to
ponder that.

On Fri, Nov 8, 2024 at 11:39 Bob Carlson bob@rjcarlson.com wrote:

That sounds promising. I tried a lot of stuff but not that and nothing
worked quite right. I’ve tweaked my code now to make the chamfer by
subtracting later. It’s quite easy. The other thing I did is make 2 half
tooth profiles instead of one whole. Now N = 2 works. I also found that
skin() did not work at low tooth counts and had to use a combination of
skin and hull. If two profiles are very different sizes and far apart, that
seemed to be the problem area. I use skin to make thin wafers then hull the
wafers together. I suppose some schemes where I generate many profiles
close together would work too.

Maybe after I finish this version I’m make one more trial of your idea.

-Bob

On Nov 7, 2024, at 15:13, Adrian Mariano avm4@cornell.edu wrote:

I think that to get this right you basically need to take the top point

of the triangle and one of the bottom points of the triangle in their
position projected onto the cylinder, represent in cartesian coordinates,
then interpolate appropriately between them by the chamfer fraction, then
convert back to spherical coordinates to extract the angles.  You can work
through those steps to get some complicated formula, but it looked messy.
I couldn't think of any simpler approach.


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

If you want to identify a specific case for reproducing a problem with skin() I can take a look at it, but I couldn't find anything obviously wrong in a brief bit of fiddling with parameters. It's interesting how rather different our hirth joints can look for similar parameters. For 2 teeth, with no cone angle/distance they are pretty similar: [image: image.png] but with an extreme cone setting (I was trying to set it to the tooth height to create the problem you described) they are rather different: [image: image.png] Note that mine are symmetric in that a single module produces both halves and you specify conical with an angle, and then use the negative angle to make the mate. On Thu, Nov 14, 2024 at 6:35 PM Bob Carlson <bob@rjcarlson.com> wrote: > I forgot something. In _profileU(hs) there is code documented out that > causes problems with skin. They show up in the tricky areas like N = 2 and > coned = toothHeight/2. > > -Bob > > On Nov 14, 2024, at 16:25, Bob Carlson via Discuss < > discuss@lists.openscad.org> wrote: > > I’ve attached my code that I now believe is debugged and working reliably. > It supports all the way down to N=2 (teeth). Depending on N it renders in > .25 to .5 s. Preview is similar. > > When N = 2 or 3 this is an edge condition that required a lot of testing > and work. The other area that caused the most problems was when the “coned” > argument was at or around half the tooth height (as measured at the outer > radius.) Around this point any auxiliary shapes you use to add a base, add > or subtract a chamfer etc, switch from concave to convex or vice versa. > > One file is Customizer enabled and serves as the test platform for the > second file where all the working code is. The test file also includes some > visualization aids that I wrote to help see exactly what is going on. > > A note about the anchors. They are all relative to the entire joint. This > makes it easier to position both parts in a larger assembly in a way that > insures the parts mesh exactly. > > -Bob > > <PastedGraphic-1.png> > > <PastedGraphic-3.png> > > > <hirth.5.scad> > <hirth test.5.scad> > > > On Nov 8, 2024, at 10:37, Adrian Mariano <avm4@cornell.edu> wrote: > > I implemented the method I suggested. It was pretty easy to do and works. > I do not understand your problem with skin. How does it fail? I construct > mine using vnf_vertex_array which is like skin without fancy point > alignment, and have no issues. It shouldn’t matter how far apart the > profiles are or how different the scale. Skin just connects the points you > give it to make the polyhedron. > > I do have a problem with rounding. The rounding isn’t at the right angle > which leads to a corner where it joins the > > I thought the 2 tooth case was working for me but more thorough > investigation revealed problems in the case of skewed teeth. I’ll have to > ponder that. > > On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com> wrote: > >> That sounds promising. I tried a lot of stuff but not that and nothing >> worked quite right. I’ve tweaked my code now to make the chamfer by >> subtracting later. It’s quite easy. The other thing I did is make 2 half >> tooth profiles instead of one whole. Now N = 2 works. I also found that >> skin() did not work at low tooth counts and had to use a combination of >> skin and hull. If two profiles are very different sizes and far apart, that >> seemed to be the problem area. I use skin to make thin wafers then hull the >> wafers together. I suppose some schemes where I generate many profiles >> close together would work too. >> >> Maybe after I finish this version I’m make one more trial of your idea. >> >> -Bob >> >> > On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu> wrote: >> > >> > I think that to get this right you basically need to take the top point >> of the triangle and one of the bottom points of the triangle in their >> position projected onto the cylinder, represent in cartesian coordinates, >> then interpolate appropriately between them by the chamfer fraction, then >> convert back to spherical coordinates to extract the angles. You can work >> through those steps to get some complicated formula, but it looked messy. >> I couldn't think of any simpler approach. >> > >> >> > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org > > >
SP
Sanjeev Prabhakar
Fri, Nov 15, 2024 1:43 AM

Hi Bob
At the trough it should be a fillet rather than chamfer. On the crest it
should be chamfer.

On Fri, 15 Nov, 2024, 4:56 am Bob Carlson via Discuss, <
discuss@lists.openscad.org> wrote:

I’ve attached my code that I now believe is debugged and working reliably.
It supports all the way down to N=2 (teeth). Depending on N it renders in
.25 to .5 s. Preview is similar.

When N = 2 or 3 this is an edge condition that required a lot of testing
and work. The other area that caused the most problems was when the “coned”
argument was at or around half the tooth height (as measured at the outer
radius.) Around this point any auxiliary shapes you use to add a base, add
or subtract a chamfer etc, switch from concave to convex or vice versa.

One file is Customizer enabled and serves as the test platform for the
second file where all the working code is. The test file also includes some
visualization aids that I wrote to help see exactly what is going on.

A note about the anchors. They are all relative to the entire joint. This
makes it easier to position both parts in a larger assembly in a way that
insures the parts mesh exactly.

-Bob

On Nov 8, 2024, at 10:37, Adrian Mariano avm4@cornell.edu wrote:

I implemented the method I suggested. It was pretty easy to do and works.
I do not understand your problem with skin.  How does it fail?  I construct
mine using vnf_vertex_array which is like skin without fancy point
alignment, and have no issues.  It shouldn’t matter how far apart the
profiles are or how different the scale. Skin just connects the points you
give it to make the polyhedron.

I do have a problem with rounding. The rounding isn’t at the right angle
which leads to a corner where it joins the

I thought the 2 tooth case was working for me but more thorough
investigation revealed problems in the case of skewed teeth. I’ll have to
ponder that.

On Fri, Nov 8, 2024 at 11:39 Bob Carlson bob@rjcarlson.com wrote:

That sounds promising. I tried a lot of stuff but not that and nothing
worked quite right. I’ve tweaked my code now to make the chamfer by
subtracting later. It’s quite easy. The other thing I did is make 2 half
tooth profiles instead of one whole. Now N = 2 works. I also found that
skin() did not work at low tooth counts and had to use a combination of
skin and hull. If two profiles are very different sizes and far apart, that
seemed to be the problem area. I use skin to make thin wafers then hull the
wafers together. I suppose some schemes where I generate many profiles
close together would work too.

Maybe after I finish this version I’m make one more trial of your idea.

-Bob

On Nov 7, 2024, at 15:13, Adrian Mariano avm4@cornell.edu wrote:

I think that to get this right you basically need to take the top point

of the triangle and one of the bottom points of the triangle in their
position projected onto the cylinder, represent in cartesian coordinates,
then interpolate appropriately between them by the chamfer fraction, then
convert back to spherical coordinates to extract the angles.  You can work
through those steps to get some complicated formula, but it looked messy.
I couldn't think of any simpler approach.


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

Hi Bob At the trough it should be a fillet rather than chamfer. On the crest it should be chamfer. On Fri, 15 Nov, 2024, 4:56 am Bob Carlson via Discuss, < discuss@lists.openscad.org> wrote: > I’ve attached my code that I now believe is debugged and working reliably. > It supports all the way down to N=2 (teeth). Depending on N it renders in > .25 to .5 s. Preview is similar. > > When N = 2 or 3 this is an edge condition that required a lot of testing > and work. The other area that caused the most problems was when the “coned” > argument was at or around half the tooth height (as measured at the outer > radius.) Around this point any auxiliary shapes you use to add a base, add > or subtract a chamfer etc, switch from concave to convex or vice versa. > > One file is Customizer enabled and serves as the test platform for the > second file where all the working code is. The test file also includes some > visualization aids that I wrote to help see exactly what is going on. > > A note about the anchors. They are all relative to the entire joint. This > makes it easier to position both parts in a larger assembly in a way that > insures the parts mesh exactly. > > -Bob > > > > > > > On Nov 8, 2024, at 10:37, Adrian Mariano <avm4@cornell.edu> wrote: > > I implemented the method I suggested. It was pretty easy to do and works. > I do not understand your problem with skin. How does it fail? I construct > mine using vnf_vertex_array which is like skin without fancy point > alignment, and have no issues. It shouldn’t matter how far apart the > profiles are or how different the scale. Skin just connects the points you > give it to make the polyhedron. > > I do have a problem with rounding. The rounding isn’t at the right angle > which leads to a corner where it joins the > > I thought the 2 tooth case was working for me but more thorough > investigation revealed problems in the case of skewed teeth. I’ll have to > ponder that. > > On Fri, Nov 8, 2024 at 11:39 Bob Carlson <bob@rjcarlson.com> wrote: > >> That sounds promising. I tried a lot of stuff but not that and nothing >> worked quite right. I’ve tweaked my code now to make the chamfer by >> subtracting later. It’s quite easy. The other thing I did is make 2 half >> tooth profiles instead of one whole. Now N = 2 works. I also found that >> skin() did not work at low tooth counts and had to use a combination of >> skin and hull. If two profiles are very different sizes and far apart, that >> seemed to be the problem area. I use skin to make thin wafers then hull the >> wafers together. I suppose some schemes where I generate many profiles >> close together would work too. >> >> Maybe after I finish this version I’m make one more trial of your idea. >> >> -Bob >> >> > On Nov 7, 2024, at 15:13, Adrian Mariano <avm4@cornell.edu> wrote: >> > >> > I think that to get this right you basically need to take the top point >> of the triangle and one of the bottom points of the triangle in their >> position projected onto the cylinder, represent in cartesian coordinates, >> then interpolate appropriately between them by the chamfer fraction, then >> convert back to spherical coordinates to extract the angles. You can work >> through those steps to get some complicated formula, but it looked messy. >> I couldn't think of any simpler approach. >> > >> >> > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org >
BC
Bob Carlson
Fri, Nov 15, 2024 4:29 PM

That’s an interesting exercise. I am playing with another strategy to produce the chamfers that will produce a flat chamfer. My current algorithm produces one that is follows the surface of a cone. Unnoticeable at normal tooth counts, but you can see it with very low tooth counts. I’ll generate some pics of the skin issue, but it won’t be till late today.

Sanjay, you are no doubt correct that the groove should be a fillet, I have no ME background at all. But it seems very difficult to produce. I played around with the math to inscribe a circle into an angle at a specific tangent point, but got tired of the exercise before I solved it. I suspect you can do that off the top of your head. Somewhat arbitrarily I chose to make the groove chamfer 50% of the ridge chamfer. Is there another ratio that is accepted or preferred?

-Bob

On Nov 14, 2024, at 17:24, Adrian Mariano avm4@cornell.edu wrote:

It's interesting how rather different our hirth joints can look for similar parameters.  For 2 teeth, with no cone angle/distance they are pretty similar:

That’s an interesting exercise. I am playing with another strategy to produce the chamfers that will produce a flat chamfer. My current algorithm produces one that is follows the surface of a cone. Unnoticeable at normal tooth counts, but you can see it with very low tooth counts. I’ll generate some pics of the skin issue, but it won’t be till late today. Sanjay, you are no doubt correct that the groove should be a fillet, I have no ME background at all. But it seems very difficult to produce. I played around with the math to inscribe a circle into an angle at a specific tangent point, but got tired of the exercise before I solved it. I suspect you can do that off the top of your head. Somewhat arbitrarily I chose to make the groove chamfer 50% of the ridge chamfer. Is there another ratio that is accepted or preferred? -Bob > On Nov 14, 2024, at 17:24, Adrian Mariano <avm4@cornell.edu> wrote: > > It's interesting how rather different our hirth joints can look for similar parameters. For 2 teeth, with no cone angle/distance they are pretty similar:
SP
Sanjeev Prabhakar
Fri, Nov 15, 2024 11:07 PM

I am not sure how you have modeled this but the main point here is that the
teeth should not foul while meshing, if that is not the case in your design
then it should be fine.

On Fri, 15 Nov, 2024, 10:00 pm Bob Carlson via Discuss, <
discuss@lists.openscad.org> wrote:

That’s an interesting exercise. I am playing with another strategy to
produce the chamfers that will produce a flat chamfer. My current algorithm
produces one that is follows the surface of a cone. Unnoticeable at normal
tooth counts, but you can see it with very low tooth counts. I’ll generate
some pics of the skin issue, but it won’t be till late today.

Sanjay, you are no doubt correct that the groove should be a fillet, I
have no ME background at all. But it seems very difficult to produce. I
played around with the math to inscribe a circle into an angle at a
specific tangent point, but got tired of the exercise before I solved it. I
suspect you can do that off the top of your head. Somewhat arbitrarily I
chose to make the groove chamfer 50% of the ridge chamfer. Is there another
ratio that is accepted or preferred?

-Bob

On Nov 14, 2024, at 17:24, Adrian Mariano avm4@cornell.edu wrote:

It's interesting how rather different our hirth joints can look for
similar parameters.  For 2 teeth, with no cone angle/distance they are
pretty similar:


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

I am not sure how you have modeled this but the main point here is that the teeth should not foul while meshing, if that is not the case in your design then it should be fine. On Fri, 15 Nov, 2024, 10:00 pm Bob Carlson via Discuss, < discuss@lists.openscad.org> wrote: > That’s an interesting exercise. I am playing with another strategy to > produce the chamfers that will produce a flat chamfer. My current algorithm > produces one that is follows the surface of a cone. Unnoticeable at normal > tooth counts, but you can see it with very low tooth counts. I’ll generate > some pics of the skin issue, but it won’t be till late today. > > Sanjay, you are no doubt correct that the groove should be a fillet, I > have no ME background at all. But it seems very difficult to produce. I > played around with the math to inscribe a circle into an angle at a > specific tangent point, but got tired of the exercise before I solved it. I > suspect you can do that off the top of your head. Somewhat arbitrarily I > chose to make the groove chamfer 50% of the ridge chamfer. Is there another > ratio that is accepted or preferred? > > -Bob > > On Nov 14, 2024, at 17:24, Adrian Mariano <avm4@cornell.edu> wrote: > > It's interesting how rather different our hirth joints can look for > similar parameters. For 2 teeth, with no cone angle/distance they are > pretty similar: > > > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org >
BC
Bob Carlson
Sat, Nov 16, 2024 1:54 AM

It turns out that in the previous version I was calculating the phi angle for the chamfers incorrectly, another place where my math intuition failed me. This code gets it right I think. Look for phiCA in hirth.6.. Phi in spherical coordinates is from vertical and I am sometimes using phiCA from the XY plane instead, so -90. So watch out.

-Bob



On Nov 15, 2024, at 09:29, Bob Carlson via Discuss discuss@lists.openscad.org wrote:

That’s an interesting exercise. I am playing with another strategy to produce the chamfers that will produce a flat chamfer. My current algorithm produces one that is follows the surface of a cone. Unnoticeable at normal tooth counts, but you can see it with very low tooth counts. I’ll generate some pics of the skin issue, but it won’t be till late today.

Sanjay, you are no doubt correct that the groove should be a fillet, I have no ME background at all. But it seems very difficult to produce. I played around with the math to inscribe a circle into an angle at a specific tangent point, but got tired of the exercise before I solved it. I suspect you can do that off the top of your head. Somewhat arbitrarily I chose to make the groove chamfer 50% of the ridge chamfer. Is there another ratio that is accepted or preferred?

-Bob

On Nov 14, 2024, at 17:24, Adrian Mariano avm4@cornell.edu wrote:

It's interesting how rather different our hirth joints can look for similar parameters.  For 2 teeth, with no cone angle/distance they are pretty similar:


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

It turns out that in the previous version I was calculating the phi angle for the chamfers incorrectly, another place where my math intuition failed me. This code gets it right I think. Look for phiCA in hirth.6.. Phi in spherical coordinates is from vertical and I am sometimes using phiCA from the XY plane instead, so -90. So watch out. -Bob  > On Nov 15, 2024, at 09:29, Bob Carlson via Discuss <discuss@lists.openscad.org> wrote: > > That’s an interesting exercise. I am playing with another strategy to produce the chamfers that will produce a flat chamfer. My current algorithm produces one that is follows the surface of a cone. Unnoticeable at normal tooth counts, but you can see it with very low tooth counts. I’ll generate some pics of the skin issue, but it won’t be till late today. > > Sanjay, you are no doubt correct that the groove should be a fillet, I have no ME background at all. But it seems very difficult to produce. I played around with the math to inscribe a circle into an angle at a specific tangent point, but got tired of the exercise before I solved it. I suspect you can do that off the top of your head. Somewhat arbitrarily I chose to make the groove chamfer 50% of the ridge chamfer. Is there another ratio that is accepted or preferred? > > -Bob > >> On Nov 14, 2024, at 17:24, Adrian Mariano <avm4@cornell.edu> wrote: >> >> It's interesting how rather different our hirth joints can look for similar parameters. For 2 teeth, with no cone angle/distance they are pretty similar: > > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org
M
mikeonenine@web.de
Sun, Nov 17, 2024 5:15 AM

I’ve had a look at some of the codes posted above and actually got one to work. But the question remains:

In the image below, 60° triangles parallel to the z-axis linear_extruded to the origin give an angle of 90° between the flanks of a spline, which can be seen when one looks along a ridge towards the origin.

Are these then 60° splines or 90° splines?

I’ve had a look at some of the codes posted above and actually got one to work. But the question remains: In the image below, 60° triangles parallel to the z-axis linear_extruded to the origin give an angle of 90° between the flanks of a spline, which can be seen when one looks along a ridge towards the origin. Are these then 60° splines or 90° splines? ![]()
AM
Adrian Mariano
Sun, Nov 17, 2024 5:30 AM

I think it's tough to tell what the angles are in the fixed view like that
due to the distortion from perspective.  In my code the triangles that form
the teeth are constructed with the specified angle, but then they end up
getting projected at a different angle depending on the cone angle you
pick.  Furthermore, there's the question of where the angle is measured.  I
think the wikipedia page suggested it is measured relative to the cylinder
axis, but I'd normally expect tooth angle to be measured on the tooth,
which means the slope of the tooth will also lead to a change in the
effective angle.  (Maybe this factor is what you're talking about?)  I
decided for my implementation to treat the requested angle as "nominal" and
not worry about these various deviations.  As long as you pick the same
angle (and other parameters) for both sides of the joint, the parts will
mate.  And if you don't like the angle you get---change it.

On Sun, Nov 17, 2024 at 12:15 AM Caddiy via Discuss <
discuss@lists.openscad.org> wrote:

I’ve had a look at some of the codes posted above and actually got one to
work. But the question remains:

In the image below, 60° triangles parallel to the z-axis linear_extruded
to the origin give an angle of 90° between the flanks of a spline, which
can be seen when one looks along a ridge towards the origin.

Are these then 60° splines or 90° splines?


OpenSCAD mailing list
To unsubscribe send an email to discuss-leave@lists.openscad.org

I think it's tough to tell what the angles are in the fixed view like that due to the distortion from perspective. In my code the triangles that form the teeth are constructed with the specified angle, but then they end up getting projected at a different angle depending on the cone angle you pick. Furthermore, there's the question of where the angle is measured. I think the wikipedia page suggested it is measured relative to the cylinder axis, but I'd normally expect tooth angle to be measured on the tooth, which means the slope of the tooth will also lead to a change in the effective angle. (Maybe this factor is what you're talking about?) I decided for my implementation to treat the requested angle as "nominal" and not worry about these various deviations. As long as you pick the same angle (and other parameters) for both sides of the joint, the parts will mate. And if you don't like the angle you get---change it. On Sun, Nov 17, 2024 at 12:15 AM Caddiy via Discuss < discuss@lists.openscad.org> wrote: > I’ve had a look at some of the codes posted above and actually got one to > work. But the question remains: > > In the image below, 60° triangles parallel to the z-axis linear_extruded > to the origin give an angle of 90° between the flanks of a spline, which > can be seen when one looks along a ridge towards the origin. > > Are these then 60° splines or 90° splines? > > > _______________________________________________ > OpenSCAD mailing list > To unsubscribe send an email to discuss-leave@lists.openscad.org >