Skip to content

Humidifier

José Antonio Jiménez Campos edited this page Jun 28, 2021 · 19 revisions

A HomeKit Humidifier/Dehumidifier service. It requires a compatible sensor.

Type Service Type
26 Humidifier
27 Humidifier with temperature sensor

The following configuration is available:

Section Key Description
Actions "0", "1" etc. The actions performed by the service
Digital Inputs "b" GPIOs that invoke specific actions
State & Status Inputs "f[n]" & "g[n]" Inputs that manage service state
Service Notifications "m" Notifications to send to another service
ICMP Ping Inputs "q[n]" & "p[n]" Ping inputs that manage service state
Wildcard Actions "y[n]" Perform an action when an service reaches a target value
Initial State "s" State an service enters on boot
Sensor GPIO "g" GPIO line sensor is attached to
Sensor Type "n" Type of sensor attached to service
Sensor Polling Time "j" How often the humidity sense is read
Temperature Offset "z" Correction offset to apply
Humidity Offset "k" Correction offset to apply
Thermostat Type "w" Type of humidifier connected to service
Deadband Humidity "d" Deadband/Hysteresis of humidifier
Deadband Humidity Force Idle "df" Deadband/Hysteresis of humidifier to exec Force Idle Actions
Deadband Humidity Soft On "ds" Deadband/Hysteresis of humidifier to exec Soft On Actions
Delay time to process "dl" Time in seconds to wait for process humidifier logic

Actions

Key Action Description
"0" All OFF Turns off all components of the thermostat
"1" Device ON, Humidifying OFF Turn on but humidifier is in idle-mode
"2" Device ON, Dehumidifying OFF Turn on but dehumidifier is in idle-mode
"3" Device ON, Humidifying ON Humidifier is active and humidifying
"4" Device ON, Dehumidifying ON Humidifier is active and dehumidifyng
"5" Sensor Error Action to perform when there is a sensor error
"6" "f3" triggered Change target humidity by +5%
"7" "f4" triggered Change target humidity by -5%
"8" Device ON, Humidifying Force OFF Turn on but humidifier is in force idle-mode
"9" Device ON, Dehumidifying Force OFF Turn on but dehumidifier is in force idle-mode
"10" Device ON, Humidifying Soft ON Humidifier is active and humidifying in soft mode
"11" Device ON, Dehumidifying Soft ON Humidifier is active and dehumidifying in soft mode

Multiple actions are supported by a humidifier. The Digital Outputs "r": [{}] for each should be configured to attain the desired state.

Sensor GPIO

Sensor GPIO is defined by the "g" key contained within the service object.

Key Value Description
"g" GPIO # GPIO line the temperature sensor is connected to

Sensor Type

Sensor type is defined by the "n" key contained within the service object.

A variety of one-wire sensors are available and supported by HAA.

Refer to Sensor Type for details of the sensors that are supported.

Sensor Polling Time

Sensor polling time is defined by the "j" key contained within the service object.

Key Value Description
"j" 30 Sensor is polled every 30 seconds (default)
0.1 to 65535 Float specifying the number of seconds between polls

The humidity is polled on a regular basis to read the latest values. These values are then posted to HomeKit. If this option is not specified then the sensor will be polled once every 30 seconds.

NOTE: This option is available only for device type 27

Temperature Offset

Temperature offset is defined by the "z" key contained within the service object.

Key Value Description
"z" 0.0 No offset is applied (default)
-∞ < 0.0 > +∞ Offset is added to temperature value read

The accuracy of the temperature sensor varies and may sometimes read consistently higher or lower than the actual temperature. The temperature offset option enables calibration of the sensor by specifying a positive or negative offset to apply to the reading.

The option uses is a floating point value, accurate to 1 decimal place e.g. 1.1

Humidity Offset

Humidity offset is defined by the "k" key contained within the service object.

Key Value Description
"k" 0 No offset is applied (default)
-∞ < 0 > +∞ Offset is added to humidity value read

The accuracy of the available one-wire sensors varies and may sometimes read consistently higher or lower than the actual humidity. The humidity offset option enables calibration of the sensor by specifying a positive or negative offset to apply to the reading.

The option uses is an integer point value.

Humidifier Type

Humidifier type is defined by the "w" key contained within the service object.

Key Type Description
"w" 1 Humidifier (default)
2 Dehumidifier
3 Humidifier and Dehumidifier

This option is used to select the type of humidifier controlled by the device.

Deadband Humidity

Deadband Humidity is defined by the "d" key contained within the service object.

Key Value Description
"d" 0 Set humidity deadband to 0% (default)
0 > +∞ Humidity deadband allowed

The "d" option is used to set the humidity deadband in % to adjust how humidifier works. The value is an integer variable.

Humidifier Deadband

A humidifier deadband (or hysteresis) is designed to lag the inputs from the environment for the purposes of saving you energy and saving your air conditioner or furnace wear and tear from turning on and off frequently.

The deadband represents a humidity range around the automatic mode set point that is your “comfort zone”. For example, with a 4% wide deadband ("d": 4) and a setpoint of 20%, the deadband will be 18 - 22%. This keeps the system from bouncing quickly between humidifying and dehumidifying when in automatic mode.

When humidity fall within the deadband, neither humidifying nor dehumidifying can occur. A larger deadband will have your system run more economically, while a smaller deadband will have your system hold the humidity closer to the setpoint and increase comfort.

Deadband Humidity Force Idle

Deadband humidity force idle is defined by the "df" key contained within the service object.

Key Value Description
"df" 0 Set humidity deadband to 0% (default)
0 > +∞ Humidity deadband allowed

Deadband Humidity Soft On

Deadband humidity soft on is defined by the "ds" key contained within the service object.

Key Value Description
"ds" 0 Set humidity deadband to 0% (default)
0 > +∞ Humidity deadband allowed

Delay time to process

Time to wait until humidifier data in processed. It is used to avoid conflicts when many HomeKit orders are sent at same time.

Key Value Description
"dl" 3.0 Set delay time to 4 seconds (default)
0.15 > +∞ Delay time allowed in seconds

Service Notifications

The list of notifications "m" supported by a thermostat are as follows:

Value Notification
0 Humidifier OFF
1 Humidifier ON
-3 Auto mode
-2 Humidifier mode
-1 Dehumidifier mode
1000 - 1100 Set humidifier threshold humidity to value - 1000
2000 - 2100 Set dehumidifier threshold humidity to value - 2000

See the general Service Notifications section for details of how to configure these notifications.

Digital Inputs

Digital Inputs "b" are supported by this service.

See Digital Inputs for details on how to define this mandatory option.

State and Status Inputs

State inputs "f[n]" & Status Inputs "g[n]" are supported by this service. The supported list is:

Key Required State
"f0" Humidifier OFF
"f1" Humidifier ON
"f3" Change target humidity by +5%
"f4" Change target humidity by -5%
"f5" Dehumidifier mode ON
"f6" Humidifier mode ON
"f7" Auto mode ON

NOTE: Fixed states "f5", "f6" & "f7" are only available when thermostat type 3 is selected ("w": 3)

Refer to State Inputs for more detail and examples.

ICMP Ping Inputs

ICMP Ping inputs "p[n]" and "q[n]" are supported by this service. Refer to ICMP Ping Inputs for more detail.

Wildcard Actions

Wildcard Actions "y[n]" are supported by this service. The supported list is:

Key Action
"y0" Trigger action when service reaches a specific temperature
"y1" Trigger action when service reaches a specific humidity

Refer to Wildcard Actions for more detail.

Initial State

The Initial State key is supported by this service. Refer to Initial State for more details.

Key State Description
"s" 0 OFF (default)
1 Humidifier
2 Dehumidifier
4 Defined by fixed state inputs
5 Last state before restart
6 Opposite to last state before restart
Clone this wiki locally