Skip to content

jchrzaniuk/Klipper-Adaptive-Meshing-Purging

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Klipper Adaptive Meshing and Purging

A uniquely simple adaptive meshing solution for Klipper-enabled 3D printers!


What is it?

KAMP is a project that was created to simplify the usage of adaptive meshing on Klipper-based 3D printers. Adaptive meshing is the practice of parsing values from a gcode file to define a mesh's dimensions. This gives you the benefits of using a bed mesh, but only specifically where it is needed, without passing a bunch of variables around. KAMP was designed with simplicity in mind!

Why do I want this?

The use of bed meshes is considered cheap insurance by the great Andrew Ellis in his very popular Print Tuning Guide. While I completely agree, I also believe in efficiency. Building a bed mesh can take a bit of time, and what's worse, a lot of it will be wasted because the mesh is not the same size as the build area being used, until now! Adaptive meshing will not only waste much less time and effort building bed meshes, it will make your meshes more effective by building a richer bed mesh tailored to the area you are actually using when you print. Imagine the perfection your first layer can become because almost no information is wasted in your bed mesh!

How does it work?

Thanks to the great work from kageurufu on [exclude_object] in the Klipper firmware, we are able to easily work out a bed mesh's min and max values by pulling out a sliced object's size and clamp that size to a bed mesh. Imagine making a bed mesh, but the size of a Benchy! Multiple objects in gcode are parsed the same way, so the mesh density can adapt to any number of objects, as long as they fit on your buildplate. We can also use these values for localized purge lines, purging near the print. No more long romantic walks from the corner of the buildplate to the first extruded line.

Sounds interesting, what does an adaptive mesh look like?

Well, for clarity, let's look at a normal 7x7 mesh:

This is a normal 7x7 mesh. If I were printing just a couple small objects, or one large object, or a plate full of parts, this is what a machine will normally make.

Now, here's what an adaptive mesh looks like:

This is an adaptive mesh for a small object near the origin of the bed. Despite the fact that the object is only 20mm^2^, a 3x3 mesh was still created, making this mesh extremely dense, which will result in an even better first layer.

This is an adaptive mesh for a skinny and long object at the back of the bed, 200mm x 10mm in size. While the object is rather small, KAMP made a mesh that is 7x4, almost exactly the size of the object, and packed with information.

Does this work with any printer with a probe?

As long as the printer is running a recent version of Klipper, and has a probe, KAMP is ready to serve you.

Use caution with inductive probes and beds with powerful magnets, though. Also, if you have Klipper excluding areas of your bed mesh using Faulty Regions, you will need to #comment out or remove that configuration to use KAMP.

If you have a workaround that makes Faulty Regions compatible, please submit a pull request! 😄

⚠️ A note on the usage of a Relative Reference Index:

Relative Reference Index is a method used in the Klipper firmware to calculate mesh points for printers that have a probe, as well as a physical Z endstop, like the ones commonly found on Voron printers. Normally, when using Relative Reference Index, the mesh point closest to the Z endstop or the center of the bed is defined, and that point becomes Z0.0 in the mesh, and all other points are scaled in Z from that point. This is normally fine when the mesh can't move around, as that point will remain consistent. We've gotten KAMP to change that value depending on the size of the mesh that is adaptively generated, but current Klipper limitations do not allow us to use that value and home the Z axis to it, setting that point in the mesh to Z0.0. What this means for Relative Reference Index users, typically, is your mesh may appear strange, but should work as intended. If you've got a creative solution that works, feel free to submit a Pull Request and contribute to the project!

Looks awesome! How do I get started?

Prerequisites:
  • You must have a version of the Klipper firmware that supports Object Exclusion, and have [exclude_object] defined in your printer.cfg file. 1

Printer.cfg

[exclude_object]
...
  • Once you have exclude_object defined in your printer.cfg file, make sure you have enable_object_processing: True under [file_manager] in your moonraker.conf file. This will allow Klipper to process incoming gcode files for objects. 1

Moonraker.conf

[file_manager]
enable_object_processing: True
...
  • You must have object labeling enabled in your slicer. (Usually in slicer output options.)

⚠️ Expand me if you use a dockable probe like Klicky or Euclid:

If you are using a BED_MESH_CALIBRATE macro override for probe attachment routines, you must #comment it out or remove it. Don't worry, we thought ahead and made it easy to define macros that attach and remove a probe, like for Klicky, Euclid, and other dockable probes.

klicky-probe.cfg

Simply add a # before the [include ./klicky-bed-mesh-calibrate.cfg] to disable it.

...
#[include ./klicky-bed-mesh-calibrate.cfg]
...

And update the variables in Adaptive_Mesh.cfg:

variable_probe_dock_enable: True       # Normally False, enable with True if you have a dockable probe.
variable_attach_macro: 'Attach_Probe'  # The macro you use to attach the dockable probe.
variable_detach_macro: 'Dock_Probe'    # The macro you use to dock the dockable probe.
...

Installation:

  1. Copy the configuration files to your klipper instance and use [include] to add them to your printer's configuration like this:

    Printer.cfg

    [include Adaptive_Mesh.cfg]
    [include Adaptive_Purge.cfg]
    ...
  2. Check the macro variables at the top of each configuration file and adjust them accordingly. With them, you can enable status lights, use dockable probe commands, or even allow mesh point fuzzing! 2

  3. Double check your PRINT_START macro to ensure BED_MESH_CALIBRATE and/or ADAPTIVE_PURGE macros are defined.

  4. Enjoy!

Helpful tips & information:

  • For richer meshes when printing more/larger objects, increase probe_count in your [bed_mesh] configuration. We recommend at least 5,5 for a 25-point mesh, but because KAMP can adapt (and rich meshes are beneficial), a 49-point mesh maximum is encouraged, or 7,7.

  • If you don't have a good PRINT_START macro to use, check out some of the excellent work my good friend Jontek2 has done for a simple and powerful PRINT_START configuration for Voron printers!

  • Try out the ADAPTIVE_PURGE macro and sign your work with a neat VoronDesign logo purge right before your print begins! There's lots of neat variables that can be configured to get it perfect, every time.


Troubleshooting:

Error:

0 points, clamping to bed mesh [(X_Value,Y_Value) (X_Value,Y_Value)]

This error is caused by BED_MESH_CALIBRATE or PRINT_START being called in your gcode file before EXCLUDE_OBJECT_DEFINE is. This is something you slicer may be doing. Currently, exclude_object injects the object definition code after the first line of gcode it sees. This is being worked on and will be fixed as soon as the PR is merged into Moonraker.

Solution:

In the mean time, you can add a gcode command in your slicer's start gcode section before PRINT_START is called and that will fix the issue. M117 is a good one to use, it'll just clear the display's current message.

Here, M117 has been added to the Slicer's Start gcode.

Error:

Move exceeds maximum extrusion (X.Xmm^2 vs X.Xmm^2)

Solution:

This happens when an extrusion move exceeds Klipper's max_extrude_cross_section value. You typically need to increase this value to get a small and effective purge to work. We recommend setting this value to 5 to allow purging, but still protect your extruder if something else is wrong.

Example:

[extruder]
...
max_extrude_cross_section: 5
...

Honorable Mentions and Amazing Contributors:

  • MapleLeafMakers - for assisting in the inception of the project.
  • Julian Schill - A true code warrior and jinja ninja.
  • KageUrufu - For spearheading object cancellation in Klipper, and helping make this possible.
  • The Voron Helpers and Voron Contributors team, a group I feel are my close friends.

Footnotes

  1. After making any changes to critical Klipper or Moonraker functions, be sure to use FIRMWARE_RESTART, as well as restart your Moonraker instance so those changes take effect. 2

  2. Mesh point fuzzing allows the user to fuzz mesh points to spread out possible polishing marks and wear from nozzle-based probes, like load cells or Voron Tap.

About

A unique leveling solution for Klipper-enabled 3D printers!

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published