Thermostat was designed to control different kind of entities (not only switchable like in generic_thermostat).
- switch,- input_boolean- Basic on/off like generic_thermostat or PWM mode.
- climate- PID regulator.
- number,- input_number- PID regulator (additional switch is required).
- Support multiply heaters/coolers.
- Supports heat_coolmode.
- Supports awaymode.
- Supports invert logic of the heater/cooler.
- Protection if target sensor does not report values for period of time (sensor_stale_duration).
This is recommended way, which will handle one-click upgrade in HACS.
- Install hacs if it is not installed.
- Open HACS -> Integrations. Click 3 dots in the upper right corner.
- Click Custom repositories.
- Add https://github.com/jethome-ru/hassio-component-smart-thermostatrepository.
- Find Smart Thermostat with auto Heat/Cool modes and PID control supportand click install button.
NOTE: This is not recommended way, because you will need to upgrade component manually.
- 
Copy /custom_components/smart_thermostatto your<config_dir>/custom_components/directory.- On HassIO the final location will be /config/custom_components/smart_thermostat.
- On Supervised the final location will be /usr/share/hassio/homeassistant/custom_components/smart_thermostat.
- NOTE: You will need to create the custom_componentsfolder if it does not exist.
 
- On HassIO the final location will be 
- 
Restart Home Assistant Core. 
climate:
  - platform: smart_thermostat    
    name: kitchen_thermostat
    target_sensor: sensor.kitchen_temperature
    min_temp: 15
    max_temp: 28
    precision: 0.1    
    heater:
      - entity_id: climate.kitchen_thermostat_heating_floor
        pid_params: 1.3, 0.5, 0.2
      - entity_id: input_number.kitchen_custom_ajustable_heater_regulator
        switch_entity_id: input_boolean.kitchen_custom_ajustable_heater_regulator_switch
        pid_params: 1.3, 0.5, 0.2
    cooler: switch.kitchen_on_off_cooler- target_temp- Climate target temperature, can be changed in UI. Initial can be set via- target_tempconfig option.
- cur_temp- Current sensor temperature. Will be reported by- target_sensorentity.
- CONFIG.xxx- Reference to the config option.
- CONFIG.CONTROLLER.xxx- Reference to the config controller option (heater/cooler).
- name(Required) - Climate entity name
- unique_id(Optional) - Climate entity- unique_id
- cooler(Optional) - String, Array or Map of the coolers.
- heater(Optional) - String, Array or Map of the heaters.
- target_sensor(Required) - Target temperature sensor
- sensor_stale_duration(Optional) - Thermostat will stop all controllers if no data received from sensor during this period.
- min_temp(Optional, default=7) - Set minimum set point available.
- max_temp(Optional, default=35) - Set maximum set point available.
- away_temp(Optional) - Temperature used by the- awaymode. If this is not specified, the preset mode feature will not be available.
- target_temp(Optional) - Initial target temperature.
- heat_cool_disabled(Optional, default=false) - Disable- heat_coolmode.
- heat_cool_cold_tolerance(Optional, default=0.3) - Cold tolerance for turning on heater controllers. Used only in- heat_coolmode.
- heat_cool_hot_tolerance(Optional, default=0.3) - Hot tolerance for turning on cooler controllers. Used only in- heat_coolmode.
- initial_hvac_mode(Optional) - Initial HVAC mode.
- precision(Optional) - Precision for this device. Supported values are 0.1, 0.5 and 1.0. Default: 0.1 for Celsius and 1.0 for Fahrenheit.
NOTE: at least one of heater or cooler is required.
Initial HVAC mode can be set via initial_hvac_mode config option.
Thermostat behavior will depend on active HVAC mode. HVAC mode can be set in UI.
NOTE: Smart thermostat will always take full control of the heaters/coolers. So it will turn them on/off back if you change their states manually
NOTE: available if at least one CONFIG.heater was defined.
- All heater controllers will be turned on. Specific behavior of each heater will depend on the controller type.
- All cooler controllers will be turned off.
NOTE: available if at least one CONFIG.coller was defined.
- All cooler controllers will be turned on. Specific behavior of each cooler will depend on the controller type.
- All heater controllers will be turned off.
NOTE: available if at least one CONFIG.heater and at least one CONFIG.cooler were defined.
- 
If cur_temp >= target_temp + CONFIG.heat_cool_hot_tolerance- All cooler controllers will be turned on.
- All heater controllers will be turned off.
- Specific behavior of each heater/cooler will depend on the controller type.
 
- 
If cur_temp <= target_temp - CONFIG.heat_cool_cold_tolerance- All heater controllers will be turned on.
- All cooler controllers will be turned off.
- Specific behavior of each heater/cooler will depend on the controller type.
 
NOTE: turning on controller DOES NOT MEANS turning on CONFIG.CONTROLLER.enitity_id inside controller.
Controller behavior depends on the specific controller logic and described below for each controller.
Specific controller will be created for each heater/cooler config option based on CONFIG.CONTROLLER.enitity_id domain.
Domains: switch,input_boolean
- entity_id(Required) - Target entity ID.
- inverted(Optional, default=false) - Need to invert- entity_idlogic.
- keep_alive(Optional) - Send keep-alive interval. Use with heaters, coolers, A/C units that shut off if they don’t receive a signal from their remote for a while.
- min_cycle_duration(Optional, default=null) - Minimal cycle duration. Used to protect from on/off cycling.
- cold_tolerance(Optional, default=0.3) - Cold tolerance.
- hot_tolerance(Optional, default=0.3) - Hot tolerance.
- Turn on entity_idifcur_temp <= target_temp - cold_tolerance(heater) orcur_temp >= target_temp + self._hot_tolerance(cooler)
- No entity_idchanges will be performed if configmin_cycle_durationwas set and enough time was not passed since last switch.
- Behavior on/off will be inverted if invertedconfig option was set totrue
Domains: switch,input_boolean.
See General PID explanation how to tune PID parameters.
- Internal PID limits are integers, defined as constants PWM_SWITCH_MIN_VALUEandPWM_SWITCH_MAX_VALUE(0, 100). So, you must use this limits when tuningpid_paramsterms.
- entity_id(Required) - Target entity ID.
- inverted(Optional, default=false) - Need to invert- entity_idlogic.
- keep_alive(Optional) - Send keep-alive interval. Use with heaters, coolers, A/C units that shut off if they don’t receive a signal from their remote for a while.
- pid_params(Required) - PID params comma-separated string or array in the format- Kp, Ki, Kd(Always positive, will be inverted internally for cool mode).
- pid_sample_period(Optional) - PID constant sample time period.
- pwm_period(Required) - PWM period. Switch will be turned on and turned off according internal PID output once in this period.
- PID output will be calculated internally based on provided pid_params.
- pwm_periodwill be separated to two parts:- ONand- OFF. Each part duration will depend on PID output.
- PWM on/off need will be checked every pwm_period/100time but not often than each 1 second. (PWM_SWITCH_MAX_VALUEinternal const variable)
- Behavior on/off will be inverted if invertedconfig option was set totrue.
- It is keep on/off state duration before Home Assistant restart. Last change time is saved in thermostat state attributes.
NOTE: This mode will be set if entity domain is one of the listed above and pid_params config entry is present.
Domains: climate
See General PID explanation how to tune PID parameters.
- entity_id(Required) - Target entity ID.
- inverted(Optional, default=false) - Need to invert- entity_idlogic.
- keep_alive(Optional) - Send keep-alive interval. Use with heaters, coolers, A/C units that shut off if they don’t receive a signal from their remote for a while.
- pid_params(Required) - PID params comma-separated string or array in the format- Kp, Ki, Kd(Always positive, will be inverted internally for cool mode).
- pid_sample_period(Optional) - PID constant sample time period.
- min(Optional) - Minimum temperature which can be set. Attribute- min_tempfrom- entity_idwill be used if not specified.
- max(Optional) - Maximum temperature which can be set. Attribute- max_tempfrom- entity_idwill be used if not specified.
- Climate entity_idwill be turned on when controller is active.
- Climate entity_idwill be turned off when controller is not active.
- Climate entity_idtemperature will be adjusted everypid_sample_periodit is provided, or on everyCONFIF.target_sensorupdate ifpid_sample_periodis not provided.
- pid_paramswill be inverted if- invertedwas set to- true
Domains: number,input_number
See General PID explanation how to tune PID parameters.
- entity_id(Required) - Target entity ID.
- inverted(Optional, default=false) - Need to invert- entity_idlogic.
- keep_alive(Optional) - Send keep-alive interval. Use with heaters, coolers, A/C units that shut off if they don’t receive a signal from their remote for a while.
- pid_params(Required) - PID params comma-separated string or array in the format- Kp, Ki, Kd(Always positive, will be inverted internally for cool mode).
- pid_sample_period(Optional) - PID constant sample time period.
- min(Optional) - Minimum temperature which can be set. Attribute- minfrom- entity_idwill be used if not specified.
- max(Optional) - Maximum temperature which can be set. Attribute- maxfrom- entity_idwill be used if not specified.
- switch_entity_id(Required) - Switch entity which belongs to- switch,- input_booleandomains.
- switch_inverted(Optional, default=false) - Is- switch_entity_idinverted?
- Switch switch_entity_idwill be turned on when controller is active.
- Switch switch_entity_idwill be turned off when controller is not active.
- Number entity_idtemperature will be adjusted everypid_sample_periodit is provided, or on everyCONFIF.target_sensorupdate ifpid_sample_periodis not provided.
- pid_paramswill be inverted if- invertedwas set to- true
- switch_entity_idbehavior will be inverted if- switch_invertedwas set to- true
- Setup your logger to print debug messages for this component using:
logger:
  default: info
  logs:
    custom_components.smart_thermostat: debug- Restart HA
- Verify you're still having the issue
- File an issue in this GitHub Repository containing your HA log (Developer section > Info > Load Full Home Assistant Log)
- You can paste your log file at pastebin https://pastebin.com/ and submit a link.
- Please include details about your setup (Pi, NUC, etc, docker?, HassOS?)
- The log file can also be found at /<config_dir>/home-assistant.log