General information about my experience with 3D printing. A list of personal projects is here, and the model files are available here.
I started out with FreeCAD. I was impressed by the range of capabilities that comes with the software and the quality with which they are delivered---at least initially. Everything worked well for small parts and the initial phases of the larger arm project. However, as the design grew, the tree-structure representation of design elements became unwieldy. It was difficult to predict how the tree would rearrange following an operation. Ultimately, a bug surfaced in the FreeCAD software, and I was unable to undo and recover my design. I started looking elsewhere and found Autodesk Fusion 360, which can be obtained free of charge for personal use. I was, and still am, quite new to CAD; however, Fusion 360 is obviously a top-notch product. Everything just works. The operations are stunningly intuitive and well-crafted. It is difficult to imagine a reason for looking elsewhere except, of course, for the facts that the free version cannot be used commercially and the commercial version is quite expensive.
The small deboss labels on various components contain the Fusion 360 version numbers of the design file. This is a handy way to keep track of the design file version used to print each component, particularly when diagnosing issues, updating the design, and printing new versions. I use the ParametricText add-in to automatically update the version numbers when saving the design file.
UltiMaker Cura is a simple tool with a single purpose: slice the mesh outputs of a mesh model into horizontal layers of 3D printer instructions. I used Cura successfully for quite a while, but eventually ran into issues with filament stringing. After trying many (many) alternative configurations, I found that the PrusaSlicer default settings are very effective, and I've been using this tool ever since.
With endless options on the market it can be difficult to choose; however, at under $200 (in 2022) with generally quite positive reviews, it was difficult to get past the Creality Ender 3. It was simple to assemble and has been cranking out high-quality pieces since the start.
I use OctoPrint with my Raspberry Pi as an efficient and easy way to manage print jobs. See here for tips on configuring OctoPrint on the Pi.
I added the CR Touch Automatic Leveling Kit to my Ender 3. The sensor comes with a mounting bracket for the Ender 3; however, it isn't truly designed for this model, and I had previously replaced the hot end with something different. As a result, the sensor was mounted too far above the bed, which caused the hot end to drop down into the bed. After much experimenting and searching, I found that the sensor needed to be offset down toward the bed in order for everything to work. I did this by adding spacers as shown below:
After installing the hardware, flash the printer with the correct firmware here. Download the firmware bundle prefixed with the printer name (e.g., "Ender-3 CR Touch Firmware" for an Ender 3 printer, or "Ender-3 V2 CR Touch Firmware" for an Ender 3 V2 printer). Within the bundle, select the board version. Note that 4.2.2 is an early board that requires a special adapter to plug the bed leveling probe into, whereas the 4.2.7 board has a direct connection for the probe. Clear an SD card and place the firmware binary onto the card as the only file. Name the file "firmware.bin", insert the SD card, and turn the printer off/on. The display should indicate that the firmware has been updated. Sometimes this is finicky, and the board doesn't take the firmware. Renaming the file "firmware-123.bin" or "Ender 3 firmware.bin" might work. The steps for calibrating the leveling probe's z-offset are as follows:
- Auto-home the printer.
- Move the z-axis to identify the appropriate z-offset using a sheet of A4 paper for thickness. Note the z-offset
that causes the nozzle to just slightly grab the paper. Call this
adjustment. - Auto-home the printer again.
- Access the leveling probe's z-offset and note its value. Call this
current. Then set the leveling probe's z-offset tocurrent + adjustment. - Save the configuration settings.
- Level the bed. The hot end should be in the correct position above the bed, with the z-value showing 0.0 on the printer display and a very small gap between the nozzle and bed.
- Add
G28 G29to your slicer's g-code preamble. TheG28(home) command is probably already present, in which case you just tack onG29(level bed). - Octoprint has a bed leveling visualizer plugin, which displays the bed mesh as shown below:

- Add
G28 G29to your slicer's g-code preamble. TheG28(home) command is probably already present, in which case you just tack onG29(level bed).
After installing the new bed leveling firmware above, I kept running into under-extrusion issues. It took a while to realize that the new firmware was configured with a lower extrusion rate than the stock Ender 3 firmware. The process for calibrating the extrusion rate (or e-steps) is as follows:
- Use the menu options to manually extrude 10cm (100mm) of filament. Here, 100mm is
expected mm. - Measure how many mm of filament is actually extruded, and call this
actual mm. Ifactual mmequalsexpected mmexactly, then there is no need to calibrate the e-steps. Ifactual mmdoes not equalexpected mm, then proceed. - View the extruder's current
steps/mmvalue. This is the number of steps that the printer expects it takes to extrude 1mm of filament. Multiplysteps/mm * expected mmto obtainsteps taken, the number of steps the extruder actually took to extrudeactual mm. - Calculate
steps taken / actual mmto obtain the calibrated steps/mm value. Enter this into the settings. For example:- Under-extrusion: (81 steps/mm * 100mm expected) / (93mm actual) = 87.097 steps/mm calibrated
- Over-extrusion: (81 steps/mm * 100mm expected) / (117mm actual) = 69.231 steps/mm calibrated
- Python function to obtain the calibrated steps/mm:
def calibrate( expected_mm: float, actual_mm: float, steps_per_mm: float ) -> float: return (steps_per_mm * expected_mm) / actual_mm
In the end, the automatic bed leveling update did not work very well. Some prints did okay, but others had issues when printing over the entire print bed. I ended up reverting back to the stock Ender 3 firmware as follows:
- Visit the Creality Cloud firmware site.
- Download
Ender-3Marlin2.0.6HW4.2.2 GD Version firmware, as my Ender 3 has the 4.2.2 mainboard with the GD chip. - After flashing the firmware, the default language is Chinese. The language menu is second from bottom in the main interface.
- Recalibrate the extrusion stepper motor (see above).
I updated to a glass bed, which is very flat, and also to a direct-drive adapter for the extrusion motor. This has been working well.
This is particularly relevant when the extruder stepper motor is skipping, the extruder gear is slipping on the filament, or the printer is under-extruding.
- Remove the nozzle: The flat end should be clean without any filament sitting on top, which might indicate that the bowden tube isn't tightly seated against the nozzle entry within the hot end.
- Replace the bowden tube.
- Replace the tube couplings in the extruder and hot end to ensure they will properly grab the new tube.
- Tighten the nozzle.
- Loosen the nozzle 3/4 a turn.
- Insert the bowden tube firmly and fully into the hot end coupling.
- Heat the hot end.
- Tighten the nozzle, which seats the bowden tube firmly against the nozzle.
- Trim the tube to length for the extruder so that it can easily reach all print positions.
- Insert the bowden tube firmly and fully into the extruder coupling.
- Level the bed if needed.
Perhaps related to the new hot end mentioned above, I started having serious trouble with filament becoming stuck in the heat sink. Forums are littered with discussions of heat creep, with solutions ranging across filament drying, slicer settings (extrusion speeds and distances), cooling fans, and extruder upgrades. In my case, upgrading the hot-end fan ($13) and converting the extruder to direct drive ($15) solved my problems.
