Skip to content

Post processing script for Slic3r PE to remove fine threads from filament tips during MMU2 tool changes.

License

Notifications You must be signed in to change notification settings

jmarsik/skinnydip

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SKINNYDIP MMU2 string eliminator v1.0.2 beta

a post processing script for Slic3r PE to remove fine threads from filament tips during MMU2 toolchanges. Written by Erik Bjorgan based on a core concept from David Shealey. With love to the Prusa Community Forum and its incredible admin team. http://facebook.com/groups/prusacommunity

While this tool is becoming more and more stable, it is still experimental. Use it at your own risk!

Tested with the following versions of Slic3r PE:

  • 1.41.2+linux64
  • 1.42.0-alpha7+linux64
  • 1.42.0-alpha7+win64
  • 1.42.0-beta1+linux64

While it is possible that it may work with other versions of Slic3r, please do not assume this to be the case, as any changes to the gcode structure expected by this script could lead to gcode that has unintended effects, some of which may be dangerous. If you choose to use this, I salute you!

Purpose:

This script is used to eliminate the stubborn threads of filament that can jam the MMU2 during toolchanges by providing a brief secondary dip into the melt zone immediately after the cooling moves complete.

Installation:

Dependencies

This script requires Python 2.7. Linux users won't need to install anything. Windows users can download v2.7.16 at https://www.python.org/downloads/

Windows

Copy skinnydip.py to any folder eg C:\my\folder\skinnydip.py Unless python is in your system path you may need to find its location as well eg C:\python27\python.exe

In Slic3rPE > Print Settings > Output Options > Post Processing Scripts, use the following:

C:\python27\python.exe C:\my\folder\skinnydip.py

New: Batch file for Windows users (recommended)

Some Windows users were reporting that parameters weren't being picked up correctly when filenames contained spaces. This was determined to be due to an issue with Slic3r PE. The included batch file (skinnydip.bat) should be saved in the same directory as skinnydip.py. It attempts to locate your python installation automatically. To call skinnydip with the windows batch file, in Slic3rPE > Print Settings > Output Options > Post Processing Scripts, use the following:

\path\to\skinnydip.bat

This batch file also includes a pause at the end so that you can see the output of the post-processor before windows closes the command line window. You will need to press any key for this window to close in order to resume using Slic3r.

Linux / Mac

In Slic3r PE, provide the absolute path to the skinnydip.py script in Print Settings > Output Options > Post-processing scripts.
eg. /home/username/some_folder/skinnydip.py

Known issue with installation on Linux appimage builds

At the time of this initial release some Linux appimage builds of Slic3r PE are misconfigured in a way that prevents running Python scripts directly. Use /home/username/skinnydip_appimage_workaround.sh in the post processing script field instead. This script should be located in the same folder as skinnydip.py

Permissions:

If you have issues with skinnydip.py or the workaround script running, you may need to update their permissions to mark them as executable. This can be done through the right-click menu or through the command line, ie:

chmod +x skinnydip.py

Usage:

The script is configurable via comments made in the filament profile's start gcode section Every filament used for this script needs to have the following lines appear at the top of its filament start gcode.

M900 K{if printer_notes=~/.*PRINTER_HAS_BOWDEN.*/}200{else}30{endif}; Filament gcode
; SKINNYDIP CONFIGURATION START
; material_type PLA
; material_name my PLA Spool
; insertion_speed 2000 
; extraction_speed 4000
; insertion_pause 0 
; insertion_distance 41 
; removal_pause 0
; toolchange_temp off
; beep_on_dip off
; beep_on_temp off
; SKINNYDIP CONFIGURATION END

The most important parameter to configure correctly is "insertion_distance". This distance is the depth that the filament is plunged back into the melt zone after the cooling moves complete. The goal is to melt just the stringy part of the filament tip, not to remelt the entire tip, which would undo the shaping done by the cooling moves.

If this number is too high, filament will be rammed out of the hotend onto the wipe tower, leaving blobs. If it is too low, your tips will still have strings on them.

How will I know the post processing script is configured correctly?

A successfully processed gcode file will have a header similar to the one below added to the beginning of the file. Check this by opening the gcode file with a text editor. If this header is not present, this means that your file has not been processed by the skinnydip script. This is usually due to a problem with the way you've instructed Slic3r to run the script, but can also happen if Python 2.7 is not available on your system.

; SKINNYDIP THREAD REDUCTION v1.0 beta
; https://github.com/domesticatedviking/skinnydip
; Postprocessing completed on Mon Mar 11 22:05:23 2019
;               File Processed:/path/to/file.gcode
; Note that editing the values below will have no effect on your
; Skinnydip settings.  To change parameters you must reslice.

;         Configured extruders: ['T0', 'T1', 'T2', 'T3', 'T4']
;             Toolchange temps: [230, 231, 232, 233, 234]
;            Insertion lengths: [50, 31, 31, 31, 31]
;      Auto insertion distance: 33.5
;       Total # of toolchanges: 83
;                   Dips added: 80
;       Toolchange temps added: 199
;   Tools beeping on skinnydip: None
; Tools beeping on temp change: None

Explanation of configuration parameters:

Parameter Explanation Default Value
material_type Name of type of material n/a
material_name User defined name for this filament n/a
insertion_speed Speed at which the filament enters the melt zone after cooling moves are finished. 2000 (mm/min)
extraction_speed Speed at which the filament leaves the melt zone. Faster is generally better 4000 (mm/min)
insertion_pause Time to pause in the melt zone before extracting the filament. 0 (milliseconds)
insertion_distance Distance in mm for filament to be inserted into the melt zone. This setting is hardware and assembly specific, so it must be determined experimentally. For stock extruders, use 40-42mm. For bondtech BMG extruders, use 30-32mm. If blobs appear on the wipe tower or stringing starts getting worse rather than better, this value should be reduced. n/a
removal_pause Number of milliseconds to pause in the cooling zone prior to extracting filament from hotend. This pause can be helpful to allow the filament to cool prior to being handled by the bondtech gears. 0 (milliseconds)
toolchange_temp Temperature to extract filament from the hotend. Cooler temperatures are associated with better tips. off
beep_on_dip Play a tone through the printer's speaker to signal when a skinnydip move is taking place (for debug purposes) off (off/on)
beep_on_temp Play a tone when a toolchange temperature setting has been applied (for debug purposes) off (off/on)

Goals:

This method is highly effective for removing fine strings of filament. This script is intended as a proof of concept, with the hopes that this functionality would be added to a future revision of Slic3r PE.

About

Post processing script for Slic3r PE to remove fine threads from filament tips during MMU2 tool changes.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 98.8%
  • Other 1.2%