K40 lasercutter
My Chinese lasercutter which I bought back in 2014 has been upgraded over the years. As many others do, I got the cooling system for the laser tube inside the casing, added some LED lights inside and also added an air pump for the laser head.
All in all the machine works fine now but the relatively small working area remains the bottleneck for using this machine for real interesting projects.
Mid-2020 I used the laser cutter for a couple of projects where I needed series of cut acrylic. The machine handled this flawlessly, but I did put it outside to prevent any smoke from entering our home.
I do have some ideas about upgrading the machine with a larger workspace and put the electronics and water cooling system in a seperate housing. No materials are needed for this, except 3 linear rails and some aluminium profiles. But- (status May-2021) I will start this project only if there is some work to be done with the machine since it is already working fine as it is, although the workspace is limited.
I use Inkscape (freeware) for making designs in SVG and import these .SVG files in K40whisperer (also freeware) which then can send the required Gcode to the K40 lasercutter. This all works very well and fast, you don’t need a fast computer for this. I use a 10 year old dedicated HP laptop for this.
In future use I want to make this lasercutter use the same board as I am using with my big LED laser cutter, so I can use GRBL on both.
As you probably know, a K40 or any other CO2 lasercutter can cut a specific kind of materials while a common LED lasercutter can cut other kind of materials better, due to the used kind of light on both which differ in wavelenghts.
The CO2 cutter can cut acrylic easily and the LED laser cutter can’t.
The LED cutter requires some sort of substance in the to be cut material to work properly.
Be aware that the security goggles you need also are specific for either macine.
Circular clock WS2812 & Arduino nano
LEES DIT ARTIKEL IN HET NEDERLANDS
In the above video you see all required parts for the elctronics. An arduino Nano, a time module LS3231 with battery back-up and a 4-parts ring each with 15 WS2812 LED’s that provide a 160mm 60 LED units clock. You can build it as an open built unit as shown above with wire strings or in a 3d printable slim case that I developed. See the pictures below.
For building this nice precise clock, you can use my design files for the housing on any 3d printer that has a horizontal bed size of at least 165x165mm.
Grab both the print STL’s . HERE. from the Prusa shared site where I uploaded these designs. (If the link breaks, search on the prusa site for ws2812 circular arduino clock).
OR get the STL file for the clock’s FRONT from my website HERE
AND get the STL file for the clock’s REAR from my website HERE
One STL is for the rear and includes the Nano box, the other is for the front face of the clock. Position the rear STL 180 degrees (so up goes down) in your slicer, so both the box and the LED housing are at Z-0 level, i.e. facing down at the same horizontal level. The front can best be printed with the flat side down. ABS is not recommended since it has less stiffness, but will probably also work. For me PETG or PLA works best.
Use white filament for the front part, the rear can be any color you like.
In the circle the 4 WS2812 LED segments are positioned in 1 full circle of about 160mm.
Once you have the rear electronics connected, the front will slide snug over it. No glue required. But the LED ring can best be glued in 4 places with a drop of hotglue to the base of the rear housing. Best to do this after you are sure everything works OK.
The LED parts are available on a.o. banggood , aliexpress and so on, search for 60LED circle WS2812 that has the 160 mm outer diameter.
Each LED represents a dot either for seconds, minutes or as hour indicator.
The colors detemine the function. Blue is also used as Quarter indicator with less intensity, to have a feeling of positioning for the other LEDS when it is dark.
Please look at the video above of the ‘open’ demo model to understand how it works.
Below you can find the Arduino code for the used Nano3, as-is. it works for me, and in the code you will also find all required electrical connections and the used Time module’s spec.
When connected to your PC, you can program the Arduino and via the serial interface you can afterwards change special settings of the clock like brightness, special quarter dimlit indicators, et cetera. it’s all in the code below.
The controls can be sent via a serial interface with the usb input of the Arduino, via a terminalprogram like YAT or with the Arduino IDE program’s interface.
The commands are:
- f; fader OFF
- F; fader ON
- m (number); dim the 4 blue marker LED’s with value (number)
- S; sync to RTC time
- s; sync to System time (computer)
- t (time); change system time to:
- b; brightness of all non-marker LEDs
Please donate $1 to my paypal account if you use (parts of) my developed materials so I can continue to share nice stuff for you to download
Hope you will have a good build!
Cheers,
jan
The Arduino code, to be used for programming the Arduino Nano3 is available at the bottom of this post as plain text to be imported in an empty arduino file (with copy and paste).
Take care to use only the libraries and time module that are specified in the code! The used time module is of the better generation that holds the time very well, also on standby.
When connecting the wires between the neopixel segments, the arduino and the time module, use a temperature-regulated soldering tool. Use a fan when you are soldering and don’t inhale the toxic gases while soldering.
The Arduino code is shown below, to be imported in Arduino in an .ino file. With Arduino, you must compile the code to get the Arduino flashed with the program. If you want to do this easier, you can make use of the binary file I already compiled for both Arduino nano versions (with full memory and with half memory). Both Arduino nano types will be OK to use for this build, but they each require specific firmware.
The last part of this post is the Arduino program for the clock:
/**
* NeoClock
*
* Clock using 60 WS2812B/Neopixel LEDs and DS3231 RTC
* Small changes and updates made by jan Griffioen, Amsterdam Europe 2018-2021
* Libraries needed:
* * Adafruit NeoPixel (Library Manager) – Phil Burgess / Paint Your Dragon for Adafruit Industries – LGPL3
* *
* * Arduino Timezone Library (https://github.com/JChristensen/Timezone) – Jack Christensen – CC-BY-SA
* * Time Library (https://github.com/PaulStoffregen/Time) – Paul Stoffregen, Michael Margolis – LGPL2.1
*/
#include <Adafruit_NeoPixel.h>
#ifdef __AVR__
#include <avr/power.h>
#endif
#if defined(ESP8266)
#include <pgmspace.h>
#else
#include <avr/pgmspace.h>
#endif
/* for software wire use below
#include <SoftwareWire.h> // must be included here so that Arduino library object file references work
#include <RtcDS3231.h>
SoftwareWire myWire(SDA, SCL);
RtcDS3231<SoftwareWire> Rtc(myWire);
for software wire use above */
/* for normal hardware wire use below */
#include <Wire.h> // must be included here so that Arduino library object file references work
#include <RtcDS3231.h>
RtcDS3231<TwoWire> Rtc(Wire);
/* for normal hardware wire use above */
#include <TimeLib.h> //http://www.arduino.cc/playground/Code/Time
#include <Timezone.h> //https://github.com/JChristensen/Timezone
#include <EEPROM.h>
//Central European Time (Frankfurt, Paris)
TimeChangeRule CEST = {“CEST”, Last, Sun, Mar, 2, 120}; //Central European Summer Time
TimeChangeRule CET = {“CET “, Last, Sun, Oct, 3, 60}; //Central European Standard Time
Timezone CE(CEST, CET);
TimeChangeRule *tcr; //pointer to the time change rule, use to get the TZ abbrev
time_t utc;
#define PIN 5
unsigned long lastMillis = millis();
byte dimmer = 0x88;
byte hmark = 0;
byte ohour=0;
byte ominute=0;
byte osecond=0;
boolean fader=true;
Adafruit_NeoPixel strip = Adafruit_NeoPixel(60, PIN, NEO_GRB + NEO_KHZ800);
void setup() {
Serial.begin(57600);
strip.begin();
strip.setBrightness(50);
// Some example procedures showing how to display to the pixels:
// colorWipe(strip.Color(255, 0, 0), 50); // Red
//colorWipe(strip.Color(0, 255, 0), 50); // Green
//colorWipe(strip.Color(0, 0, 255), 50); // Blue
//colorWipe(strip.Color(0, 0, 0, 255), 50); // White RGBW
// Send a theater pixel chase in…
//theaterChase(strip.Color(127, 127, 127), 50); // White
theaterChase(strip.Color(127, 0, 0), 50); // Red
//theaterChase(strip.Color(0, 0, 127), 50); // Blue
//rainbow(20);
rainbowCycle(2);
//theaterChaseRainbow(50);
strip.clear();
strip.show(); // Initialize all pixels to ‘off’
Rtc.Begin();
Rtc.Enable32kHzPin(false);
Rtc.SetSquareWavePin(DS3231SquareWavePin_ModeNone);
if (!Rtc.GetIsRunning())
{
Serial.println(“Rtc was not actively running, starting now”);
Rtc.SetIsRunning(true);
}
if (!Rtc.IsDateTimeValid())
{
// Common Cuases:
// 1) the battery on the device is low or even missing and the power line was disconnected
Serial.println(“Rtc lost confidence in the DateTime!”);
}
byte eechk = EEPROM.read(0);
if(eechk == 0xAA) { //Assume this is our config and not a fresh chip
dimmer = EEPROM.read(1);
hmark = EEPROM.read(2);
fader = EEPROM.read(3);
}
timeSync();
}
void calcTime(void) {
utc = now();
CE.toLocal(utc, &tcr);
ohour = hour(utc);
ominute = minute(utc);
if(osecond != second(utc)) {
osecond = second(utc);
lastMillis = millis();
if(ominute == 0 && osecond == 0) {
//Every hour
timeSync();
}
}
}
void addPixelColor(byte pixel, byte color, byte brightness) {
color *= 8;
uint32_t acolor = brightness;
acolor <<= color;
uint32_t ocolor = strip.getPixelColor(pixel);
ocolor |= acolor;
strip.setPixelColor(pixel, ocolor);
}
void drawClock(byte h, byte m, byte s) {
strip.clear();
addPixelColor(m, 1, dimmer);
if(hmark > 0) {
for(byte i = 0; i<12; i++) {
addPixelColor((5*i), 2, hmark);
}
}
h %= 12;
h *= 5;
h += (m/12);
addPixelColor(h, 2, dimmer);
// 0x RR GG BB
if(fader) {
byte dim_s1 = dimmer;
byte dim_s2 = 0;
byte px_s2 = s+1;
if(px_s2 >= 60) px_s2 = 0;
unsigned long curMillis = millis()-lastMillis;
if(curMillis < 250) {
dim_s2 = 0;
dim_s1 = dimmer;
}else{
dim_s2 = map(curMillis, 250, 1000, 0, dimmer);
dim_s1 = dimmer – map(curMillis, 250, 1000, 0, dimmer);
}
// Add blue low intensity dots for 12(0),3, 6 and 9 O’çlock to verify where the clock is positioned..
addPixelColor(15, 128, 10);
addPixelColor(30, 128, 10);
addPixelColor(45, 128, 10);
addPixelColor(0, 128, 40);
addPixelColor(s, 0, dim_s1);
addPixelColor(px_s2, 0, dim_s2);
}else{
addPixelColor(s, 0, dimmer);
}
// add a background color
// setBrightness(Serial.parseInt());
// uint16_t j;
// for(j=0; j<60; j++) { // 1 cycles of colors on wheel
// strip.setPixelColor(j, Wheel(((j * 256 / strip.numPixels()) + j) & 255));
// }
strip.show();
}
byte rounds = 0;
void loop() {
calcTime();
if(rounds++ > 100) {
Serial.print(ohour);
Serial.print(“:”);
Serial.print(ominute);
Serial.print(“:”);
Serial.print(osecond);
Serial.println(“(C)JG-2020”);
rounds = 0;
}
//rainbow(21);
if (osecond == 59){theaterChase(strip.Color(0, 0, 127), 40); }// Blue; }
//if (ominute == 59 AND osecond == 59){theaterChase(strip.Color(0, 127, 0), 50); }// Green}
//if (ohour == 11 AND ominute == 59 AND osecond == 59){theaterChase(strip.Color(127, 127, 0), 50); }// Green}
else {drawClock(ohour,ominute,osecond);}
delay(10);
chkSer();
}
void timeSync(void) {
RtcDateTime dt = Rtc.GetDateTime();
setTime(dt.Hour(),dt.Minute(),dt.Second(),dt.Day(),dt.Month(),dt.Year());
Serial.print(“Synced to: “);
Serial.print(dt.Year());
Serial.print(“-“);
Serial.print(dt.Month());
Serial.print(“-“);
Serial.print(dt.Day());
Serial.print(“-“);
Serial.print(dt.Hour());
Serial.print(“-“);
Serial.print(dt.Minute());
Serial.print(“-“);
Serial.println(dt.Second());
}
void timeSave(void) {
utc = now();
RtcDateTime store = RtcDateTime(year(utc), month(utc), day(utc), hour(utc), minute(utc), second(utc));
Rtc.SetDateTime(store);
Serial.print(“Synced to: “);
Serial.print(year(utc));
Serial.print(“-“);
Serial.print(month(utc));
Serial.print(“-“);
Serial.print(day(utc));
Serial.print(“-“);
Serial.print(hour(utc));
Serial.print(“-“);
Serial.print(minute(utc));
Serial.print(“-“);
Serial.println(second(utc));
}
void setBrightness(byte brightness) {
dimmer = brightness;
}
void chkSer(void) {
unsigned int iy;
byte im,id,iH,iM,iS;
if(!Serial.available()) return;
switch(Serial.read()) {
case ‘b’:
setBrightness(Serial.parseInt());
Serial.print(F(“Brightness changed to: “));
Serial.println(dimmer);
EEPROM.put(0, 0xAA);
EEPROM.put(1, dimmer);
break;
case ‘t’:
iy = Serial.parseInt();
im = Serial.parseInt();
id = Serial.parseInt();
iH = Serial.parseInt();
iM = Serial.parseInt();
iS = Serial.parseInt();
setTime(iH,iM,iS,id,im,iy);
Serial.println(F(“System time changed”));
break;
case ‘f’:
fader = false;
EEPROM.put(0, 0xAA);
EEPROM.put(3, 0);
Serial.println(F(“Fader off”));
break;
case ‘F’:
fader = true;
EEPROM.put(0, 0xAA);
EEPROM.put(3, 1);
Serial.println(F(“Fader on”));
break;
case ‘m’:
hmark = Serial.parseInt();
EEPROM.put(0, 0xAA);
EEPROM.put(2, hmark);
Serial.println(F(“HMark changed”));
break;
case ‘s’:
timeSync();
Serial.println(F(“Synced RTC to System”));
break;
case ‘S’:
timeSave();
Serial.println(F(“Synced System to RTC”));
break;
default:
Serial.println(‘?’);
}
}
// Fill the dots one after the other with a color
void colorWipe(uint32_t c, uint8_t wait) {
for(uint16_t i=0; i<strip.numPixels(); i++) {
strip.setPixelColor(i, c);
strip.show();
delay(wait);
}
}
void rainbow(uint8_t wait) {
uint16_t i, j;
for(j=0; j<256; j++) {
for(i=0; i<strip.numPixels(); i++) {
strip.setPixelColor(i, Wheel((i+j) & 25));//255
}
strip.show();
delay(wait);
}
}
// Slightly different, this makes the rainbow equally distributed throughout
void rainbowCycle(uint8_t wait) {
uint16_t i, j;
for(j=0; j<256*5; j++) { // 5 cycles of all colors on wheel
for(i=0; i< strip.numPixels(); i++) {
strip.setPixelColor(i, Wheel(((i * 256 / strip.numPixels()) + j) & 255));
}
strip.show();
delay(wait);
}
}
//Theatre-style crawling lights.
void theaterChase(uint32_t c, uint8_t wait) {
for (int j=0; j<4; j++) { //do 4 cycles of chasing
for (int q=0; q < 3; q++) {
for (uint16_t i=0; i < strip.numPixels(); i=i+3) {
strip.setPixelColor(i+q, c); //turn every third pixel on
}
strip.show();
delay(wait);
for (uint16_t i=0; i < strip.numPixels(); i=i+3) {
strip.setPixelColor(i+q, 0); //turn every third pixel off
}
}
}
}
//Theatre-style crawling lights with rainbow effect
void theaterChaseRainbow(uint8_t wait) {
for (int j=0; j < 256; j++) { // cycle all 256 colors in the wheel
for (int q=0; q < 3; q++) {
for (uint16_t i=0; i < strip.numPixels(); i=i+3) {
strip.setPixelColor(i+q, Wheel( (i+j) % 255)); //turn every third pixel on
}
strip.show();
delay(wait);
for (uint16_t i=0; i < strip.numPixels(); i=i+3) {
strip.setPixelColor(i+q, 0); //turn every third pixel off
}
}
}
}
// Input a value 0 to 255 to get a color value.
// The colours are a transition r – g – b – back to r.
uint32_t Wheel(byte WheelPos) {
WheelPos = 255 – WheelPos;
if(WheelPos < 85) {
return strip.Color(255 – WheelPos * 3, 0, WheelPos * 3);
}
if(WheelPos < 170) {
WheelPos -= 85;
return strip.Color(0, WheelPos * 3, 255 – WheelPos * 3);
}
WheelPos -= 170;
return strip.Color(WheelPos * 3, 255 – WheelPos * 3, 0);
}
3d applications – self-folding materials
3D printing became a hot item around 2016, and quite a few 3d printing machines have been sold over the years. But, at some point it seems that the use for products from these machines has faded away.
Due to the availability of 3D printers and the fact that these printers are getting better and are producing prints with better quality as they evolve over time, more applications have been developed.
In this article I will sum up a couple of these new areas in which 3D printing became a driver for new developments, which are sometimes just scratching the surface of possible future developments.
- Dental products. For over 40 years , dentists are using Services from laboratories to produce Ceramic protheses for teeth. The base for this is a mould, taken from the patient. I recall that this was indeed not a very pleasant process for the patient. This process was time consuming and it required also some adjusting and fine-tuning at delivering the protheses at the right place. Currently all dentists are either producing the protheses themselves or use online deliveries that are mostly available with a production- and delivery time of less than 4 hours. the process starts with a 3d-scan from the patient’s mouth, compared with (if available) older pictures and/or X-rays. All is fed into a normal PC, and the software makes the 3d print data. After that, printing the protheses is quite simple with the new ceramic printable filaments. Placing the protheses with UV-herdening glue means that someday we will be able to do this at home. Although the prepping of the place to put the protheses will still be done by a dentist, I presume.
- Technical parts. For many tehnological industries the availability of 3D printers has made it possible to have faster development processes of new parts and applications, You can think of modeling new tools, household objects, cars and -parts, and so on. Since new materials can be printed like aluminium, copper, gold, silver and carbon much is possible. After the developments has produced a complete product, mass-production can start and for this, the 3D design files can be handed over to make the work easy.nn In this way both time and money is saved.
- Art. Maybe not the most obvious development yet, but lately I ran into some artists whom actually used 3D printing in most expressive ways, as art may do. If you check the internet for this, some interstingexamples can be found.
- Medical developments. Since 2017, a new development achieved the ability for 3D printed parts to shrink and expand, based on the printed structure. Read this article about self-folding materials
- Fun printing. Many hobbyists are printing 3D objects just for fun. To add-on applications to their 3D printer, build new ones or print household applications.
VORON 2.4 20″x20″x20″ and DUET2WIFI
Get the documentation, specs, config.g, macros and build docs
After my succesfull buildproject of a Voron 2.4 3d printer in the fall of 2020, I still wanted a really big 3d printer with a print surface of over 20x20x20 inch.
Imagine to have a print of more than double the size compared to the below picture!
During the build and at using the Voron 2.4 printer, I found the documentation on the hardware build really excellent. But, the electronics part was scattered around several places, and although the Klipper implementation is very good I have experienced that the combination of 2 SKR 1.4 turbo motherboards with an Octopi controller does not provide enough operational stability to me. And- I feel the need to control more settings than I can do with the Klipper solution. I think I probably am just more into the Duet and the reprap solution than the Klipper one, due to previous positive Duet – and MKS reprap experiences.
In a couple of previous builds I used a Duet2wifi, and I also experienced the add-ons for Duet2 like driver boards, PT100 boards and more hardware that is also very well implemented in the new RRF3+ firmware.
Reasons enough for me to choose the Duet2 and the 5-ports expansion board , or possibly an additional Duex board for my new to build Voron 2.4 ‘big 3d printer’.
At this page, I will share my progess on this build.
I have all required hardware laying around and since I already built a Voron 2.4, I will first focus on the electronics. For the hardware, I still need the plexiglass sides, top and front doors. I do have all extrusion, bed, bed heater 230V, linear rails, all printed parts and so on, neatly stored at home.
So, I am setting up the electronics to know beforehand that everything works well. I don’t want to start building the hardware and find out afterwards that my Duet2wifi will not do the job I want it to do.
Yesterday (October 4th,2020) I put the electronics and config.g together. I used:
- Duet2wifi board with 24V PSU and 4.3 inch TFT/LCD
- 5-port expansion board with 4 plug-in 2209 drivers V3.0
- Z-switch mechanical
- X-and Y end switches (hall-effect)
- Hotend 24V with NTC connected including tool’s fan (I am missing the PT100’s interface board, have ordered one but I did this before so should be no problemo)
- Hotbed simulated with another hotend including NTC
- Stepper motors connected to X(0),Y(1) and 1 x stepper on the expansion board Z(5) (Driver5)
The Duet2wifi board is a Chinese MKS clone with electronics version 1.02 which works fine. The expansion board is also a Chinese one, but this is a bare-bone implementation of the 5-ports driver add-on board that comes without drivers. the nice thing about this add-on board is that drivers can be plugged in directly.
The Duet2 came with firmware 2.1 installed. To get to FFR3.1, you must first install 3.0 and after this, you can move to 3.1… be aware!
After updating the paneldue and the Duet2wifi board, I activated the wifi and put the ssid and PW in. (This procedure goes via USB between PC and Duet, using a terminal emulator like YAT) This is a bit tiresome but given the security you get from it, I feel it is OK.
The settings that are needed to get the Chinese expension board to work are not too difficult. Add the Z-drives, and change some other settings. On top of this page, you can download the latest doc with all info I have, and a direct download to the adapted config and macros is available in the documentation.
The rest of the build including photos will be here later!
Update 3-2021: I recently built 2 other 3d printers using Duet2wifi boards: a cartesian I3 with independent extruders and a Delta 2GS. Not much time to work on the big Voron. I also just rebuilt my Geetech A30M (330x330x400mm build size) from the smartto board to Duet2wifi, Check ik out on this site!
I will probably not build the big Voron 3d printer after all, and if I don’t, I will rebuild my existing Voron 2.4 300×300 from Klipper, octopi and 2x SKR1.4 to Duet2wifi+Duex. That will be interesting and achievable.
Since I am currently running 10 different 3d printers, my space is getting cramped in the house. I don’t want to expand into another room. One should be enough. Having more printers gives me the best possible fit of a specific filament type per printer.
The Voron is due to its perfect prints with ABS really only used for/with ABS or nylon.
The I3Bear dual carriage works best with dual PLA or PLA&PVA.
The Prusa mini works perfect with PETG
The I3Bear solo goes perfect with PETG or PLA.
The A30M & its mixing extruder goes perfect with PLA and/or PETG
And so on….
Our 3d printers, managed by OCTOPI and Duet Web Controller
Above: Our Dual Bear I3 dual color 3d printer with independant carriages, this one does not run octopi and is remotely managed by Duet Web Control (DWC).
Above: The Voron 2.4, dimensions 300x300x220 mm
And the Twotrees Sapphire pro, our perfect printer for fast production, also on octopi.
And the multicolour completely rebuilt Geeetech A30M dual head printer with a new Duet2Wifi motherboard, dual Chimera heatblock and direct drive extruders. This one runs Duet with DWC instead of Octopi.
Our 3d printers, managed by OCTOPI OR Duet’s web-based app
Above: Our Dual Bear I3 dual color 3d printer with independant carriages, remotely managed by DUET’s webinterface
The Octopi solution works with a Raspberry PI, and on it the Octopi firmware. The device you set up on your wifi and you connect it to your 3d printer’s USB. Then you have a web interface on the Raspberry’s IP address that allows you to manage all the things about your connected printer. All the settings like temperature, mesh, and basically anything else you can manage through a local LCD. And- you can upload your jobs to the raspberry and start/manage and adjust temperature and such. What I really like is that you can connect a raspberry camera and follow your jobs.
The Duet I find in use and possibilities more pleasant. because in addition to everything that the octopi can, you can also modify the system files online. And printer updates can do, directly in the firmware. Moreover, you do not need a separate box because the Duet2wifi already has everything on board.
The disadvantage is that you can’t attach a camera to the Duet. There is a possibility em an IP camera to integrate into the DWC, Duet’s web based remote app. And such a wifi IP camera is easy to make yourself with a cheap esp unit.
Above: The Voron 2.4, dimensions 300x300x220 mm
And the Twotrees Sapphire pro, our perfect printer for fast production
And the multicolour completely rebuilt Geeetech A30M dual head printer with a new Duet2Wifi motherboard, dual Chimera heatblock and direct drive extruders
Magnetic dual parking extruders reprap I3 Bear with Duet2wifi and sensorless homing
My most recent and probably last build from scratch is the dual carriage I3-based printer as shown in the below picture, in the building phase. This printer can be used either for 2 colors or for printing with soluble support PVA filament.
I decided to use sensorless homing for this build due to problems when using endstop switches. When using endstops, problems may come up because f.i. homing to the left means that the left tool will be parked against the endstop, should you use endstops. Same on the right hand side when the right hand tool is parked. I encountered difficulties that the driven sensor carriage in the middle can then get into an unknown state (or position) when both tools (carriages) are in the parked position.
If you home one of both Tools with sensorless homing, the status of the sensor carriage is always automatically known. So, since the XY position of the center (sensor) carriage is known you can always do a Z-homing at any given X-Y position and you can also do G32 and G29 without the need to carry T0 or T1 along. And- you can easlily reset an unknown status of the sensor carriage by homing it, either left or right.
Get my build plans and Configuration files for Duet2wifi HERE
The box at the left rear is for the Duet2wifi board. The 24V fan-regulated power supply is already positioned at the rear, right side.
The main challenge with this build was to get the settings perfect for the dual tools.
It took me 2 months before I got it to work perftectly for both PLA and/or Petg.
As with my previous dual color dual nozzle builds, the basics is very simple. Just define 2 tools with 2 heaters, 2 temp sensors, 2 fans et cetera.
I already envisioned the approch with the slicer(s): All offsets are done ONLY in firmware, NOT in the slicer! As far as the slicer(s) is/are concerned, the nozzles of Tool0 and 1 are at the same (X0/Y0) offset.
For the Duet, the only addition in the slicer is an M0 command as stop command for the printer. Define 2 nozzles of 1.75mm without any offset and you’re done in the slicer.
Then, you will need to set everything in your config.g at the tool section like XYZ offset and so on.
I decided to get T0 as reference, and set everything to 0 there. X=0, Y=0 and Z=0. Then, measure the differences at T1 versus T0 with calipers to start with and inport these values in the T1 toolsection in config.g.
Start a testprint and measure what to amend, take little steps and the metrics are done!
But- the hard part is- as I experienced- to get good prints without blobs and unexpected stringing, both incoming as outgoing (into and out of the printed object(s). Drying the filament also helps a lot!
In the end, I just took the same approach as with the tool settings: As little as possible retraction settings in the slicer and all except the basic print retractions are now in the configuration files that are called upon Tool changes tpre.g, tfree.g and tpost.g (for T0 and T1).
This means that you can play with retracting and extruding of filament length and speed directly at, during and after Tool changes. And- in my experience it is all affected by the type of filament you use and the temperature you are at with the hotend. Also, the fact whether you use a lower temperature during waiting has great impact.
In my experience, you should finetune the config settings for the mentioned settings per object and per type of filament.
Therefore, I decided to used this printer for only 1 goal and make the settings perfect to accomplish this goal. Right now, I have optimized this printer to print 1) PLA from 123print in the Netherlands, of a specific type and 2) PVA from the same supplier. This gives me the possibility to print complex objects with soluble supports and it works extremely well at doing this!
PM: I also added LED lights on top of the printer as an integrated feature. This makes use of a heater pin as GPIO (with a M42 P [pin] S[value intensity]) command), like the solenoids that I use to catch the carriages T0 and T1. To come from the 3.3V and max 1mA from the GPIO pin to the required 24Volts, I used small mosfet boards. All programming is done in the Duet’s config and macro files, view the below example of my stop.g file which is called from the slicer’s stop setting: M0.
; stop.g
; called when M0 (Stop) is run (e.g. when a print from SD card is cancelled)
; Also called by slicer end gcode by M0
;
M400 ; Finish move queue
M117 Cool down ; Update the LCD screen with “Cool down”
M83 ; Extruder relative mode
G1 E-2 ; Retract filament 2mm for both extruders !!
M106 S255 ; Fan at 100 to cool nozzle and bed
M104 S0 T0 ; Extruder T0 heater off
M104 S0 T1 ; Extruder T1 heater off
M140 S0 ; Bed heater off
G28 X ; Home X
M220 S100 ; Set speed factor back to 100% in case it was changed
M221 S100 ; Set extrusion factor back to 100% in case it was changed
M42 P4 S0 ; Magnet T0 off
M42 P5 S0 ; Magnet T1 off
M104 S41 T0 ; set extruder T0 to cool down
M104 S41 T1 ; set extruder T1 to cool down
;M568 R41:41 S41:41 ; set standby and active temperatures for tools 0 and 1 (or single M568 T0 R41 S41)
M116 ; wait for Tools actions as specified in above M568 instructions
G90 ; Absolute positioning
G1 Y200 ; to get objects removed easier, move bed forward
M106 P0 S0 ; Fan L object T0 off
M106 P2 S0 ; Fan R object T1 off
G28 X ; Home X
M84 ; Steppers off
M98 P/sys/ledflash.g; Perform execution of ledflash.g in specified directory
M42 P6 S0.008 ; Led light setting almost OFF
M117 Jantec=done! ; Update the LCD screen with “Jantec=done!”
G1 X5 Y5 ; Move to corner
M140 S{print_bed_temperature} ; Set bed temp
T1 ; Select extruder 1 (or 0 depending on how your printer is set up)
M104 S{print_temperature} ; Set extruder temp
M116; Wait for temperatures
Please donate $1 to my paypal account if you use (parts of) my developed materials so I can continue to share nice stuff for you to download
Mellow FLY-CDY-V2 motherboard
recently (3-2021) I have been setting up my new 3d printerboard from Mellow, an STM32 board that is named FLY CDY V2. It is (almost) fully compatible with Duet2Wifi and also uses its wifi-based 3d printer management system DWC.
The config file I made for this setup is HERE
The FLY_CDY_V2 board comes completely empty so I added the firmware.bin in the /sys directory, after I had an empty SD card filled with the clean reprap directories and -files.
Next to the firmware.bin. also a board.txt is required to be available in /sys with some settings, with the following content:
//Config for fly-CDY
board = fly_cdyv2
led.neopixelPin = D.15;
//wifi pins
8266wifi.espDataReadyPin = E.10;
8266wifi.TfrReadyPin = E.12;
8266wifi.espResetPin = E.11;
8266wifi.serialRxTxPins = { D.9, D.8 };
heat.tempSensePins = { B.1 , A.3 , C.4 , D.14}; be aware that D.14 is not a temp pin but a heat pin, is this wrong??
stepper.numSmartDrivers = 6;
serial.aux.rxTxPins = {A.10, A.9};
This board.txt is already OK for 2209 drivers and for the use of the neopixels output.
In the pdf that is provided by Mellow on the Github page for the reprap STM32 boards, section FLY-CDYV2, everything is explained as to get wifi up and running, configure config.g et cetera.
In my config.g everything needed to work properly is already done, as is with my board.txt.
I made the config for a.o. a Cartesian printer with single X,Y,Z steppers and a triple hotend with 3 extruders, 1 heater and 3 nozzles.
Included is: Neopixels, BLTouch, 3 filament sensors on the X,Y- and Zmax inputs, active fans for hotend tool on fan1 and object on fan0
If so desired, sensorless homing is possible with the correct driver boards. In this version, 3 optical endstops have been used on inputs xmin, ymin and zmin.
Retraction is set OFF in this firmware by default, but may be swiched ON to make the triple hotend drip less (2 mm retract and -0.5 extrude without Z-hop), do experiment with these settings!
Please be aware that some pin names for the FLYCDYV2 board differ from the Duet’s naming convention like “bed” versus “bed-heater” et cetera.
Plus, some typical Duet2wifi extensions are NOT available like the GPIO bus.
The FLYCDYV2 has some interesting standard extra’s though, like the BLTouch connector with power, driver pins and Z probe pins, the Neopixel connector AND the 6 driver slots and 3 extruder heaters/sensors/fans!
It is quite simple to change this setup to a dual Z axis with independant Z-motors and either single extruder or a dual setup, single or dual nozzle, mixing or non-mixing.
Please see my complete ready-to-go config directory setups for this board HERE to get you started!
Also: Check my CNC Indymill running with the FLY-CDY-V2
Please donate $1 to my paypal account if you use (parts of) my developed materials so I can continue to share nice stuff for you to download
Dual magnetic parking extruders I3 Bear Duet2wifi build and Config files
My dual carriage I3-bear based 3d printer is working very well.
On this page I share my latest configuration files, my build experiences like the used STL’s , schematics and so on.
Hope you enjoy!
Be aware that the tool settings in config.g are set including relative X, Y, Z values for this build so DO NOT put this in your slicer!
And- you need at least RRF3.3.1 for reprap FW and for DWC.
The sensorless homimg also requires knowledge of config settings and the good news is that the Duet2wifi has this all managed by the reprap firmware. No switches needed or complex jumper settings!
Tip for printing the parts: I used ABS for all parts. Use at least a printer with calibrated XYZ values for your specific filament.
Do a testcube first and apply any needed adjusting to your slicer’s settings like pre-shrinking settings of the endresult and so on.
If you don’t do this, then don’t start this build.
It is a prerequisite to get the magnetic carriage to deliver-and get the carriages from left and right of the X-axis.
Therefore the movement needs to be free of unneccessary friction.
And– if you use sensorless homing any additional friction on any sensorless homed axis might lead to unintended stalls.
I added a dripstop to the left and right hand sided X-carriages, made of some thin tinned plate.
It is positioned so, that a little tension is put on the nozzle tip in the parking position. It really works very well!
The config.g for this build and the Duet2wifi is HERE
The Sys directory for the dual carriage build and Duet2wifi is HERE
The Macros directory for the dual carriage build and Duet2wifi is HERE
The build plan for the 2040 extrusion frame is HERE
The STL files for the X-axis carriages and carriages are HERE
All other needed STL files for the printer are HERE
The Duet’s case and 4.3 inch Paneldue’s case are HERE
The page of the working printer is HERE
The build plans for the electronics and Duet2wifi wiring schemes are HERE
Please donate $1 to my paypal account if you use (parts of) my developed materials so I can continue to share nice stuff for you to download