Close
0%
0%

Printer Repair [gd0137]

A log of upgrading / repairing my (non-SecSavr) 3D printers.

Public Chat
Similar projects worth following
One place for upgrading / repairing my (non-SecSavr) 3D printers.

I got 2 DP2 printers for £152 total on AliExpress. I finished upgrades for the first one years ago, but I still haven't done the other one. Then there's the Anycubic Linear Plus with an unfinished enclosure called Hexadecibel, a Tevo Flash in need of new fans and my first printer which is a CR-10 that has been heavily modified. I now call it the CR600S and has been in the middle of an upgrade since probably 2019.

Navigation

The title tag system is explained here, and the table is updated when a change occurs. This project also has a tag for each of the printers. Notable logs have bold L# text.

L1
[X][DP2] Trying the GC6609 Stepper Drivers
L2
[A] DP2 Repair -> Printer Repair
L3
[LP] Recommissioning the Anycubic Linear Plus
L4
[X][DP2] Mystery temp drops
L5
[P2][X]DP2] Part 2: Mystery temp drops
L6
[T][CR600S] Coaxial hotend: Full-colour, 3DPCB and continuous fiber?
L7
[X][CR600S] Grounding an AC bed of a CR-10 (or a 3D printer in general)
L8
[A][CR600S] Connected all wires but AC bed
L9
[A][CR600S] Calibrated limits and BMG clone steps/mm
L10
[A][CR600S] Connected AC bed
L11
[X][CR600S] Tuning Marlin input shaper using an android app

  • [E1][X][CR600S] Tuning Marlin input shaper using an android app

    kelvinA12/21/2024 at 14:28 0 comments

    I created the following gcode for the Y axis, which merely shakes it back and forth at 240mm/s:

    G28 Y
    G0 Y125 Z125 F3600
    G0 F14400
    
    
    G0 Y125 ;line 10
    G0 Y175
    G0 Y125
    G0 Y175
    [continues till line 3010]

    It's similar to X, but it went 125 -> 150 -> 125 to try and amplify the vibrations. This gcode is designed for back-to-back rounds, so do a full homing first before the very first round.

    Running them, with Junction Deviation set to the max value of 0.3mm, I determined that 9000mm/s2 and 3600mm/s2 were acceptable acceleration limits for the X and Y axis respectively. I made sure to do the test of the latter with a 1kg spool ontop to ensure that the printer wont skip steps with a large print:

    There is 1mm-thick, double sided tape holding the spool to the bed. It's the transparent kind that doesn't leave residue.

    Disappointed by the inconclusive results from the Marlin test pattern or vase-mode frequency sweep, I was able to find FFTSensor, a nifty app on the Play store. This takes either accelerometer (or gyroscope) data and puts it through a fast fourier transform to show a smooth-framerate real-time graph that allows me to pick out specific frequencies. 

    In my testing, I found it was best to use the linear scale so that I could zoom in and guestimate where multiple peaks were, not just the absolute highest. I also found it was best to press my phone against the Z-axis extrusion so that the readings weren't dominated by the low frequency swaying of the axis (e.g. 2Hz for the Y axis). 

    The axes are aligned to the phone screen: X is right left, Y is top bottom and Z is out in.

    From the aforementioned attempts to calibrate input shaping, I had zeta factors in excess of 0.5, but the vibrations felt weakest at 0 and just gradually increased the more I increased the value. It also took a while for me to realise I could set the frequency to 0 to disable shaping for that axis; before I found that out, I just threw in some high number like 99Hz.

    Anyway, with the gcode and app, the frequencies were very easy to see and change values to see/hear their effect. A common tactic I employed was to jump between peaks, hear/feel the result and then jump to the new highest peak. For the Y axis, it flip-flopped from 12.9Hz and 20.6Hz, but the latter sounded and felt smoother.

    I also had to sweep through speed multipliers to confirm the real resonant frequency and not one that came about due to the coincidental timing of the swaying motion. For the Y axis, I was getting a 12.9Hz frequency at 100% but it would slowly disappear when reducing the speed multiplier. Meanwhile, the other candidate frequency would sweep in the range 18.9 - 21.0Hz. 77% speed produced the strongest vibrations. 

    The X axis was harder to determine since there were more options, with the most likely candidates being, in order: 44, 54, 35, 28Hz. 

    This recording was taken close to the end of tuning. I guess I was having too much fun that I forgot to screenshot during the test.

    I underwent a process of elimination. I was bouncing around peaks and it didn't sound like 28Hz was going to be it. 54Hz was questionable when I was sweeping through the speed multiplier. The peak that moved between 42 - 45Hz sounded the best and still attenuated the 54 - 57Hz peak. Then the moment I found out about how to entirely disable shaping, the highest frequency shown was 42.6Hz, closely followed by 34.6Hz. I tried both and 42.6 was the better response. 

    A note on Junction Deviation tuning

    My walls out of the corners looked better at Junction Deviation = 0.24, so I believe that the strategy for tuning is:

    • set JD to max, which is 0.3
    • tune max acceleration
    • tune input shaping
    • tune linear advance and E acceleration
      • it was 1200mm/s2 for my BMG clones, which is understandable since it's geared 3 : 1.
    • finally, lower JD (e.g. in steps of 0.06) till the reflections of the walls look straight...
    Read more »

  • [A][CR600S] Connected AC bed

    kelvinA03/23/2024 at 09:27 0 comments

    I ordered some cool wire block terminals because the terminals on the PSU looked too small to be able to fit 2 ferrules into them. Other than having to double up the 20AWG silicone wire for the live bed wire, they were no problems with them. They're quite easy to use; just strip the wire, insert and close the lever.

    It seems that ferrules up to the yellow size is also supported, as can be seen with the AC bed wire in the blue terminal.

    Mechanical relay issues

    I failed to integrate a mechanical relay into the AC bed circuit. The idea was that, in the event of a fault, AC power to the SSR can be cut. This is because I've heard that SSRs can fail in a way that keeps power permanently on.

    It took 40 minutes to get these 3 wires installed.

    The wires I tried to use were fairly thin and my smallest size of ferulles (white) were not small enough so I had to fold over the bare wire and then crimp multiple times. Additionally, these blue terminal blocks are awful as the white ferulles only barely fit and one of the screws had quite a bit of friction. I'd recommend finding a relay with green blocks:

    In any case, the 5V relay, in either the high or low trigger mode, didn't seem to close the connection. I'm not sure if I'm missing anything in the Marlin PSU-on feature settings, but I think the reason is hardware related as the signal pin uses 3V3.

    Thermistor fluctuations

    I cut off the dupont and crimped XH onto the wire that was already there, and all seemed fine other than I was fluctuating between 21 and 23C degrees. I thought it was a poor crimp job so I tried again (and one of the crimps literally came undone just trying to get the wires out of the housing). Second attempt had no thermistor reading whatsoever so the 3rd time I just soldered on a wire with a pre-existing XH termination. Still got the fluctuations, just at a slightly higher frequency. It'll be something like 24->23->22->24->23... at a frequency of 0.2Hz.

    Conclusions

    I should finally be good to finally answer the main question: Does the #Coaxial8or [gd0144] work as intended? All CR600S related systems seem operational now.

  • [A][CR600S] Calibrated limits and BMG clone steps/mm

    kelvinA03/22/2024 at 05:49 0 comments

    With the #Coaxial8or [gd0144] installed, I've gone to the limits (of the printer) to get this information.

    Motion limits

    // The size of the printable area
    #define X_BED_SIZE 308
    #define Y_BED_SIZE X_BED_SIZE
    
    // Travel limits 
    #define X_MIN_POS 0
    #define Y_MIN_POS -9
    #define Z_MIN_POS 0
    #define X_MAX_POS X_BED_SIZE
    #define Y_MAX_POS Y_BED_SIZE
    #define Z_MAX_POS 328

    308 x 308mm is where the nozzle is just inside the edge of the bed for my printer. Due to the bowden tubes for the coaxial8or, I've only gone up to 328mm. It seems that I can comfortably  do something like 305 x 305 x 325mm, which is essentially a 12 inch cube with Z height to spare; I'm satisfied with that. I still get to use the full advertised XY bed size for the CR-10 and I don't think I've ever had a single print even 250mm high, let alone the 400mm that a stock CR-10 supports. Like I've said in this Coaxial8or R1 log, I've tried hard to preseve my XY limits, even going as far as the #Revolving Hotend [gd0012] so that I didn't lose any to XY nozzle offsets. 

    I should mention that I've got a custom Y tensioner installed, which allows an extra 10mm or so, hence the negative Y_MIN_POS. It would likely be decreased to -6 if one was to install the slimmened Coaxial8or R1.

    SanBrother DDE (BMG clone) 

    //#define DEFAULT_AXIS_STEPS_PER_UNIT   { 320, 320, 1600, 1675 }  // 64 microsteps
    //#define DEFAULT_AXIS_STEPS_PER_UNIT   { 80, 80, 400, 418.750 }  // 16 microsteps
    #define DEFAULT_AXIS_STEPS_PER_UNIT     { 80, 80, 400, 209.375 }  // 16 XYZ, 8 E microsteps

     This agrees with my previous go-to value of 418.5mm that I must've calibrated years ago when TriangleLab first came out with their BMG clone and have used it blindly with every BMG clone since. Now I have a more accurate value, obtained by going up to 64 microsteps and no interpolation and getting 99.97mm when expecting 100.00mm. I've then dropped the E to 8 microsteps, mainly because there's eight of them and I don't want to find out that the 180MHz chip on the Octopus Pro can't handle that kind of step rate, but also because of the below graph from this video:

    This is for the TMC2208 (not the 2209/2226 I've got) and the lower microsteps were 1/4 not 1/8, but I'm just kind of assuming that the torque curves between StealthChop and SpreadCycle are more similar at 1/8 than 1/16.

  • [A][CR600S] Connected all wires but AC bed

    kelvinA03/18/2024 at 19:18 0 comments

    Surprisingly, even though the task was simple, it took 3h 20min to actually do the following:

    • Splice, crimp and connect the power cables to the PSU.
      • It's a good thing that I took the advice from Me In The Past and got 16AWG (1.3mm^2) instead of 14AWG (which Me In The Past deduced was overkill and unweildly) as the jumper wires from the main power terminal to the bed power terminal barely fit.
    • Stick electrical tape over the exposed metal tabs at the back of the mains socket for added safety.
    • Open up the TMC2226s, stick on the heatsink
    • Insert all steppers where they need to go. I've done XYZE0E1 as TMC2226 and the rest as TMC2209. I'm missing a heatsink for E7 but since I'm planning to only run these extruders at 300mA, it should be fine.
    • Bundle up and electrical tape the wires for the X carriage.
    • Replace the dupont-terminated Y axis motor cable with a XH like all the other ones.

    I've used the packaging from the DDE (Dual Drive Extruders from SanBrother) as the testbench, which was a good idea as the PCBs have much more grip.

    I haven't yet done the electrical system for the AC heated bed, as right now I've only got one question on my mind: Does the #Coaxial8or [gd0144] actually coaxialate?

    Oh, right. I also had to get an extended Z axis endstop holder printed this morning. You can see it installed in the topmost image.

  • [X][CR600S] Grounding an AC bed of a CR-10 (or a 3D printer in general)

    kelvinA03/17/2024 at 14:26 0 comments

    Some history

    The Coaxial8or has been installed and now it's time for me to get the new electrical system set up so that I can heat up the CHC Pro and unscrew the heatbreak and nozzle that are both currently attached to it.

    If you've been reading those logs, you may remember that my PSU popped a fuse. I didn't know if it was the suspicious PSU itself that's been sitting in the open in a cupboard for years or the shady mains kettle switch socket, so replacements for both have arrived in the mail. I'm partway though the upgrade when writing this intro, and it was the switch socket's fuse that has blown. 

    I decided to finally look into installing safety related features for the bed before I power the printer back on. I don't think I remembered to mention this anywhere, but when I was working on the CR600S and my arm lightly grazed the edge of the spring steel bed, it felt a lot sharper than it should have. I got a multimeter to it and left ground floating, and I was getting as much as 18VAC, down to 4AC when the bed was powered. My current hypothesis is that the (reverse order) stackup of

    • [conductive heating wire] 
    • [silicone insulation]
    • [conductive aluminium bed] 
    • [insulating magnetic sheet]
    • [conductive underside of spring steel plate]

    is acting like a capacitor. 

    Unintentional potential differences like this is why earthing bonding wire is needed for things like plumbing. Me In The Past knew that, for safety, I should earth the AC bed when I installed it, but quickly dismissed the idea because I had neither the tools nor any free tapping locations to screw a bonding wire in. It didn't help that I couldn't (and still can't, hence this log) find any strategies for grounding a CR-10 / Ender3 bed (with or without an AC silicone mat installed).

    Well a few weeks ago, I came to the simple conclusion to just use one of the 4 M4 tramming bolts that are already there.

    Installing the upgrade

    To facilitate this upgrade, I've gotten the following:

    • 4.3mm ring, red (22 - 16AWG) insulated crimp
    • M4 thin brass nut
    • 16AWG yellow silicone wire (1 metre)

    I've also got silicone bed spacers installed.

    Crimping the ring onto the wire

    I feel somewhat proud of myself for splurging an extra 20p on the set of 25 of these instead of 10, because it took 6 attempts to get a crimp that was sufficient:

    First I had looked up the tips for doing a crimp in the first place, such as crimp orientation and splice length.

    I'm using the JX-1301 and I had to strip about 2mm before the minimum helper barrier (approx 5mm from the cutting pincher).

    Then I tried a few times using the crimp rectangled in red, before seeing that the one in green looked like it would compress further in. The first time with the latter (5th attempt overall), I accidentally crimped at an angle but it seemed that there was potential so I tried again:

    This ordeal was also a good grip workout.

    Installing the wire onto the tramming bolt

    Now that I actually had a crimp termination, I could move onto installing it. I tried a few things and decided that the best solution would be to use some cutters to cut out a small (30 degree or so) portion of the top ring section of a silicone spacer:

    It was actually quite satisfying to cut.

    Then I lightly bent the ring termination so that it would screw on the underside of the bed flush, put the ring termination on the bolt and followed it with a thin M4 brass nut, using a 7mm spanner to tighten it. Lastly, I placed the spacer back on and it seems to have all worked as the spacer is in contact with the underside of the bed and my multimeter reads 0.0 Ohms between the bed and the other side of the yellow silicone wire.

    You hopefully can see what I mean when I said I lightly bent the ring crimp so that it sits flush when the nut is tightened on it.

    Lastly, I've thread the wire through the sheath.

  • [T][CR600S] Coaxial hotend: Full-colour, 3DPCB and continuous fiber?

    kelvinA04/22/2023 at 15:30 0 comments
  • [DP2] Part 2: Mystery temp drops

    kelvinA03/18/2023 at 22:27 0 comments

    [18 March 2023] Ok. I'm trying to print Tetent Concept3 and I've encountered the strange behaviour again:

    So it seems that there's actually a zone between 180 and 220 degrees where the readings are not correct. 

    However, it seems that (other than that one mystery hiccup at 115C), the temperature reading is fine if the hotend cools down to 45C.

    Maybe some component is overheating and I should turn the internal fan on? Right now I've got an external fan pointed at the DP2's general direction and I'll see if I can make it though the rest of this 90 minute print.

    [perhaps 3 minutes later] Well that didn't last long at all:

    It seems that cooling down to 140C works too... 

    Maybe the fan wasn't pointed precisely enough. I didn't want the part to warp or anything. I'm trying again with an even more directly pointed fan.

    [23:07] Nouhhh my restarts are now proving ineffective!

    [23:14] Okay alright pack it up guys. This print is a fail.

  • [DP2] Mystery temp drops

    kelvinA12/30/2022 at 16:21 2 comments

    [15:42] As mentioned in a comment here, my DP2 is having a thermal runaway condition where everything is printing just fine and then BAM out of nowhere I tank from 212C to 189C or so. So far, I've taken off the silicone sleeve and, other than the bottom of the nozzle, it's one of the cleanest v6 blocks I've ever seen on a printer (that hasn't recently gotten a new one). The thermistor is the cartridge style and very solidly in there, so it doesn't seem to be the cause of a loose one.

    [15:56] Went into the wiring and all terminal blocks are tight. Hm... could it be software? I'll track the temperature though Repetier to get more insights.

    [16:13] And were live:

    [16:44] Ok... all looking goo-- WOAH WOAH WOAH THERE IT IS!

    Yeah there's ABSOLUTELY no way I'm loosing 20C in like 2 seconds. And then, max power was injected in yet the temp is climbing much slower than it should be (so I turned it off). Something else to note is how high the power% is. Seems like 70% to keep at 212C for some reason, especially since it was hovering at 50% at the start of the print. This could be caused by the hotend being further away.
    I cooled it to 100C and then turned the heater on again... and it's looking to plateau at 180C. As you could see from the first graph, that certainly shouldn't be happening.

    then again, it might just be a difference in scales. The gradients look about the same now.

    Maybe I should try printing at 200C and see if that eliviates the strain on the heater cartridge? Also, that little dip is when I restarted the printer, just incase something was restart related.

    [17:15] I'm currently compiling the latest Marlin 2.1 bugfix to see if that changes anything (if this current 200C test fails)

    [18:02

    Earlier into the print, I was getting large temperature swings:

    They've seemingly died down, and then I got this suspicious spike:
    I wonder what this could be caused by. Maybe the passively cooled internals are messing with the ADC? I have also opened a window so the ambient air is a little colder.

    [19:13] Okay the print finished (and just in time because the part fell off as soon as I lifted the magnetic build plate). I'll try an autotune with the fan at 100% to see if that can resolve anything, and then flash the updated firmware.

  • [LP] Recommissioning the Anycubic Linear Plus

    kelvinA08/13/2022 at 17:29 0 comments

    [18:28] 6 hours ago, I was looking at the Tetent Timespy [gd0136] concept I had modelled the day before and desired to print it. I thought about the printers I had available. The CR600S is completely out of commision and the Tevo Flash needs a fan shroud tweak and a new fan, but I couldn't think of anything hardware related that stopped me from using the Linear Plus. 

    Fixing auto bed calibration

    Powered it on and it homed fine, so I started an Auto Bed Calibration and that's when I found out that the issue was firmware related. The printer wasn't moving to the correct next probe position. So, 5 hours ago, I got started.

    Pulling from common

    So my Marlin Github is set up to have "common" as the main branch that has all the common changes I make to all Marlin printers, and then printer specific branches. Since I didn't want any suprises, I pulled changes from common as-is instead of first pulling from marlin/bugfix-2.0.x. About an hour later after accepting changes, I was ready for the first compile.

    Yeah I thought I could get away with this and marlin would automatically apply the value to the other 2 axes.

    Yeah that make sense.

    Oh yeah... that's right. There was some sanitycheck bug I found when compiling for the DP2. Instead of going into that file, adding a "!" and recompiling, let's take our chances and spin a win on a git pull bugfix2.0.x -> common.

    Pulling from bugfix-2.0.x

    So there's a bunch of new things I have to accept in the config files, and so I finish one and then see this:

    Why is there so many things that failed to merge??? I haven't touched any of these files!

    Thus, I "Accept all incomming" for maybe 20 files at a time, since, for some reason, I couldn't do all at once successfully.

    Yeah... this is probably one of those "caught inside a merge" kind of errors. I don't know what they're actually called, but I imagine that a non-compiling codebase was pushed to the branch. I copy out the 4 files I've modified, hard reset the repository, paste the 4 files back in and... same result. 

    Pulling from bugfix-2.1.x

    Wait. There's a 2.1.x!?

    So after like an hour figuring out how to pull from 2.1.x and not 2.0.x, I go through the config and find out what a TPARA is:

    I accept changes in the config files, then do the same copy-out strategy mentioned above. 

    Success?

    FINALLY WE HAVE GREEN

    Man it's so nice to see that logo, signalling a successful firmware flash.

    The changes from the initial LP firmware is 

    • changing the probe margin from 30mm to 45mm to increase the likeliness of the piezo sensors detecting a signal. The closer the probe point is to the edges, the closer it is to the rigid bed mounts and the less the bed vibrates enough to trigger the piezos.
    • Reducing Z_CLEARANCE_BETWEEN_PROBES from 18mm to 10mm to see if a bug has been fixed since the last time I flashed firmware.

    Solving the delta calibration issue

    First time trying the auto calibration and the Z was moving down at a snail pace.

    This is probably why. Changed that to 120mm/s.

    Then the probing looked pretty gittery so I was thinking it was to do with a low DELAY_BEFORE_PROBING of 70ms. It barely succedded with a standard deviation of 0.49 after 3 iterations. Increased it to 200 and then 500ms and the calibration failed and made it more obvious that the bug I mentioned earlier was still around. For some reason, the printer won't move to the correct location if this value is too low.

    I changed DELAY_BEFORE_PROBING to 100ms and increased Z_CLEARANCE_BETWEEN_PROBES back to 18mm/s. I got a successful calibration and after 4 iterations, the screen spat out a s.d. of 0.35. Now it's been entire years since I've last done a delta calibration, but I feel like the typical standard dev is 0.020, but maybe I'm misremembering 0.200.

    My hypothesis was that 18mm was high enough for a full auto calibration, but not high enough for the linear plus to move to the...

    Read more »

  • [A] DP2 Repair -> Printer Repair

    kelvinA08/13/2022 at 16:31 0 comments

    I'm going to start putting all my printer repair logs into this project, so it has been renamed.

View all 11 project logs

Enjoy this project?

Share

Discussions

Similar Projects

Does this project spark your interest?

Become a member to follow this project and never miss any updates