-
Notifications
You must be signed in to change notification settings - Fork 143
Change Log
- Initial Release (forked from my ERCF-Software-V3 project which is now deprecated).
- HHv2 is a rewrite to structure the software so it can support all types of MMU (only ERCF at release) and sanitize command set
- Adds total control of motor synchronization, multiple endstops (even for the extruder!!)
- Although HHv1 (aka ERCF-Software-V3) will remain available, HHv2 will be where all future enhancements will be made
- The latest KlipperScreen-Happy_Hare edition requires HHv2 (for my sanity)
- Much better doc and LOTS of new features to discover
- Speed and extrusion overrides (M220/M221) support .. records overrides across tool changes (MMU_TOOL_OVERRIDES command to see/reset)
- SpoolMan support (new options to MMU_GATE_MAP for SpoolD.. see doc)
- Separate "per-print" and total swap stats! No need to clear in your print_start anymore.
- "Auto restoring" gate quality indication (the "excellent/good/../terrible" one). Slowly averages out bad results.
- New "state machine" that closes a lot of annoying corner cases that I knew about but most users hadn't found yet doc.
- New filament cutter option (Alternative
_MMU_CUT_TIP
macro) instead of tip forming andmmu_form_tip_macro
setting - MMU_UNLOCK is back (but as an optional step to resume temps). Can just call
RESUME
as well. - Better support for Octoprint users where the [print_stats] module is not available. Read up on new state machine and
_MMU_START_PRINT
and_MMU_END_PRINT
conventions (must read doc) - New moonraker gcode pre-processor module! Adds !referenced_tools! placeholder so you can automatically check all used tools before printing wiki
- 'MMU_FORM_TIP' command updated to allow for runtime "tuning" Any variable to the macro can be adjust (and persisted) for testing or tweaking in print (handles tip cutting macro as well)
- Config now also automatically adjusts references to "extruder" when referring to stepper (e.g. in rare [controller_fan], [homing_heaters] and [angle])
- Lots of little things/bug fixes but I lost track 🫣
- Replacement of manual steppers with new MMU toolhead - faster homing and movements in general, new optional
gate
andextruder
sensors, optional encoder, intial support for Tradrack and other customized designs. - Ever wanted to use Happy Hare on a non-ERCF MMU?
- Ever wanted to use a pre-extruder entry sensor instead of collision?
- Wanted to fit a gate sensor and not rely on encoder for loading and parking at the gate
- Want to run without an encoder? (why? 🤷 )
- Want fast (no wait) homing?
- DON'T WANT TO RECONFIGURE YOUR EXISTING EXTRUDER? 👍
- Want the latest and greatest features?
NOTE: Requires Klipper 0.12.0 or greater
- LED support for bling, gate_status, filament color and action status, pre-gate sensor support for automated loading and gate_status setting, BTT MMB board support, integrated filametrix cutter support, new [mmu_sensors] config section of easy sensor setup. Doc improvements. New Features:
- LED (bling) support! See new page in the wiki doc
- Pre-gate sensor support: Automatically set gate_status, LED status and activate pre-load. Oh, and new earlier run-out detection of reliable EndlessSpool
- Installer updates and support for BTT MMB board
- Integrated Filament Cutter support (Filametrix)
- Improved doc. E.g. Conceptual MMU
- New [mmu_sensors] section for simple setup of filament_sensors and endstops
- Enhancements for gate_sensor as alternative or in addition to encoder
- Lots of bug fixes and minor enhancements requested.
- Version tracking and better feedback on what to do
- Enhancements to existing commands. E.g try: 'MMU_STATUS SHOWCONFIG=1'
- Better Spoolman integration: will now pull material and colors from spoolman in addition to activating the spool
- Allow the LED effects to be configure anywhere on a chain (as well as gate 0->N or N->0 ordering)
- EndlessSpool got some love because I think it will be much more valuable with pre-gate switches and early runout detection:
- a) endless_spool_on_load parameter that will activate ES on loading a tool with empty gate
- b) endless_spool_final_eject distance specification for push beyond park position in an attempt to prevent filament from being accidentally re-loaded
- c) Cleanup of the display on klipper console and log messages
- d) Will ensure that the gate_status is at least "unknown" when MMU_REMAP_TTG is run, so attempt will always be made to load from the gate
- Updated LED support with lots more "multi-segment" flexibility
- New servo calibration - to fine tune and save without klipper restart!
- New full set of default toolhead positioning macros (defined in
mmu_sequence.cfg
) - Full support for pre-extruder sensor option (prior to extruder entry)
- Exposed vendor-specific params (including the "cad_" set -- see doc at bottom of
mmu_parameters.cfg
) - Full support for Tradrack including installer
- New manual bowden calibration for setups without encoder
- Workaround for CANbus comms timeout that is plaguing klipper
- Much improved
MMU_STATUS SHOWCONFIG=1
. It will tell you in english what loading and unload sequence you have based on dynamic changes withMMU_TEST_CONFIG
or sensor disable/enable. - EndlessSpool is now available on tool load
- Sync feedback sensor support .. I.e support for Annex Belay or another other sensor including proportional feedback. doc
- Improved "tip forming" test procedure and
MMU_FORM_TIP
command - Fixed silly bug in spoolman integration where spool_id was being used to search as filament_id
- New
toolhead_ooze_reduction
parameter for tuning without messing with what should be fixed extruder measurements. Doc page to follow - Refined toolhead unloading with better detection of incorrect config
- Cleanup and separation of config files based on function
- Lots of new/updated doc
- Fixes / update to the way toolhead movement occurs through the "sequence macros" like
_MMU_PRE_UNLOAD
and_MMU_POST_LOAD
etc.- Also if enabled these will now work while not actively printing (that was an oversight)
- These macros also play nicely with Klippain pause/resume macros now
- The z_hop_height_error has been deprecated. Additional z_hop height can be configured in the macro variables at the start of mmu_sequence.cfg
- LED update
- Better error feedback on LED misconfiguration
- Fix for led index when order of reversed.
- New placeholder preprocessing for colors and filament temps pulled from you slicer ( !colors! and !temperatures! ). See here
- LED update: New effect
custom_color
. This will display colors stored for each gate based on user setting. One example use is to render the colors used in the slicer so you can visually compare with what is loaded. Documentation is in the gcode pre-processing section. - Improved movement "sequence" macros. These now work better when not completely homed (e.g. z-hop is optional.
- CUT_TIP macro now has option to control whether movement goes back to wipetower or not after cut
- Faster pausing on runout
- Fix for not automatically engaging the sync/servo after fixing error and resuming.
- New Slicer Setup doc on how to setup your slicer to disable tip forming
- New Toolchange Movement doc on how to setup toolhead movement during toolchange or error
- Couple of new states to filament movement. These are to enable and display of various other sensors such as a gate sensor (option to encoder) and pre-entry extruder sensor.
- New rendering of filament position in console (and KlipperScreen-HH) showing all sensor options if fitted
- Imporved use of miscellaneous sensors to detect errors or non-errors
- Cleanup of the status displays of various commands
MMU_GATE_MAP
,MMU_TTG_MAP
,MMU_ENDLESS_SPOOL
- New encoder calibration routine that allows calibration that "remembers" gate homing point and compensates for space between gate sensor and encoder if both are fitted
- Other bug fixes report in github "Issues"
- Bug fixes reported via github "Issues"
- Added capability to install to auto-check github to ensure the latest version and to switch branches with
-b <branch name>
option
This release centralizes macro configuration and extends will a lot more pre-packaged options
- Macro config moved into a unified
mmu_macro_vars.cfg
. - Default macros have become read-only with a formal way to add custom extensions
- New recommended "print_start" and end integration
- New
MMU_SLICER_TOOLS_MAP
command that is used by the "print_start" and for easy integration of non-wipetower purge options like the excellent "Blobifier" E.g.
> MMU_SLICER_TOOL_MAP DETAIL=1
--------- Slicer MMU Tool Summary ---------
2 color print (Purge volume map loaded)
T0 (Gate 0, ASA, ff0000, 245°C)
T1 (Gate 1, ABS+, 00fe02, 240°C)
T6 (Gate 6, ABS, 0310fe, 240°C)
Initial Tool: T0
-------------------------------------------
Purge Volume Map:
To -> T0 T1 T2 T3 T4 T5 T6 T7 T8
T0 - 200 210 210 200 200 200 210 210
T1 200 - 210 210 200 200 200 210 210
T2 210 210 - 220 210 210 210 220 220
T3 210 210 220 - 210 210 210 220 220
T4 200 200 210 210 - 200 200 210 210
T5 200 200 210 210 200 - 200 210 210
T6 200 200 210 210 200 200 - 210 210
T7 210 210 220 220 210 210 210 - 220
T8 210 210 220 220 210 210 210 220 -
- New Tip Forming and Purging doc
- New printer variables:
printer.mmu.slicer_tool_map.initial_tool
printer.mmu.slicer_tool_map.tools.<tool_num>.material|color|temp
printer.mmu.slicer_tool_map.purge_volumes
-
printer.mmu.runout
which is true during runout toolchange -
printer.mmu.active_gate
map of a attributes of current filament (like color, material, temp,..)
- Z-hop modfications:
- By default HH will not return to pre-toolchange position (will only restore z-height).
- New
variable_restore_xy_pos: True|False
to control sequence macros return to starting pos or let the slicer do it. This has benefit when printing without a wipe tower so the print is not contaminated at the point of tool-change
- New "addons" folder for recommended third-party extensions with ready-to-use configs
- Includes @kevinakasam's "EREC" filament cutter logic for cutting at the MMU (ERCF specific)
- Includes @dendrowen's excellent "Blobifier" - intelligent purging that doesn't require a wipe tower!! (Any MMU)
- Enhanced
MMU_SENSORS
command for quick review of all mmu sensors - New (optional) popup dialog option in Mainsail/KlipperScreen/Fluidd when MMU pauses on error
- Two new pre-processing placeholders: !materials! and !purge_volumes!
- Also, thanks to the Blobifer author, @dendrowen, the "MMU Statistics" has been given some love with new layout and some new customization. For both total stats and current job status. See
console_stat_*
options inmmu_parameters.cfg
). Note advanced formatting on Python3 only.
MMU Statistics:
+------------+-----------------------+--------------------------+----------+
| 1895(1230) | unloading | loading | complete |
| swaps | pre | - | post | pre | - | post | swap |
+------------+------+---------+------+------+---------+---------+----------+
| total | 0:47 | 6:54:24 | 0:02 | 0:02 | 5:35:31 | 6:40:30 | 20:05:52 |
| └ avg | 0:00 | 0:13 | 0:00 | 0:00 | 0:10 | 0:12 | 0:35 |
| this job | 0:36 | 4:26:51 | 0:01 | 0:01 | 3:34:34 | 4:34:54 | 13:22:01 |
| └ avg | 0:00 | 0:12 | 0:00 | 0:00 | 0:10 | 0:13 | 0:38 |
| last | 0:00 | 0:12 | 0:00 | 0:00 | 0:10 | 0:17 | 0:42 |
+------------+------+---------+------+------+---------+---------+----------+
11:43:27 spent paused over 10 pauses (All time)
8:15:38 spent paused over 3 pauses (This job)
Number of swaps since last incident: 105 (Record: 1111)
Gate Statistics:
#0: 😎, #1: 😎, #2: —, #3: —, #4: —, #5: —, #6: 😎, #7: —, #8: —
The release provides more flexibilty in tool change movement, introduces consumption counters, optimizes statistics output
- New (moonraker) pre-processing option to lookahead for next print location to allow for option to move to the NEXT print position on completion of tool change. Requires addition to
[mmu_server]
section ofmoonraker.conf
:enable_toolchange_next_pos: True
-
variable_restore_xy_pos
can now be "none", "last" or "next" (next being new functionality) - Augmented
MMU_STATS
functionality to provide "consumption counters" that can warn or even pause your print when threshold is exceeded - New doc page to explain statistics and consumption counters
- New doc page to explain spoolman config and use
- Elimination of "h" option to ERCFv2 MMU - ThumperBlock are not a compatible 23mm wide so no longer required
- More accurate timing of tool change phases
- Defaults for "white" and "black" filament can not be configured in
mmu_macro_vars.cfg
- Fixes to
printer.mmu.runout
andprinter.mmu.last_tool
for better accuracy at all possible times - Filament remaining in toolhead is now tracked accross reboots / restarts to prevent over extruding initial load
-
custom_color
is now a more intuitiveslicer_color
and set with theMMU_SLICER_TOOL_MAP
command (MMU_START_SETUP does this for you) - New config parameter
extruder_temp_variance
to specify the +/- delta allowable when waiting for extruder temperature - Updates and to bloblifier macro (needs latest klipper)
- Allow specifying spool_id in advance for supporting RFID readers. You can read more about it here
- Fixed incorrect doc in
mmu_macro_vars
- Bug: Fixed user defined load/unload_sequence macro names (previously would always look for default names)
- Add all slicer tools to the "slicer_tool_map" (unused tools only visible with DETAIL=1 flag).
- Set color on Tx macros so color can be seen in Mainsail / Fluidd UI's. Requires refresh of Mainsail screen because it doesn't update dynamically :-(
- Doc converted to Wiki and removed from distribution. Old doc links will be invalid
Main focus on this release is the reduction of blobing, stringing and tuning for beautiful prints Read here. Most issues are because of incorrect toolhead parameters and the former lack of a retract setting when the toolhead is moving. Both of those are now solved with automated toolhead calibration (including tip cutting variables) and an new z-hop ramp setting:
- Added new
MMU_CALIBRATE_TOOLHEAD
command for automated measurement oftoolhead_extruder_to_nozzle
,toolhead_sensor_to_nozzle
,toolhead_entry_to_extruder
andtoolhead_ooze_reduction
. Read the doc but this will eliminate incorrect "trial and error" values for these key dimensions. - Added new
toolchange_retract
andtoolchange_retract_speed
parameters to allow for retraction at the time of "z-hop" and un-retract as print resumes. - Added new
z_hop_ramp
parameter to control how the toolhead move off the print to help break stringing. It allow the definition of a horizonal move on top of the "z-hop". The direction will be towards the center of the print area. The toolhead will ramp up and away from the print and then move back to original position above starting point.z_hop_speed
should be increased closer to your x,y travel speed - Updated
form_tip
andcut_tip
macros (and Blobifer) to correctly compensate fortoolhead_ooze_reduction
andtoolchange_retract
- Blobifier automatically calculates "additional purge" volume basaed on filament left in the hotend based on calibration rather than having to compensate by altering slicer purge map
- New printer.mmu variables.. 'extruder_filament_remaining', 'extruder_residual_filament', 'toolchange_retract' for use in your own macros
- Removed some minor pauses when resuming print
- New
MMU_COLD_PULL
helper command. Useful in its own right but essential for the new toolhead calibration. Check it out - it can work in a completely automated way (/~https://github.com/moggieuk/Happy-Hare/wiki/Blobbing-and-Stringing#---cleaning-extruder-with-a-cold-pull)
Other new features include:
- Help address one of the Timer Too Close error conditions - Klipper has a less than optimal "save-variable" implementation can can cause problems with old/slower SD-cards. To workaround this HH now includes a batch update so all the HH overhead is combined into one or two calls rather than the previous 10 or so. You can see a "mmu__revision" added to you
mmu_vars.cfg
that increments on every write. - Couple more bug fixes (erroneous load errors) when using the
EXTRUDER_ONLY=1
flag on extruder loading/unloading without using bypass - Added
gate_autoload
parameter to allow the pre-gate sensor autoload feature to be disabled - Enhanced EndlessSpool functionality with
endless_spool_eject_gate
option allow for one gate to marked the waste gate ('W' in status) so that filament fragments will be sent to this gate rather than current gate. Allows for a "dump shoot" and prevents possible tangling when buffering on certain buffer designs where retracted filament end can escape into neighboring buffers. The default value of-1
will use the current gate. - Change parameter name
extruder_homing_current
toextruder_collision_homing_current
to be more precise on meaning (upgrade will have made this change for you) - Improved
MMU_STATUS SHOWCONFIG=1
functionality - New installer support:
- For new MMU's boards
- For GDW DS041MG servo option with Siboor ERCFv2 kits
- New
servo_always_active
parameter for servos that require continuous PWM signal (like GDW DS041MG). Use with caution! -
MMU_CHECK_GATE
now defaults to current gate when invoked with no arguments.ALL=1
flag to force checking all gates. - New Wiki content and enhancements to existing pages
- Bug fixes: one condition that could result in klipper "stepcompress" error
Main focus: tighter integration with spoolman
- Better integration with spoolman db. Printer name and gate assignment will be reflected in the spoolman db (requires spoolman >= 0.18.1)
- Now three modes of spoolman integration:
readonly
the former mode,push
the former augmented with the updating of assigned gate directly in spoolman, andpull
where the gate map is defined by what is in spoolman. Useful in larger print farms. This is controlled via a newspoolman_support
parameter. Details here - New
MMU_SPOOLMAN
command for performing gate related management (updates) to spoolman db - New innovative automatic TTG mapping strategies. Controlled by
variable_automap_strategy
. Essentially this is applied after reading the slicer tool map to ensure mapping to the correct gate even if the MMU is loaded incorrectly. Strategies include: 'none', 'filament_name', 'material', 'color', 'closest_color', 'spool_id'. Details here - Moonraker plugin now parses the filament names and includes in slicer tool map and mmu gate maps
- Mainsail integration: Extruder/Filament colors and other filament attributes from spoolman are displayed in UI. Also there are controls on what color to display:
slicer
,gatemap
(hiding unused filaments),allgates
for the full gate map. Controlled with the newt_macro_color
parameter. Details here 🆒
Other features/updates:
- Can now use LEDs without led_effects being installed. A new
variable_led_animation_enable
has been added to control this behavior and will simply be forced to False if led_effects module isn't installed. It can also be controlled fromMMU_LED ANIMATION=[0|1]
. LED updates have also been made slightly more efficient. Details in this Wiki - Consumption counters now automatically track servo arm movement and filament cutting for automatic maintenance warnings - no need to add macros yourself. Remember
MMU_STATS SHOWCOUNTS=1
to view current counts. - Now incorporates a filament "tightening" move after loading the toolhead if synced extruder is turned off. This is to prevent false clog detection when the slack in the bowden is greater than the clog detection length
- New
variable_user_park_move_macro
can be used to customized the movement to the park position instead of default straight line move (Issue #351). - New printer variables:
printer.mmu.gate_filament_name
andprinter.mmu.spoolman_support
- Fixed issue when the loaded slicer tool map could be reset during print start.
- Several PR's incorporated and bug fixes to address reported Issues.
- Slight changes to stepper synchronization that should help with TTC and stepcompress errors.
- Lots of wiki updates (see links above).
- Tolerance to in Danger Klipper "bleeding edge" added. Comes without warantee!
- Fixed (cosmetic) problem where the load/unload distances in the console animation weren't consistent (Issue #348)
- Added sanity checks to MMU_COLDPULL parameters so it can be called from Mainsail UI (Issue #362)
- Exposed
preload_retries
parameter to extend the time Happy Hare tries to automatically load a spool once the pre-gate sensor has been triggered (Issue #360) - Added
variable_min_toolchange_z
(mmu_macro_vars.cfg) to specify the floor at which any toolchange movement will occur to prevent scraping the bed if no z-hop is specified. - Project against klipper's new habit of setting toolhead position slightly out of range after homing - save position will ensure it is in range.
- Octoprint compatibity option has been removed from mmu_macro_vars .. not necessary to ensure compatibility anymore
- Wiki page on macro customization has been improved.
- Bloblifier macro update that adds "safe decend logic" to ensure toolhead doesn't hit parts of the print.
- Lots of work to avoid TTC errors. Specifically working around what appears to be a klipper bug when lots of homing moves are used. I know this has solved the problem for the 4 users I was working closely with.
- Improved error reporting for connection problems with SpoolMan.
Completely revised parking and movement for toolchange operations:
- This is the big one. After upgrade, you MAY NEED TO REVIEW and TWEAK the MOVEMENT section
mmu_macro_vars.cfg
to finish configuration -- upgrade cannot be completely automated for all setups. - Previously anything other than simple toolchange workflows was very confusing to setup. The configuration had too many "enable_parking" settings, etc. The new system is both much more sophisticated but should be easier to configure to get the behavior you want. Specifically parking can be defined on 7 operations: toolchange, load, unload, runout, complete, pause & cancel, and for each of those you can choose the parking location,z-hop (including optional ramp) and retraction.
- Additionally movements can be specified between certain toolchange steps to make it easy to, for example, park on a silicon pad to stop ozzing while changing.
- End of print eject will no longer return to the print.
- Rewritten wiki page: Toolchange Movement
Teaser:
variable_enable_park_printing : 'toolchange,runout,load,unload,complete,pause,cancel'
variable_enable_park_standalone : 'toolchange,load,unload,pause,cancel'
variable_enable_park_disabled : 'pause,cancel'
variable_min_toolchange_z : 1.0
variable_park_toolchange : -1, -1, 1, 10, 2
variable_park_runout : -1, -1, 2, 10, 2
variable_park_pause : 50, 50, 10, 0, 2
variable_park_cancel : 150, 50, 20, 0, 5
variable_park_complete : 50, 50, 20, 0, 5
variable_pre_unload_position : -1, -1, 0
variable_post_form_tip_position : -1, -1, 0
variable_pre_load_position : -1, -1, 0
Automated calibration / tuning of bowden length and gear ratios:
- Gear "ratios" in
mmu_vars.cfg
have been upgraded to a single list ofrotation_distances
. - Bowden tube length can now be automatically tuned over time by setting the
auto_calibrate_bowden: 1
parameter. This will use telemetry from successful loads and unloads on gate 0 to adjust slowly to find the perfect length. [Caveat: not tested with all sync-feedback devices like Belay so may be better to initially disable] - For designs like the ERCF that use a different BMG drive for each gate, each gear needs to be calibrated. Now the option
auto_calibrate_gates: 1
will use telemetry similar to above to tune the "rotation_distance" for that gear so movement matches the reference gate 0.
Other:
- Further TTC mitigation. Working with various users I narrowed down the cases where this was most likely to happen and worked around them. Logic is near identical but changes timing enough to prevent the error. But note that TTC can be caused by legitimate causes: PSU, heat, bad cables, overload, etc, etc.
- Fixed error in the amount of filament loaded when using tip cutting (Filametrix). The load length was not correctly being reduced by the
toolhead_ooze_reduction
value when cutting tip (thanks to user @jacksky007 for debugging) - Improved error feedback from spoolman moonraker module
- X and Y axis filament cutter support (PR413 - thank you)
- Creality K1 support (PR388 -- thank you)
- Toolerance to skew correct (move out of bounds) in both axes in blobifer macro (PR427 - thank you)
- Various bug fixes from Discord / Issue feedback
- Start of a new wiki page for KlipperScreen-Happy-Hare edition: Klipperscreen
- Wiki pages updated: Slicer Setup, Command Reference, Happy Hare Parameters, Blobbing and Stringing and more..
Addressed design oversight in toolhead calibration settings when cutting tips
- Fixes issue where
toolhead_ooze_reduction
parameter was used for two purposes that cancelled each other out and thus prevented use for fine tuning load distance.- The previous
toolhead_ooze_reduction
value will be moved totoolhead_residual_filament
to better represent what is means -
toolhead_ooze_reduction
will be reset to 0 and used exclusively for tuning the loading length (it's primary purpose) -
MMU_CALBRATE_TOOLHEAD
updated accordingly - Printer variables updated:
printer.mmu.extruder_filament_remaining
now holds the combinedtoolhead_residual_filament
+ any cut fragment length - Wiki updated
- The previous
- New printer variable
printer.mmu.toolchange_purge_volume
which is valid during a toolchange and contains the recommended purge volume (from slicer tool map purge volues + volume of any residual filament left in extruder). Saves time in macros reading the entire purge volumes map - Possible TTC mitigations (doing everything possible to give host more headroom)
- Absolute minimal writes to
[save_variables]
during toolchange or check gates operations - Improved logger
- Absolute minimal writes to
- Allow extruder (entry) sensor to be used to autoload extruder when using the bypass. Controlled with new
bypass_autoload
parameter inmmu_parameters.cfg
- New rainbow effect on startup on entry LEDs
** Blobifier v1.5 update. Pretty cool update by @dendrowen incorporating @igiannakas idea of pulsing purging!**
- Purge with a pulsating (and occasionally, retracting) motion. This will prevent laminar flow from occuring and purge the old filament more quickly. (Up to 30% EXTRA filament saved!)
- Changed the blob calculation mode. The blob will now split into equal parts if it is too large (e.g. 2x85mm instead of 150mm + 20mm). This will eliminate/reduce the small blobs scattering over the buildplate.
- Due to the above changes, certain variables have been added and removed:
- new:
- z_raise: The total amount the nozzle should be raised during a blob. The value should be somewhere around iteration_z_raise * max_iterations_per_blob - triangular(iteration) * iteration_z_change
- z_raise_exp: The rate at which the hotend reduces raising speed during a blob. 0.85 seems to be a good starting value.
- purge_length_maximum: The maximum length of the entire purge. Use max_iterations_per_blob * max_iteration_length.
- removed:
iteration_z_raise, max_iterations_per_blob, iteration_z_change, max_iteration_length
- new:
- Revised some parameter checks to work with the new Happy Hare version 2.7
- Add settings:
- shaker_arm_z to allow for different bed/shaker arm heights.
- brush_accell to be able to change the acceleration of the brush movement.
Major code refactor for modular design
The BIG news - Finally support for Type-B MMU's
-
MMU's now supported by Happy Hare:
- ERCF
- Angry-Beaver
- Box Turtle
- Night Owl
- 3MS
- Tradrack
- Custom
- more comming! (Prusa, Chameleon)
-
MMU Options supported by Happy Hare:
- Toolhead filament cutting
- MMU filament cutting (EREC, Snapping Turtle, ..)
- Blobifier purging system
- Passive or active rewinders
- Sync feedback (Belay, TurtleNeck, ..)
Specific changes:
- New style
mmu_hardware.cfg
to support replicated stepper configuration. Old configurations will be upgraded with new[mmu_machine]
section but this might be a good time to look at the latestmmu.cfg
andmmu_hardware.cfg
templates. - New individual
mmu_gear
sensor option just past the MMU filament driver (e.g. for Box Turtle and Night Owl) - Combined
mmu_gate
andmmu_extruder
(entry) sensors for "no bowden designs" (e.g. Angry Beaver and 3MS) - New per-gate bowden lengths option for specific MMU designs
- New "no bowden" option for certain Type-B designs where the filaments are kept close to the extruder
- Simplifed
mmu_parameters.cfg
for type-B MMU's without selector - KlipperScreen-happy_hare_edition updated with new type-B functionality
Other
- New calculated purge volume option using filament colors that is calculted by Happy Hare rather than relying on slicer to supply purge matrix
- New
MMU_CALC_PURGE_VOLUMES
command to instruct Happy Hare to calculate purge volumes based on color strategy (slicer or gatemap). This is an option to reading from the slicer. - Printer varible
printer.mmu.toolchange_purge_volume
is always available on toolchange with the purge volume based on chosen strategy.
E.g. In this example I have my "gate map" populated with filaments (that were pulled from spoolman). I can now calculate purge volume map...
- New
> MMU_CALC_PURGE_VOLUMES
Purge map updated. Use 'MMU_SLICER_TOOL_MAP PURGE_MAP=1' to view
> MMU_SLICER_TOOL_MAP PURGE_MAP=1
No slicer tool map loaded
Purge Volume Map (mm^3):
To -> T0 T1 T2 T3 T4 T5 T6 T7 T8
T0 - 117 209 174 201 201 203 203 203
T1 287 - 190 141 357 357 296 296 296
T2 348 162 - 171 321 321 178 178 178
T3 293 71 130 - 327 327 240 240 240
T4 121 141 112 150 - - 150 150 150
T5 121 141 112 150 - - 150 150 150
T6 285 204 89 192 320 320 - - -
T7 285 204 89 192 320 320 - - -
T8 285 204 89 192 320 320 - - -
- MMU_UNLOAD / MMU_EJECT distinction: MMU_UNLOAD should be used for unloading filament and parking at the gate. MMU_EJECT will do the same as MMU_UNLOAD if loaded but if unloaded will take the further action of ejecting the filament out of the the gear stepper! careful which one you pick -- KlipperScreen and print end macros have been updated. Note on multi-gear MMUs is it possible to
MMU_EJECT GATE=x
even when another gate is loaded- the "final_ejection" of filament from the MMU is necessary for type-B designs but also use for ERCF/Tradrack users. You just have to change your muscle memory
- Improved "exit" LED status (a "blue" loading/loaded status) for MMU designs without a separate "status" LED.
- Removed
persistence_level
parameter so that state is now always persisted. There are many command available to reset specifc parts of the state so I decided it was better to always persist. But for QoL, two new startup options have been added:-
startup_home_if_unloaded
can be used to force homing of the selector (if MMU is unloaded) on startup if using a type-A MMU. -
startup_reset_ttg_map
used to reset TTG map to the default on restart.
-
- Renamed
auto_calibrate_gates
toautotune_rotation_distance
to better describe what it does (auto upgraded) - Renamed
auto_calibrate_bowden
toautotune_bowden_length
to better describe what it does (auto upgraded) - Added
extruder_homing_buffer
parameter which is the amount to reduce the fast bowden load so filament doesn't overshoot the extruder homing point. Useful if you need/want to home to extruder sensor before loading extruder - New per-filament temperature setting!
- New (persisted) gatemap "filament temperature" attribute
-
MMU_GATE_MAP
command extended with "TEMP=xx" setting per gate - When out of a print, logic to ensure correct temperature will be per-filament, falling back to
extruder_default_temperature
setting if not available - Extruder temperature will be pulled from spoolman if spoolman is enabled
- New "addon" for driving DC eSpooler motor (for example for the Armored Turtle MMU design). Thanks @ammaze!
- Two new parameters in
mmu_parameters.cfg
for calling macro to control the eSpooler:espooler_start_macro
andespooler_stop_macro
- Two new parameters in
- Reworked state recovery (MMU_RECOVER) that will utilize all new sensors if available
- Imporved filament pre-load functionality. Most noticable on type-B MMU's where we can load a gate without selecting it but it can now also allows pre-loading during a pause
- Don't enforce the
min_toolchange_z
if the parking move is-1, -1, 0
i.e. no movement - Improved calibration and intial setup:
- Better selector calibration for designs without CAD defined physical travel limit (e.g. Tradrack)
- Improved bowden calibration methods. Will now use automatically use the best method possible but all methods have been revamped
- New startup calibration state message that reports any lapses of calibration
- Incorporated many PR's. Sorry, I lost count, but thanks to all of you who submitted, not matter how big or small
Production Release for v3
- Support for 3DChameleon added thanks to user @u3dreal !!
- Fixed some bugs introduced during the code refactor
- Dare I say fixed the majority of Timer Too Close (TTC) errors. Really... results are very promising.
Support for Multiple MMU
- It is now possible to combine mutliple MMUs on the same printer and operate them as one. Currently this only works with type-B designs that have a separate stepper per gate/lane but will be extended to support any number and combinations in a future release.
- Updated visualization for status
- New Muli-MMU wiki page
- Updated LED support
- New configuration that allows for complete flexibility of multiple chains, individual leds, partial chains, etc
- New separate
logo
LED control (adds toentry
,exit
andstatus
)
- New
gear_unload_speed
andgear_unload_accel
inmmu_parameters.cfg
to allow for tuning different from load speed - this allows squeezing the best performance out of your MMU but also allows for imposing limits on rewinder speed, etc - New
has_filament_buffer
option inmmu_parameters.cfg
(default to 1). This can be set to0
if no filament buffer is installed (e.g. on designs with DC rewinder systems or users of Filamentalist). This option controls the use and visability inMMU_STATUS
display. - Beta support for awesome new QuattroBox MMU
- Beta support for the tiny PicoMMU with servo selector
- Fixed bug in
MMU_SOAKTEST_LOAD_SEQUENCE
where it may not home when unloading - Ensure extruder syncing is disabled if MMU is disabled with
MMU ENABLE=0
(note it is often better to enable bypass and have a bowden feed that is outside of the MMU if not already integrated like ERCF) - Minor fix for encoder reading accuracy on ERCF
- Integrated several PRs (refer to Github for details)
This project continues to take considerable effort and time not to mention the cost of building many MMU prototypes. Please consider helping to support me by donating to my PayPal link in the github 🙏
(\_/)
( *,*)
(")_(") Happy Hare Ready
Copyright (C) 2022-2025 Paul Morgan
1. Introduction
2. Installation
3. Essential Configuration
4. Calibration
5. Operation
-- YOUR MMU IS READY TO PLAY WITH --
6. Slicer-MMU Setup
-- NOW YOU ARE READY TO PRINT! --
7. Tuning
8. Optional Feature Setup
9. Advanced Configuration
10. Advanced Concepts
- State Persistence
- Statistics and Counters
- Tool and Gate Maps
- Filament Bypass
- Runout/Clog Detection
- Consumption Counters
- Synchronized Gear/Extruder
11. Quick References
12. Troubleshooting
13. FAQ
14. MCU Board Reference 🆕
15. Change Log
Happy Hare Discord