Thread for Screw Tutorial

Introduction
This tutorial is a collection of techniques to model screw threads in FreeCAD. It was updated for v0.19, although the overall process has been essentially the same since v0.14, when the tutorial was originally written. The updated content focuses on the use of the PartDesign Workbench to create the thread, and new illustrations for methods 0 to 3.

In traditional CAD systems modelling screw threads is discouraged because it puts a big load on the modelling kernel, as well as on the rendering of the shapes. In traditional systems a thread does not need to be represented directly in 3D space, as it can be indicated with its required characteristics in the 2D technical drawing that is sent for manufacturing. However, with the popularization of additive manufacturing (3D printing), there is now a real need to model 3D threads, in order to print them exactly as designed. This is what this tutorial is for.

Many of the techniques presented here have been collected from different forum threads:
 * Gathering thread modeling techniques
 * Creating a thread: Unexpected results

See also helpful videos:
 * Introducing a strategy for designing a bolt without the commonly found problems.

Remember that thread shapes take a lot of memory, and having just one thread in a document can increase the file size significantly, so the user is advised to create threads only when absolutely necessary.

Method 0. Obtain one from libraries of parts
Using models that other people have made is easy and saves time. See the external workbenches page for information on external tools.

In particular, two resources are recommended that can be installed from the Addon Manager:
 * Fasteners Workbech, to place parametric screws and washers that follow ISO standards. The screws and nuts by default don't show a thread, but this can be controlled with an option.
 * BOLTSFC, to place standard parts from the BOLTS library, which also follow ISO standards.



Method 1. Using macros (deprecated)

 * In the past, the Macro BOLTS was used to insert the parts from the BOLTS library. This is now deprecated. Use the BOLTSFC workbench instead.


 * In the past the stand-alone Screw Maker macro, by ulrich1a, was used to create individual bolts, screws, and washers. This is now deprecated. The Fasteners workbench, by shaise, includes the screw maker macro completely, together with a toolbar to select the right component.

Method 2. Fake threads: non-helical
In many cases we don't need real threads, we just need a visual indication that the threads will be there.

We can create a fake thread by using a non-helical path, for example by revolving a sawtooth profile, or by stacking discs with tapered edges. This fake thread is hard to tell apart from the real helical one by simple inspection. This method is good for visualizing a thread-like object, but it is not useful if we need to 3D-print an actual thread.



Revolving sawtooth profile

 * 1) Click on.
 * 2) Click on . Select.
 * 3) Draw a closed sketch with the required inner diameter, outer diameter around , pitch , number of teeth , and total height.
 * 4) Select the sketch, then click on . Select, and press.





Stacking discs

 * 1) Repeat the first two steps from the previous section.
 * 2) Draw a closed sketch with the required inner diameter, outer diameter around , and pitch , but draw only a single tooth of the sawtooth.
 * 3) Select the sketch, then click on . Select, and press.
 * 4) Select the, then click on . Select . For a fake thread with a pitch of , set the  to , and  to , then press . This will create two discs, one on top of the other.
 * 5) You can add more discs by increasing the value of  in the linear pattern, and by raising the, which is the total length of the fake thread.

The and  are related. If the length is too large, but the number of occurrences is not high enough, you will have disconnected discs, and the Body computation will fail, as the resulting object must always be a single contiguous solid. For example, to get a total height of, set to  and  to.

If you wish, you may add a with a diameter equal to the inner diameter of the discs, and as high as the total thread height. This will join all discs into a single solid, thus guaranteeing that there will not be disconnected discs.





PartDesign
A true thread consists of a closed profile sweeping a solid along a helical path.


 * 1) In the Workbench_Part.svg Part Workbench, click on  to create a . Give it the appropriate values for ,  , and.
 * 2) Move to the Workbench_PartDesign.svg PartDesign Workbench, and click on.
 * 3) Click on . Select.
 * 4) Draw a closed sketch with the required profile for the thread teeth, normally a triangular shape. In this case we will use a height of, which is slightly smaller than the  pitch used for the helix path. The profile must not create any self intersections when moved along the helix, neither between the turns nor in the middle, thus the sketch as shown for stacking disks cannot be used.
 * 5) Select the sketch, then click on . In, click on , and choose the helix object previously created. Then change  to  so that the profile sweeps the path without twisting; then press.
 * 6) When the dialog asks for a reference, choose.
 * 7) The helical coil is created, but there is no central body or shaft.
 * 8) Click on  with the appropriate   and   to touch the rest of the helical thread and automatically fuse to it.
 * 9) Additional boolean operations are needed to shape up the abrupt ends of the coil. For example, you can use additive features to provide a head to the screw, and a tip.







Part
This process can also be done with the tools of the Part Workbench.
 * 1) In the Workbench_Part.svg Part Workbench, click on  to create a . Give it the appropriate values for ,  , and.
 * 2) In this case, you don't need a . Switch to the Workbench_Sketcher.svg Sketcher Workbench, then click, and choose the global XZ plane.
 * 3) Then return to the Workbench_Part.svg Part Workbench, and use.
 * 4) Select the appropriate sketch from  and click the arrow to pass it to.
 * 5) Click, and choose all edges of the existing helix in the 3D view. Click.
 * 6) Make sure to tick  and . Obtaining a solid is the key to be able to perform Part Boolean operations with the resulting coil, otherwise only a surface will be produced.
 * 7) Click  to exit the dialog and create the coil.

Now you can proceed to add other primitives like, or other shapes, in order to perform and  to finish building the screw.



Tips for success

 * When the profile sweeps the helix, the resulting solid coil must not touch or self-intersect as it will be an invalid solid. This holds for the profile moving along the helix, as well as intersections in the center of the helix. Attempts to do boolean operations with it (fuse or cut) are very likely to fail. Check the quality of the coil with ; if self-intersections are reported, you must increase the pitch of the helix.




 * When a cylinder is added to a coil to form the main shaft of a screw, the cylinder must not be tangent to the coil profile. That is, the cylinder must not have the same radius as the inner radius of the thread, as this is very likely to fail a fuse operation. In general, avoid geometry coincident to elements of the sweep, such as tangent faces, or edges tangent to faces they are not connected to. In order to produce a good boolean union, the swept coil and the cylinder must intersect. Check the quality of the fusion with ; if coplanar faces are reported increase the cylinder's radius by a small amount.
 * If the coil and the cylinder are tangent, even if the first fusion succeeds, it may fail in subsequent boolean operations with a third solid.
 * This is a limitation of the OpenCASCADE Technology (OCCT) kernel; in general, it doesn't handle well operations between coplanar surfaces.




 * The inner cylinder has a seamline. You should avoid placing the start of the helix along that seam. Either turn the helix or the cylinder by some degrees.


 * The radius of the helical path does not matter, unless the helix is tapered. All that matters is the pitch and the height of the helix. This means that you can use a single to generate several threads with equal pitch. What determines the position of the resulting coil is the position of the profile sketch.


 * Keep the thread short, that is, with a low number of turns. Long threads tend to fail with boolean operations. If you need to add many turns, consider creating first a short thread, and then using to duplicate the same pattern several times.


 * For 3D visualization and 3D printing it may be okay to leave the cylinder and the thread unfused, that is, with intersections between the two solids. Reducing the amount the boolean operations results in less memory consumption and smaller files.

Pros and cons

 * Edit_OK.svg Easy to understand.
 * Edit_OK.svg Very natural way of defining a thread profile.
 * Edit_OK.svg No problems with meshing of the resulting object, unlike method 4.


 * Edit_Cancel.svg Due to invalidity of self-intersecting sweeps, it is next to impossible to generate a thread with no gap between each tooth, that is, with no straight cylindrical face at the inner sides of the thread.
 * Edit_Cancel.svg Boolean operations are required to obtain a single contiguous solid. Boolean operations take take a relatively long time to calculate, and fail often.
 * Edit_Cancel.svg Threads with a high number of turns are problematic.

General
The idea is to sweep a horizontal cross-section of the thread along a helix. The main problem here is figuring out the profile to use to obtain such thread.



If one uses a circle as a horizontal profile (the circle has to be placed off the origin, that offset defines the depth of the thread), the thread profile will be sinusoidal.

To obtain a standard sawtooth profile, a pair of mirrored archimedean spirals need to be fused into a wire. The resulting figure is a heart shape, which becomes barely distinguishable from a circle when the depth of the thread is small compared to its diameter, this is why a "thick" thread is shown on the picture above.

Generating the profile
Figuring out the horizontal profile to obtain a certain vertical profile is not easy. For simple cases like triangular or trapezoidal it can be constructed manually. Alternatively, it can be constructed by creating a short thread with method 3, and getting a slice of it by doing a Part Common between a horizontal plane face and the thread.

Profile for triangular thread

 * 1) First create an Archimedian spiral in the XY plane.
 * 2) Set the number of turns to 0.5.
 * 3) Set the radius to the inner radius of the thread, the outer radius will be this plus the depth of the cut.
 * 4) Set the growth to double the depth of cut of the thread.
 * 5) Part Mirror the spiral against the XY plane
 * 6) Part Fuse the spiral and the mirror to obtain a closed wire, shaped like a heart.

Profile for arbitrary cross-section



 * 1) Make a vertical cut profile. Make sure that the height of the sketch matches the pitch of the thread you need.
 * 2) Make a helix1 with height identical to the pitch and the pitch identical to the thread pitch, and a helix radius of 0.42*nominal diameter of the thread.
 * 3) Sweep the cut profile along the helix1. Set  and.
 * 4) Make a circle with nominal radius of the thread in the XY plane.
 * 5) Make a face from the circle. This can be done with  or, then set  to.
 * 6) Cut the face with the sweep profile.
 * 7) Make a  from the cut.
 * 8) Use  on the clone in order to get a wire. This wire is the horizontal profile needed for this method.
 * 9) Make a helix with radius of nominal radius of the thread and a pitch of the thread and the height of the needed thread.
 * 10) Sweep the wire along the helix.  Set  and.
 * 11) You are done.

The step-by-step guide was taken from this forum post by Ulrich1a ("Creating a thread: Unexpected results"), slightly modified.

The steps are also shown in action on this video by Gaurav Prabhudesai ("FreeCAD : How to make threads").

Pros and cons

 * Edit_OK.svg a ready-to-use thread-on-a-rod solid shape is created by the sweep directly.
 * Edit_OK.svg fewer or even no boolean operations are required, so generation speed is very high compared to Method 3.
 * Edit_OK.svg thread ends are nicely cut straight away
 * Edit_OK.svg long threads are not a problem, unless a boolean operation is needed. Otherwise, it is not going to be much better than Method 3.
 * Edit_OK.svg threads without a gap are not a problem.


 * Edit_Cancel.svg defining thread profile is complicated.
 * Edit_Cancel.svg using the standard mesher with a thread created in this way generates ugly meshes, which can lead to problems. Other meshers are better, for example, Mefisto seems to give the best results.
 * Edit_Cancel.svg large memory footprint according to Gathering thread modeling techniques.

General
Helical splines will extrude coaxial faces that are able to be lofted, while FreeCAD's parametric helix won't.   It takes two helical splines to define a thread. Those two can be scaled from a library spline, then located and extruded appropriately to get the form right.

FreeCAD's parametric helixes aren't truly helical, but helical b-splines aren't difficult to lay out. One manual method is to array dodecagons (12-sided polygons) with 5mm radius/10mm diameter at 1/12mm (0.08333.mm) z intervals and trace splines from vertex to vertex in ascending and rotating order, and to consider doing it once with, say, 10 turns, so that that spline can be re-used as a library file for import and reuse. It's convenient to use 10mm diameter/1mm pitch for ease of scaling. If you are doing it manually, drawing a Dwire and then converting it to a b-spline is easier than drawing a spline. Dwires don't have curvature computed while being drawn, so they follow the cursor and snap more obediently.

Once the splines are scaled to the right size and located so that the loft will have the right included angle between the thread flanks, they're extruded along their axis, a pitch length's worth for the inner spline, the outer pitch/8.



ISO and other threads have relieved, ie flat, inner and outer edges rather than sharp, which suits FreeCAD users with this method, because we can loft to the helical face at the nominal fastener size, while an inner face can't be lofted to an outer edge spline because a face is a closed profile, a spline is open. ISO standard says the nominal size of external threads have a face width pitch/8. The picture shows how the geometry is arranged, and the helical faces that result. Then, loft between the faces, and then a cylinder that gives the inner helical face, which ISO puts at pitch/4 width, is added to the threads.



This method produces reliable solids that boolean properly. While it doesn't produce "parametric" screw threads in standard sizes in the sense of having simple access to form by fastener size, it's an easy way of producing an accurate library for reuse, and models of specialised forms like ACME, or Archimedian screws, are also uncomplicated as one-offs.