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!
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.
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/
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
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.
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
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
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
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.
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
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) |
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.