I think this thread might be the right location for this I guess because it's something I would need
Since I upgraded my Prusa MK3s to a Duet 2 WiFi board I try to enable all the features the Prusa original FW had.
This means:
- automatic loading of filament when there is no filament in the extruder
- PINDA temperature compensation table because the probe Z offset differs depending on the temperature. In my experience this is not linear and the higher the temperature the lower Z = 0 becomes meaning if you calibrate your printer with PLA, ABS will need recalibration as the nozzle will be too low.
My target is to create a config package for others so they can 1:1 swap their board and don't need to tweak much as my config uses all the convenient features, like the filament sensor, with explanation of what needs to change in the config depending of the used extruder or stepper motors (e.g. 0.9/1.8 degree).
1.
Feature to load the filament automatically.
Status: no filament in the extruder, extruder has PLA temperature (210°C)
Behaviour: Putting filament in the extruder triggers the filament sensor which then automatically loads filament.
Problem I had: The firmware only allows me to operate the filament sensor in one direction because the pin is blocked/reserved. Meaning I could only enable auto load or run out detection at once. So I had to split it in two over macros and start gcode.
So here is my (over complicated?) solution right now:
config.g
; Filament Sensor Port and Loading Feature ON
M950 J1 C"e0stop" ; Input 1 e0 Filament Sensor
M581 P1 T2 S0 R0 ; Filament Sensor P1 triggers Trigger2.g always (R0)
Runout is not working right now. So when the printer is starting up and there is no filament and filament is put into the extruder trigger2.g is called:
trigger2.g:
; Loading Filament Script
M300 S800 P200
M581 P1 T2 S-1 R0 ; Filament Sensor does not listen anymore (S-1). Autoload is disabled.
M291 P"Please wait while the nozzle is being heated up" R"Loading PLA" T5 ; Display message
T0 ; Activate Hotend
M291 P"Feeding filament Trigger2" R"Loading PLA" T5 ; Display new message
G1 E70 F800 ; Feed 70mm of filament at 800mm/min
G1 E55 F300 ; Feed 50mm of filament at 300mm/min
G4 P1000 ; Wait one second
G1 E-5 F800 ; Retract 3mm of filament at 800mm/min
M400 ; Wait for moves to complete
M292 ; Hide the message
G10 S150 ; Set current tool temperature to 150C
;G10 S0 ; Turn off the heater again
; Filament Sensor Port and Runout Feature ON
M581 P1 T2 S-1 R0 ; Filaent Sensor does not listen anymore (S-1). Autoload is disabled.
M950 J1 C"nil" ; Input 1 e0 Filament Sensor
M591 D0 P2 C"e0stop" S1 ; Filament Runout Sensor
After the loading script the sensor is put into mode "runout detection ON"
But what if you turn your printer on and filament is already loaded and you directly start your print? This would mean that there is no runout detection enabled.
My solution right now is putting this into the Start GCODE in the slicer software:
; Prime Filament Sensor for Runout
M581 P1 T2 S-1 R0 ; Filament Sensor P1 triggers Trigger2.g always (R0) TRIGGER OFF
M950 J1 C"nil" ; Input 1 e0 Filament Sensor
M591 D0 P2 C"e0stop" S1 ; Filament Runout Sensor
And there is a third scenario. What if you want to manually change your your color (filament) mid print?
After unloading the filament the sensor needs to be in mode "autoload" and after the autoloading is complete it has to go back to the mode "runout detection".
So i added this to my filament-change.g macro:
M25
G91 ; Relative Positioning
G1 Z20 F360; Raise Z
G90 ; Absolute Values
G1 X200 Y0 F6000 ; Parking Position
M300 S800 P8000 ; play beep sound
M98 Pejectfilament.g
M400
Called Pejectfilament.g:
M591 D0 P0 C"e0stop" S1 ; Filament Runout Sensor
M950 J1 C"nil"
M291 P"Please wait while the nozzle is being heated up" R"Unloading PLA" T5 ; Display message
T0 ; Activate Hotend
M109 S210
M291 P"Retracting filament..." R"Unloading PLA" T5 ; Display another message
G1 E+8 F300 ; Extrude 8mm of filament at 300mm/min
G1 E-45 F800 ; Retract 480mm of filament at 800mm/min
G1 E-15 F900 ; Retract 480mm of filament at 900mm/min
G1 E-25 F900 ; Retract 480mm of filament at 900mm/min
M400 ; Wait for the moves to finish
M292 ; Hide the message again
M300 S800 P200
; Filament Sensor gets ready for next load
M950 J1 C"e0stop" ; Input 1 e0 Filament Sensor
M581 P1 T3 S0 R0 ; Filament Sensor P1 triggers Trigger3.g
At the end trigger3.g:
M300 S800 P200
M581 P1 T2 S-1 R0 ; Filaent Sensor does not listen anymore (S-1). Autoload is disabled.
M291 P"Please wait while the nozzle is being heated up" R"Loading PLA" T5 ; Display message
T0 ; Activate Hotend
M291 P"Feeding filament Trigger3" R"Loading PLA" T5 ; Display new message
G1 E70 F800 ; Feed 70mm of filament at 800mm/min
G1 E55 F300 ; Feed 50mm of filament at 300mm/min
G4 P1000 ; Wait one second
G1 E-1 F800 ; Retract 1mm of filament at 800mm/min
M400 ; Wait for moves to complete
M292 ; Hide the message
; Filament Sensor Port and Runout Feature ON
M581 P1 T2 S-1 R0 ; Filaent Sensor does not listen anymore (S-1). Autoload is disabled.
M950 J1 C"nil" ; Input 1 e0 Filament Sensor
M591 D0 P2 C"e0stop" S1 ; Filament Runout Sensor
I know it first seems quite complex but when runout is enabled the port is blocked and can't be used for autoload.
Now I've read about the implementation of if / else statement which could make things quite simpler and also lowers the change of error as there would be no need to put code into the start gcode.
Like so (be aware, I'm no coder! )
Filament Sensor Status = 1 means no filament
func autoload {
M581 P1 T2 S-1 R0 ; Filament Sensor does not listen anymore (S-1). Autoload is disabled.
M950 J1 C"nil" ; Input 1 e0 Filament Sensor
M591 D0 P2 C"e0stop" S1 ; Filament Runout Sensor
}
func runout_detection {
M581 P1 T2 S-1 R0 ; Filament Sensor P1 triggers Trigger2.g always (R0) TRIGGER OFF
M950 J1 C"nil" ; Input 1 e0 Filament Sensor
M591 D0 P2 C"e0stop" S1 ; Filament Runout Sensor
}
if Filament_Sensor state changed to "1" {
autoload
} else {
runout_detection
}
Something like that
2. PINDA Temperature calibration
The PINDA (v2) has an built in thermistor to use the Prusa FWs temperature compensation table.
RRP FW has has similar feature built in into the G31 command:
G31 P1000 X23 Y5 Z0.995 C0.0010 S20 H2
I've measured the Z trigger height with several temperatures from 20°C, 25°C up to 50°C and saw that the variance was not linear. At first the offset got bigger meaning the nozzle would be too close to the bed and after 40°C the difference were much smaller up to 50°C.
I'm not quite sure how the Prusa FW stores and uses the recorded values when the FW does it's auto temperature PINDA calibration but what would work is if you could use different G31 code lines depending of the temperature of the PINDA thermistor.
My "I'm no coder" mind thinks of the following:
if PINDA_Thermistor <25°C {
G31 P1000 X23 Y5 Z0.995
}
else if PINDA_Thermistor >=25° AND PINDA_Thermistor <30° {
G31 P1000 X23 Y5 Z1.005
}
else if PINDA_Thermistor >=30°C AND PINDA_Thermistor <35° {
G31 P1000 X23 Y5 Z1.020
}
.
. and so on...
else {
G31 P1000 X23 Y5 Z2.0 ; safety height
}
Hope it is clear what I mean