G-Code Filtering/Optimizing
Newbie to 3D Printing. But, 30+ years of CNC manufacturing...
I recently did a print that was a small box to hold some tooling. It had relatively large radii for the box walls. The print came out fine, but the walls were obviously segmented. I went into the G-Code and I see that PrusaSlicer (Marlin 2 flavor) had chopped what should have been a single radius call into many smaller segmented radii moves. I don't expect these stepper motors to perform like the servo's I'm used to but breaking up these moves is not only inefficient in the coding, it is error prone at the output. It seems like it is giving the stepper motors every opportunity to make an ugly print. I guess it makes some sense because the steppers aren't as liable to get "lost" as they are making short moves instead of long moves.
It leads me to wonder if there are any programs that would optimize the G-Code back into the simpler radii. I know in Mastercam(cnc programming software I'm used to) there are many such settings and one can simply supply an allowable error (like ).001" and the radii will be simplified within the allowable error.
RE: G-Code Filtering/Optimizing
Check your STL (if that is what you used) to see if the wall arcs are segmented. (Spoiler alert, they will be because STL files do not support curves.) You may need to modify your mesh output for smaller segments. AFAIR I have FreeCAD set to 10µm decimation when exporting STL files. If you are able, you might want to export from your CAD as STEP. PrusaSlicer (and most likely derivitives) will load the STEP and auto convert to a mesh with a fine enough decimation that shouldn't be visible on a print unless you scale the object up a lot. Also in PrusaSlicer you can enable Arc fitting (Print Settings/Advanced/Slicing/Arc fitting:) to convert lots of short lines that conform to a circular arc into a single arc gcode command. Your printer must support gcode G2 and G3 commands.
See my (limited) designs on:
Printables - https://www.printables.com/@Sembazuru
Thingiverse - https://www.thingiverse.com/Sembazuru/designs
RE: G-Code Filtering/Optimizing
Thank you Sembazuru for the reply!
I output everything as a step file since that is what seems to be pretty universal across mastercam/Inventor/fusion/solidworks platforms. I have so far stayed away from *.stl files since they are a pain to import into CAD programs and manipulate/edit. I will check the arc-fitting, but I'm sure I have it selected. I have a quite new (2 months) old Prusa XL 2t, it does support standard Arcs(G2,G3).
RE: G-Code Filtering/Optimizing
I do have Arc Fitting selected, there are two other parameters that can be modified:
Slice Resolution and
G-Code Resolution
These could be interesting to play with... Any other input is appreciated.
Thank you,
Kevin
RE: G-Code Filtering/Optimizing
Hmm... The only other think I can think might be the issue would be VFAs (Vertical Fine Artifacts). I don't have any hands-on experience with XL printers (or any other core XY style printer), but hopefully I've guided you to a search term for your own research. (AFAIR most VFAs may be related to belt tension of the belts and/or motor degrees per step.)
See my (limited) designs on:
Printables - https://www.printables.com/@Sembazuru
Thingiverse - https://www.thingiverse.com/Sembazuru/designs
RE: G-Code Filtering/Optimizing
Yes, Thank you so much for taking the time to respond!


