Skip to content

Rest times and TSMC

Tiago Conceição edited this page Aug 27, 2021 · 44 revisions

This guide is a walkthrough in new features of Rest times and TSMC.
What are they for? Should i use it? Which values? Are you ruining your life? Probably...

Wait/Rest times

The new rest time settings introduced on Chitubox v1.9.0 are very important and the most useful new feature, let's find out why:

The problem:

When the build plate lifts and then retracts into the VAT, the cured object and/or plate will produce shock waves on contact with the resin, making the particles to move around, similar to when you throw a rock into the water and you get the shock wave effect. Curing moving resin is bad and can lead to crack, failure, weak bound, bad quality, visual artifacts, and maybe others… So, it's very important to wait some time to stabilize the resin flow before cure a new layer in.
Rest times come in handy to wait some time before cure a layer object, solving this problem.

The wrong solution:

Before new rest time settings, Chitubox always had (still have) the light-off delay, that field is always a confusion and a trouble/hard to set, as it's not a raw value it requires manual calculations or a calculator to properly set. Light-off delay = time to lift + time to retract + the desired wait time. With math, the value is calculated as:

Light-off delay = lift height / (lift speed / 60) + retract height / (retract speed / 60) + Desired wait seconds.

This means, if you change any of the parameters used in the formula, you need to recalculate the light-off delay to the correct value. This is very impractical and I will never understand why they put this ***** to the end user when firmware can do it alone… And of course, almost all users are setting this wrong with no desired effect.
Also note that any value lower than the base formula will have no effect as firmware will cap this value to a minimum. So, let's say that the movements take about 5s to finish, any value you put lower or equal than 5 will have no effect! But if you put 6 it will wait about 1s after the movement finish. But if you change lift speed to a slower value then 6 will not result in 1s anymore! What a mess…
To take this worse, notice that formula is not taking acceleration into account, so it's calculating instant speed which in real word that never happen and the movement always require an acceleration time before reach the maximum set speed, so you always need to give a bit of margin to know for sure the wait time is at least near to what you want, for example +0.75s to 1s is a good margin to have in fast acceleration settings.
Now you see, you have the perfect receipt to make it wrong all the time if you go with this trashy light-off delay… UVtools by default set light-off accordingly + 3s if you open a file there and while you have automations on and light-off comes not set (0) on the file. Still, this automation happens only once, and if you change lift height or any other parameter via UVtools it will not recalculate the value.

The good solution:

With the introduction of the new firmware and CTBv4 is now possible to use an alternative to the light-off delay, that is the rest times. Rest times now do exactly what you need, you choose a time to wait before a action and that time is the real time without any other considerations. So, if you want to wait 3s before cure, you just need to set it to 3, and no other parameters matter in the equation. This approach should be here from beginning instead of light-off, again I will never understand why, even if they come with a good reason…
Unfortunately, not all printers will have the firmware upgrade to be able to use these new parameters, but if yours do, I highly recommend to upgrade just to use this feature!
Before, light-off delay allows you to control only one wait time, that is, the wait time before cure, but now you may notice there are two more stages available to wait, let's take a look at them by order of event:

  1. Rest time before lift: Time to wait before a lift, this is also known as the wait time after cure the layer, because lifts are made between curing and a new layer. This parameter is important, it can help in a better layer separation from FEP, remember that when you cure a layer/resin, it will heat up with the UV reaction, and hot layers can attach harder to FEP. So, allowing some time to the layer cooldown can be a good thing to help detaching and prevent failure, more useful on bottom layers where you have larger cure times, but by stupidity Chitubox don't provide a bottom setting for rest times, but if you have Chitubox Pro you can set those bottoms with different time at a great expense of a tedious workflow by playing with multi-parameter slicing. Save yourself some time and money and use UVtools to do that via Tools -> Edit print parameters.
    Bottom line: Set higher wait time for bottoms and less for normal layers. The more exposure time the more you can increase this delay. (Exposure time / 3s) is a good start point. Bottoms: 5s / Normal: 1s to 2s.

  2. Rest time after lift: Time to wait after a lift is done and before retract happens, this will wait your desired time when build platform finish the lift movement and before retract back. I really can't find any good reason to use this other than waste time, but you are free to point me some useful cases. You may think: Oh, this will let resin to settle! Sure, it will, but when retract back it will introduce the same problem, so don't worth to wait any time in this stage. What about let resin dip back into VAT? Again, I see no point here. But the funny thing are some people using this field to set the larger wait time of all the others, so the most useless field is getting more attention, I can't understand why... My advice is to never use this and spare yourself some time, set this field to 0s!

  3. Rest time after retract: Time to wait after the retract is completed and plate is on the layer cure Z position, this is also known as the wait time before cure the layer. Before cure a layer this field will wait your desired time, and this field is what you should use the most! This solves the "The problem" described on top of this article and it's the direct replacement of the light-off delay. My advice is to set to 3s, but this value depends on some variables, for example, how big is the area, will the plate submerge into the VAT? Volume of the object that gets into the VAT at this stage, resin viscosity and density. So, in a perfect tunning we would need some kind of an analysis to combine all these variables and tune the wait time per layer, to optimize the process without sacrifice time. As that not exists yet, as general rule, 2s-3s is a good start point, you just need to increase on more viscous resins, but you can also observe the resin flow in VAT and from there pick the best time for your process, remember that you always want the resin to settle before cure the layer!

Bottom line:

These new rest times come to solve two problems and I highly advice to use them if compatible with your printer and firmware, but they have a counterpart, they will sum up time to your print. So, lets assume my print have 1000 layers. I set rest time before lift to 1s and rest time after retract to 2s (these are already minimums), 1000 * 3 = 3000s extra seconds / 50 extra minutes! If you don't have trouble with FEP peel you can remove the 1s before lift and spare 1000s and reduce the total delay to 33.3 minutes. Now you see, the more layers and wait times you have the print time will escalate, so it's very important to not waste time on stupid stages and optimize the ones that really benefit from it, also don't set less nor more than required! But everything has a tradeoff, right? Is up to you if you want print fast or have the best quality and peace of mind, sometimes slower is better ;)

TSMC

Two stage motor control (TSMC) adds an additional lift/retract to the printing sequence, so instead of one lift&retract you can have a kind of slow lift to safe peel the layer from the FEP, a fast lift to go a little bit higher, a fast retract back and then a slow retract to the next layer position to be safer. In other words, the sequence is as follow: lift1 @ slow speed -> extra lift @ fast speed -> retract 1 @ fast speed -> retract 2 @ slow speed.

The problem

The TSMC solution come to “solve” a “problem” where some printers with fast acceleration does the lifts too fast and then the layer detach from plate or have some deformation, as well as others problems that may come from this. So, this will allow you to do a safe and slow peel, go a bit higher faster, go down fast and finally the last few millimeters do it slow to be safe in case it hit the LCD due a damaged object.

The wrong solution

(Spoiler alert) For the belovers of trends, TSMC and/or VROOM stop here, wipe your hard-drive and lock yourself in a cave to be safe as a promise that you will never see this post again! You have been warned!

Well, the TSMC itself is the wrong solution! Useless, dumb, stupid, non-sense and time waster! Really don’t use it, and kill it immediately with fire! Here’s why:

  1. Wastes a ton of additional time.
  2. After the layer peels (detach from FEP) you don’t need any additional lift. Serious! If your layer detaches at 1mm for example, why you want go like 2+5mm? This is just stupid and wasting your printer precious time. We always give a margin to be sure, but like instead of 7mm go 3mm or 4mm, but having an additional lift for that is just non-sense.
  3. The movement implementation is bad (they are too lazy to do better), because the first lift will start, accelerates to the target height/speed and then deaccelerates to finish that lift at 0mm/min, head stops, then repeat the process for the next lift, and repeat for the next two retracts. The problem here is that each lift/retract is single movement, they are stopping the head in each movement when this should be a whole/one smooth movement without any stop in between, this will just waste time and make the TSMC even more stupid and useless than never. Don’t get it yet? Well, I have made an illustration that worth a million words: (Hint: you are on the blue team)

TSMC-COMPARE

Now do you see? Does it make sense to you? Instead of making this a whole smooth movement they are ruining it, adding a ton of extra time to process… In my overkill example you are wasting 39s when you can spare 15s with the good TSMC and only waste 24s in total. Of course, in a real print you will not have such high times but still you will lose some seconds when could be much better/optimized! Again, non-sense crap!
Even if they implemented a good TSMC, this still not the ideal solution to the problem!
And as I’m already sick to speak in it and see people to praise and cry for this **** I will stop here and get you to the real solution!

The good solution

Coming soon! TSMC is slowing me down :(