WLED/usermods/PWM_fan
Frank dbe8554724 code spell checking - part3 (usermods)
if you can spell Fahrenheit, you can't spell Celsius. And vice versa :-)
2023-12-14 03:52:06 +01:00
..
readme.md code spell checking - part3 (usermods) 2023-12-14 03:52:06 +01:00
usermod_PWM_fan.h code review suggestions to make the code more efficient and cleaner 2023-10-05 09:49:00 -05:00

readme.md

PWM fan

v2 Usermod to to control PWM fan with RPM feedback and temperature control

This usermod requires the Dallas Temperature usermod to obtain temperature information. If it's not available, the fan will run at 100% speed. If the fan does not have tachometer (RPM) output you can set the tachometer-pin to -1 to disable that feature.

You can also set the threshold temperature at which fan runs at lowest speed. If the measured temperature is 3°C greater than the threshold temperature, the fan will run at 100%.

If the tachometer is supported, the current speed (in RPM) will be displayed on the WLED Info page.

Installation

Add the compile-time option -D USERMOD_PWM_FAN to your platformio.ini (or platformio_override.ini) or use #define USERMOD_PWM_FAN in myconfig.h. You will also need -D USERMOD_DALLASTEMPERATURE.

Define Your Options

All of the parameters are configured during run-time using Usermods settings page. This includes:

  • PWM output pin (can be configured at compile time -D PWM_PIN=xx)
  • tachometer input pin (can be configured at compile time -D TACHO_PIN=xx)
  • sampling frequency in seconds
  • threshold temperature in degrees Celsius

NOTE: You may also need to tweak Dallas Temperature usermod sampling frequency to match PWM fan sampling frequency.

PlatformIO requirements

No special requirements.

Control PWM fan speed using JSON API

e.g. you can use {"PWM-fan":{"speed":30,"lock":true}} to lock fan speed to 30 percent of maximum. (replace 30 with an arbitrary value between 0 and 100) If you include speed property you can set fan speed as a percentage (%) of maximum speed. If you include lock property you can lock (true) or unlock (false) the fan speed. If the fan speed is unlocked, it will revert to temperature controlled speed on the next update cycle. Once fan speed is locked it will remain so until it is unlocked by the next API call.

Change Log

2021-10

  • First public release 2022-05
  • Added JSON API call to allow changing of speed