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

PID control #139

Open
xuniversus opened this issue Jun 21, 2024 · 3 comments
Open

PID control #139

xuniversus opened this issue Jun 21, 2024 · 3 comments
Labels
enhancement New feature or request

Comments

@xuniversus
Copy link
Contributor

I just want to preface this issue that I love that this project, from what I gather after some superficial investigation, does not actually need the lm-sensors package with the necessary libraries embedded into the binary, and that its rust so its a generally small footprint.

Use Case

PID control would adapt fan speed to a desired temperature point.
This would stop temperature spikes to create fan spikes, and make fans try to reach a desired temperature if possible.
It would also spin down fans if temperature is already at desired temperature.

Proposed Change

New PID behavior for control.

Who Benefits From The Change(s) ?

Those who wish to maintain constant temperature or avoid fans spinning up and down too quickly.

@xuniversus xuniversus added the enhancement New feature or request label Jun 21, 2024
@wiiznokes
Copy link
Owner

I just want to preface this issue that I love that this project, from what I gather after some superficial investigation, does not actually need the lm-sensors package with the necessary libraries embedded into the binary, and that its rust so its a generally small footprint.

Thanks, yeah this is the case. We couldn't rely on libsensors system dep because we use a custom fork anyway.

PID control would adapt fan speed to a desired temperature point.
This would stop temperature spikes to create fan spikes, and make fans try to reach a desired temperature if possible.
It would also spin down fans if temperature is already at desired temperature.

Is there an equivalent in this project https://getfancontrol.com/ ?

It sound like this could be done using the Graph behavior, maybe with a settings for not make a maximum delta for changing percentage, e.i, to go from 20 to 50%, it must make multiple step each iteration (25, 30, ...)

@xuniversus
Copy link
Contributor Author

xuniversus commented Jun 21, 2024

As referenced here: Rem0o/FanControl.Releases#2196 (comment)
and here: Rem0o/FanControl.Releases#2045 (comment)

I think it's safe to say the repo owner do not believe in the concept, or believe it safe perhaps.
There have been some implementations, for example https://github.com/markusressel/fan2go and https://github.com/mrstux/hybrid_fan_control / https://github.com/khorton/nas_fan_control?tab=readme-ov-file

I think while Rem0o the owner of the repo raises a few valid points, it should be a matter of careful configuration and not something someone without experience with PIDs should do, or at the very least very much at their own risk.

@wiiznokes
Copy link
Owner

wiiznokes commented Jun 22, 2024

Ok so i did miss understood the first comment. I don't have strong opinion on adding a voltage sensor. It seems to have request for it so it might be a good addition.

I'm not sure how this would integrate in fan-control tho?
Can we just provide a voltage sensor similar to the temp sensor and that's it ? We could plug it on, let's say the graph behavior. This will be relatively easy to implement i think.
Or for the voltage sensor to be useful, we also need to map it to a temp sensor, and do more complicated stuff? This will increase the complexity of fan-control more.

So it will help if you could explain what exactly fan-control need to do.

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

No branches or pull requests

2 participants