openhab-addons/bundles/org.openhab.binding.daikin
Holger Friedrich 639a1cb263
Prepare for OH 5.0.0 (#17906)
* Switch to 5.0.0-SNAPSHOT
* Fix spotless after unleash
* resolve itest runbundles

Signed-off-by: Holger Friedrich <mail@holger-friedrich.de>
2024-12-15 20:30:05 +01:00
..
src [multiple] Reduce SAT warnings (#17564) 2024-10-19 16:59:52 +02:00
NOTICE added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00
README.md Make Markdown code block languages consistent (#17480) 2024-09-29 12:47:18 +02:00

Daikin Binding

The Daikin binding allows you to control your Daikin air conditioning units with openHAB.

In order to do so, your Daikin air conditioning unit must have a supported Wi-Fi adapter installed. This may work with the older KRP series of wired adapters, but has not been tested with them.

Supported Things

Thing Daikin Wi-Fi Adapter Model
ac_unit BRP069A81, BRP069B41, BRP072A42, BRP072C42
airbase_ac_unit BRP15B61

Discovery

This add-on will broadcast messages on your local network looking for Daikin air conditioning units and adding them to the queue of new items discovered. You can also manually add a new item if you know the IP address.

Background discovery polls the network every minute for devices. Background discovery is enabled by default. To disable background discovery, add the following line to the conf/services/runtime.cfg file:

discovery.daikin:background=false

BRP072C42 adapter discovery

A BRP072C42 adapter requires a registered UUID to authenticate. Upon discovery, a UUID will be generated but the adapter's key must be entered in the Thing configuration to complete the UUID registration.

Thing Configuration

  • host - The hostname of the Daikin air conditioner. Typically you'd use an IP address such as 192.168.0.5 for this field.
  • refresh - The frequency with which to refresh information from the Daikin air conditioner specified in seconds. Defaults to 60 seconds.

Additional Thing configurations for BRP072C42 adapter

  • secure - Must be set to true for BRP072C42 to access it through https.
  • uuid - A UUID used to access the BRP072C42 adapter. A handy UUID generator can be found at https://www.uuidgenerator.net/.
  • key - The 13-digit key from the Daikin adapter.

Channels

The temperature channels have a precision of one half degree Celsius. For the BRP072A42 and BRP072C42:

Channel Name Description
power Turns the power on/off for the air conditioning unit.
settemp The temperature set for the air conditioning unit.
indoortemp The indoor temperature as measured by the unit.
outdoortemp The outdoor temperature as measured by the external part of the air conditioning system. May not be available when unit is off.
humidity The indoor humidity as measured by the unit. This is not available on all units.
mode The mode set for the unit (AUTO, DEHUMIDIFIER, COLD, HEAT, FAN)
homekitmode A mode that is compatible with homekit/alexa/google home (off, auto, heat, cool). Not tested for BRP069B41
fanspeed The fan speed set for the unit (AUTO, SILENCE, LEVEL_1, LEVEL_2, LEVEL_3, LEVEL_4, LEVEL_5)
fandir The fan blade direction (STOPPED, VERTICAL, HORIZONTAL, VERTICAL_AND_HORIZONTAL)
cmpfrequency The compressor frequency
specialmode The special mode set for the unit (NORMAL, ECO, POWERFUL). This is not available on all units.
streamer Turns the streamer feature on/off for the air conditioning unit. This is not available on all units.
energyheatingtoday The energy consumption when heating for today
energyheatingthisweek The energy consumption when heating for this week
energyheatinglastweek The energy consumption when heating for last week
energyheatingcurrentyear-1 The energy consumption when heating for current year January
energyheatingcurrentyear-2 The energy consumption when heating for current year February
energyheatingcurrentyear-3 The energy consumption when heating for current year March
energyheatingcurrentyear-4 The energy consumption when heating for current year April
energyheatingcurrentyear-5 The energy consumption when heating for current year May
energyheatingcurrentyear-6 The energy consumption when heating for current year June
energyheatingcurrentyear-7 The energy consumption when heating for current year July
energyheatingcurrentyear-8 The energy consumption when heating for current year August
energyheatingcurrentyear-9 The energy consumption when heating for current year September
energyheatingcurrentyear-10 The energy consumption when heating for current year October
energyheatingcurrentyear-11 The energy consumption when heating for current year November
energyheatingcurrentyear-12 The energy consumption when heating for current year December
energycoolingtoday The energy consumption when cooling for today
energycoolingthisweek The energy consumption when cooling for this week
energycoolinglastweek The energy consumption when cooling for last week
energycoolingcurrentyear-1 The energy consumption when cooling for current year January
energycoolingcurrentyear-2 The energy consumption when cooling for current year February
energycoolingcurrentyear-3 The energy consumption when cooling for current year March
energycoolingcurrentyear-4 The energy consumption when cooling for current year April
energycoolingcurrentyear-5 The energy consumption when cooling for current year May
energycoolingcurrentyear-6 The energy consumption when cooling for current year June
energycoolingcurrentyear-7 The energy consumption when cooling for current year July
energycoolingcurrentyear-8 The energy consumption when cooling for current year August
energycoolingcurrentyear-9 The energy consumption when cooling for current year September
energycoolingcurrentyear-10 The energy consumption when cooling for current year October
energycoolingcurrentyear-11 The energy consumption when cooling for current year November
energycoolingcurrentyear-12 The energy consumption when cooling for current year December
demandcontrolmode The demand control mode (OFF, AUTO, MANUAL, SCHEDULED)
demandcontrolmaxpower The maximum power when in MANUAL mode. Values between 40 and 100 are accepted in an increment of 5. In SCHEDULED demand control mode, this channel will be updated with the calculated maximum power based on the current active schedule.
demandcontrolschedule A JSON string that contains the scheduled demand control settings. See below.

For the BRP15B61:

Channel Name Description
power Turns the power on/off for the air conditioning unit.
settemp The temperature set for the air conditioning unit.
indoortemp The indoor temperature as measured by the unit.
outdoortemp The outdoor temperature as measured by the external part of the air conditioning system. May not be available when unit is off.
mode The mode set for the unit (AUTO, DEHUMIDIFIER, COLD, HEAT, FAN)
homekitmode A mode that is compatible with homekit/alexa/google home (off, auto, heat, cool)
airbasefanspeed The fan speed set for the unit (AUTO, AIRSIDE, LEVEL_1, LEVEL_2, LEVEL_3, LEVEL_4, LEVEL_5, AUTO_LEVEL_1, AUTO_LEVEL_2, AUTO_LEVEL_3, AUTO_LEVEL_4, AUTO_LEVEL_5)
zone1 Turns zone 1 on/off for the air conditioning unit (if a zone controller is installed.)
zone2 Turns zone 2 on/off for the air conditioning unit.
zone3 Turns zone 3 on/off for the air conditioning unit.
zone4 Turns zone 4 on/off for the air conditioning unit.
zone5 Turns zone 5 on/off for the air conditioning unit.
zone6 Turns zone 6 on/off for the air conditioning unit.
zone7 Turns zone 7 on/off for the air conditioning unit.
zone8 Turns zone 8 on/off for the air conditioning unit.

Demand Control

Some units have a demand control feature to limit the maximum power usage to a certain percentage. This is set through the demandcontrolmode channel which accepts OFF, MANUAL, SCHEDULED, or AUTO.

When changing the mode from MANUAL to another mode, the maximum power setting will be saved in the Binding's memory and restored when switching the mode back to MANUAL. Equally, when changing the mode from SCHEDULED to another mode, the current schedule will be saved in the Binding's memory and restored when switching the mode back to SCHEDULED.

Manual Demand Control

Manual demand control requires setting the demandcontrolmaxpower channel to the desired limit. The unit accepts values between 40% and 100% in increments of 5.

Sending a command to the demandcontrolmaxpower channel will automatically switch the demand control mode to MANUAL.

Scheduled Demand Control

It is possible to set the demand control power limit based on day of the week and time of day schedules. When the unit is in scheduled demand control mode, the binding provides the current schedule through the demandcontrolschedule channel.

In SCHEDULED, the demandcontrolmaxpower channel will provide the current maximum power in effect, as defined within the schedule. This information is not provided by the unit itself. It is calculated by the binding based on the current schedule. Therefore, it is important to ensure that openHAB's local time is in sync with the unit's date/time.

The schedule and associated max power settings can be set by sending a command to the demandcontrolschedule channel. When doing so, the demand control mode will automatically change to SCHEDULED, if it wasn't already in that mode.

The schedule is specified in a JSON string in the following format:

{
  "monday": [
    {
      "enabled": true,
      "time": <minutes from midnight>,
      "power": <power in percent>
    }
  ],
  "tuesday": [
    // Schedule entries for Tuesday
  ],
  "wednesday": [

  ],
  // more days up to Sunday
  "sunday": [

  ]
}

Concrete example:

The JSON format doesn't actually support comments. They are provided for clarity.

{
  "monday": [
    {
      "enabled": true,
      "time": 480, // 8 am
      "power": 80
    },
    {
      "enabled": true,
      "time": 600, // 10 am
      "power": 100
    },
    {
      "enabled": true,
      "time": 960, // 4pm
      "power": 50
    }
  ],
  "tuesday": [
    {
      "enabled": true,
      "time": 480, // 8 am
      "power": 80
    },
    {
      "enabled": true,
      "time": 600, // 10 am
      "power": 100
    },
    {
      "enabled": true,
      "time": 960, // 4pm
      "power": 50
    }
  ],
  "wednesday": [
    {
      "enabled": true,
      "time": 480, // 8 am
      "power": 80
    },
    {
      "enabled": true,
      "time": 600, // 10 am
      "power": 100
    },
    {
      "enabled": true,
      "time": 960, // 4pm
      "power": 50
    }
  ],
  "thursday": [
    {
      "enabled": true,
      "time": 480, // 8 am
      "power": 100
    }
  ]
  // omitted days mean that they contain no schedules
}

Note:

  • Each day can have up to 4 schedule entries
  • enabled means whether this schedule element is enabled.
  • time is the start time of the schedule, expressed in number of minutes from midnight.
  • power a value of zero means demand power is disabled at the time defined by the time element.
  • When there are no schedules defined for the current day/time, it is believed that the settings from the previous schedule will apply, bearing in mind that it is a weekly recurring schedule. This is ultimately determined by the logic in the unit itself, and not controlled by the Binding.

Full Example

daikin.things:

// for BRP069B41 or BRP072A42
daikin:ac_unit:living_room_ac [ host="192.168.0.5" ]
// for BRP072C42
daikin:ac_unit:living_room_ac [ host="192.168.0.5", secure=true, uuid="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", key="xxxxxxxxxxxxx" ]
// for Airbase (BRP15B61)
daikin:airbase_ac_unit:living_room_ac [ host="192.168.0.5" ]

daikin.items:

// for BRP069B41, BRP072A42 or BRP072C42
Switch DaikinACUnit_Power { channel="daikin:ac_unit:living_room_ac:power" }
Number:Temperature DaikinACUnit_SetPoint { channel="daikin:ac_unit:living_room_ac:settemp" }
String DaikinACUnit_Mode { channel="daikin:ac_unit:living_room_ac:mode" }
String DaikinACUnit_HomekitMode { channel="daikin:ac_unit:living_room_ac:homekitmode" }
String DaikinACUnit_Fan { channel="daikin:ac_unit:living_room_ac:fanspeed" }
String DaikinACUnit_Fan_Movement { channel="daikin:ac_unit:living_room_ac:fandir" }
Number:Temperature DaikinACUnit_IndoorTemperature { channel="daikin:ac_unit:living_room_ac:indoortemp" }
Number:Temperature DaikinACUnit_OutdoorTemperature { channel="daikin:ac_unit:living_room_ac:outdoortemp" }
// Demand control, when supported by the unit
String DaikinACUnit_DemandControl_Mode { channel="daikin:ac_unit:living_room_ac:demandcontrolmode" }
Dimmer DaikinACUnit_DemandControl_MaxPower { channel="daikin:ac_unit:living_room_ac:demandcontrolmaxpower" }
String DaikinACUnit_DemandControl_Schedule { channel="daikin:ac_unit:living_room_ac:demandcontrolschedule" }

// for Airbase (BRP15B61)
Switch DaikinACUnit_Power { channel="daikin:airbase_ac_unit:living_room_ac:power" }
Number:Temperature DaikinACUnit_SetPoint { channel="daikin:airbase_ac_unit:living_room_ac:settemp" }
String DaikinACUnit_Mode { channel="daikin:airbase_ac_unit:living_room_ac:mode" }
String DaikinACUnit_HomekitMode { channel="daikin:airbase_ac_unit:living_room_ac:homekitmode" }
String DaikinACUnit_Fan { channel="daikin:airbase_ac_unit:living_room_ac:fanspeed" }
Number:Temperature DaikinACUnit_IndoorTemperature { channel="daikin:airbase_ac_unit:living_room_ac:indoortemp" }
Number:Temperature DaikinACUnit_OutdoorTemperature { channel="daikin:airbase_ac_unit:living_room_ac:outdoortemp" }
Switch DaikinACUnit_Zone1 { channel="daikin:airbase_ac_unit:living_room_ac:zone1" }
Switch DaikinACUnit_Zone2 { channel="daikin:airbase_ac_unit:living_room_ac:zone2" }
Switch DaikinACUnit_Zone3 { channel="daikin:airbase_ac_unit:living_room_ac:zone3" }
Switch DaikinACUnit_Zone4 { channel="daikin:airbase_ac_unit:living_room_ac:zone4" }
Switch DaikinACUnit_Zone5 { channel="daikin:airbase_ac_unit:living_room_ac:zone5" }
Switch DaikinACUnit_Zone6 { channel="daikin:airbase_ac_unit:living_room_ac:zone6" }
Switch DaikinACUnit_Zone7 { channel="daikin:airbase_ac_unit:living_room_ac:zone7" }
Switch DaikinACUnit_Zone8 { channel="daikin:airbase_ac_unit:living_room_ac:zone8" }

daikin.sitemap:

// for BRP069B41, BRP072A42 or BRP072C42
Switch item=DaikinACUnit_Power
Setpoint item=DaikinACUnit_SetPoint visibility=[DaikinACUnit_Power==ON]
Selection item=DaikinACUnit_Mode mappings=["AUTO"="Auto", "DEHUMIDIFIER"="Dehumidifier", "COLD"="Cold", "HEAT"="Heat", "FAN"="Fan"] visibility=[DaikinACUnit_Power==ON]
Selection item=DaikinACUnit_Fan mappings=["AUTO"="Auto", "SILENCE"="Silence", "LEVEL_1"="Level 1", "LEVEL_2"="Level 2", "LEVEL_3"="Level 3", "LEVEL_4"="Level 4", "LEVEL_5"="Level 5"] visibility=[DaikinACUnit_Power==ON]
Selection item=DaikinACUnit_Fan_Movement mappings=["STOPPED"="Stopped", "VERTICAL"="Vertical", "HORIZONTAL"="Horizontal", "VERTICAL_AND_HORIZONTAL"="Vertical and Horizontal"] visibility=[DaikinACUnit_Power==ON]
Text item=DaikinACUnit_IndoorTemperature
Text item=DaikinACUnit_OutdoorTemperature

// for Airbase (BRP15B61)
Switch item=DaikinACUnit_Power
Setpoint item=DaikinACUnit_SetPoint visibility=[DaikinACUnit_Power==ON]
Selection item=DaikinACUnit_Mode mappings=["AUTO"="Auto", "DEHUMIDIFIER"="Dehumidifier", "COLD"="Cold", "HEAT"="Heat", "FAN"="Fan"] visibility=[DaikinACUnit_Power==ON]
Selection item=DaikinACUnit_Fan visibility=[DaikinACUnit_Power==ON]
Text item=DaikinACUnit_IndoorTemperature
Text item=DaikinACUnit_OutdoorTemperature
Switch item=DaikinACUnit_Zone1 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone2 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone3 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone4 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone5 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone6 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone7 visibility=[DaikinACUnit_Power==ON]
Switch item=DaikinACUnit_Zone8 visibility=[DaikinACUnit_Power==ON]