Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fan speed advance doesn't work as intended #4476

Open
CuredPrusa opened this issue Nov 3, 2024 · 6 comments
Open

Fan speed advance doesn't work as intended #4476

CuredPrusa opened this issue Nov 3, 2024 · 6 comments

Comments

@CuredPrusa
Copy link

CuredPrusa commented Nov 3, 2024

Version 2,5,59,13
when disabling fan advance features speedup/kickstart, all perimeters have fan value as set.
But when i put 1 second at speedup and kickstart, it is trying to do the job, but half of the perimeter runs without required speed.
Outer perimeter is set to 100%. Top of the tube has outer perimeters only:
image
Version 2,5,60,0 makes it even worse.

Besides that , "only for overhangs" seems to be reversed.
Result: Speed on top of the tube is 25mms to provide a lot of cooling. One side of a model is melted too much. I can't use this feature.

I think there is something wrong when layer is fast, e.g. small perimeters only. On larger perimeters, longer layers, it seems to work fine.

@CuredPrusa
Copy link
Author

I think there something about the reset of fan speed advance timer, in my case 1 sec.
This is the example of top surface in shape of triangle.
Fan settings say top surface should have 100% cooling fan speed.
image
image

@CuredPrusa
Copy link
Author

It seems that 100% kick works also when changing to lower fan speed, that doesn't make sense.
In this example first perimeter is 100%, others 70%.

image
image

When kick engaged:
image
image

@CuredPrusa
Copy link
Author

Also, I don't see that layers are connected in this function.
If layer is ending with 20% of fan speed, I don't see fan advanced speed if next layer is starting with 100%.
For example, ending with sparse infill, starting with outer perimeter.

@CuredPrusa
Copy link
Author

I have just realized the fan advance speed change is changing speed in advance even if fan is slowing down. That doesn't make any sense. I guess this is the reason of problems I have reported.
Slowing down the fan should not be considered in that calculation because slowing is much quicker than speeding up.
Also, it would be smart to automatically adapt the speed up timer considering the delta T

@CuredPrusa
Copy link
Author

CuredPrusa commented Nov 19, 2024

I have noticed there is no buffer for fan speed change, which makes fan twitching. If infill has no anchor, it turns to travel at the end of every line. This triggers the fan timer for each line every time, both start and stop. It would be better if "infill" segment includes those travels, because this in fact is the part of the infill. The fan should keep running until whole infill segment gets completed. When advanced fan speed is not used, this problem is not noticeable due to fan inertia. The same problem is noticeable when having short layer, like small radius vertical tube, as explained before already. Maybe the same logic as for retraction could be used: "if travel is shorter than X - do not retract". But here there's no need to set it by user, a fixed percentage of line width (250-300%?) could be just fine.

@CuredPrusa
Copy link
Author

Any luck we get a fix for this theoretically useful feature?
Every now and then I try to enable it because I actually need it, but all I get is a mess blowing around.
Fan from low fan speed at inner perimeter is increasing speed at the end of that inner perimeter loop, to enter another inner perimeter loop which has the same low fan speed as the previous just printed before it. It looks like this algorithm needs a rewrite from scratch.

image
image
image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant