Cette intégration de thermostat vise à simplifier considérablement vos automatisations autour de la gestion du chauffage. Parce que tous les événements autour du chauffage classiques sont gérés nativement par le thermostat (personne à la maison ?, activité détectée dans une pièce ?, fenêtre ouverte ?, délestage de courant ?), vous n'avez pas à vous encombrer de scripts et d'automatismes compliqués pour gérer vos thermostats. ;-).
- Merci pour les bières buymecoffee
- Glossaire
- Documentation
- Comment installer Versatile Thermostat ?
- HACS installation (recommendé)
- Installation manuelle
- Configurez les coefficients de l'algorithme TPI
- Configurer les températures préréglées
- Configurer les portes/fenêtres en allumant/éteignant les thermostats
- Configurer le mode d'activité ou la détection de mouvement
- Configurer la gestion de la puissance
- Configurer la présence (ou l'absence)
- Configuration avancée
- Le contrôle centralisé
- Le contrôle d'une chaudière centrale
- Synthèse des paramètres
- Exemples de réglage
- Algorithme
- Capteurs
- Services
- Evènements
- Attributs personnalisés
- Quelques résultats
- Encore mieux
- Bien mieux avec le Versatile Thermostat UI Card
- Encore mieux avec le composant Scheduler !
- Encore bien mieux avec la custom:simple-thermostat front integration
- Toujours mieux avec Plotly pour régler votre thermostat
- Et toujours de mieux en mieux avec l'AappDaemon NOTIFIER pour notifier les évènements
- Les contributions sont les bienvenues !
- Dépannages
- Utilisation d'un Heatzy
- Utilisation d'un radiateur avec un fil pilote
- Utilisation d'un radiateur avec un fil pilote
- Seul le premier radiateur chauffe
- Le radiateur chauffe alors que la température de consigne est dépassée ou ne chauffe pas alors que la température de la pièce est bien en-dessous de la consigne
- Régler les paramètres de détection d'ouverture de fenêtre en mode auto
- Pourquoi mon Versatile Thermostat se met en Securite ?
- Utilisation d'un groupe de personnes comme capteur de présence
- Activer les logs du Versatile Thermostat
Ce composant personnalisé pour Home Assistant est une mise à niveau et est une réécriture complète du composant "Awesome thermostat" (voir Github) avec l'ajout de fonctionnalités.
Merci pour les bières buymecoffee
Un grand merci à @salabur, @pvince83, @bergoglio, @EPicLURcher, @ecolorado66, @Kriss1670, @maia, @f.maymil, @moutte69, @Jerome, @Gunnar M, @Greg.o, @John Burgess, @abyssmal, @capinfo26, @Helge, @MattG @Mexx62, @Someone, @Lajull, @giopeco, @fredericselier, @philpagan, @studiogriffanti, @Edwin, @Sebbou, @Gerard R., @John Burgess, @Sylvoliv, @cdenfert, @stephane.l, @jms92100, ... pour les bières. Ca fait très plaisir et ça m'encourage à continuer ! Si cette intégration vous a fait économiser, payez moi une p'tite bière !
VTherm : Versatile Thermostat dans la suite de ce document TRV : tête thermostatique équipée d'une vanne. La vanne s'ouvre ou se ferme permettant le passage de l'eau chaude
La documentation est maintenant découpée en plusieurs pages pour faciliter la lecture et la recherche d'informations :
- Installez HACS. De cette façon, vous obtenez automatiquement les mises à jour.
- L'intégration Versatile Thermostat est maintenant proposée directement depuis l'interface HACF (onglet intégrations),
- recherchez et installez "Versatile Thermostat" dans HACS et cliquez sur "installer".
- Redémarrez Home Assistant.
- Ensuite, vous pouvez ajouter une intégration de Versatile Thermostat dans la page Paramètres / Intégrations. Vous ajoutez autant de thermostats dont vous avez besoin (généralement un par radiateur ou par groupe de radiateurs qui doivent être gérés ou par pompe dans le cas d'un chauffage centralisé)
- À l'aide de l'outil de votre choix, ouvrez le répertoire (dossier) de votre configuration HA (où vous trouverez
configuration.yaml
). - Si vous n'avez pas de répertoire (dossier)
custom_components
, vous devez le créer. - Dans le répertoire (dossier)
custom_components
, créez un nouveau dossier appeléversatile_thermostat
. - Téléchargez tous les fichiers du répertoire
custom_components/versatile_thermostat/
(dossier) dans ce référentiel. - Placez les fichiers que vous avez téléchargés dans le nouveau répertoire (dossier) que vous avez créé.
- Redémarrez l'assistant domestique
- Configurer la nouvelle intégration du Versatile Thermostat
Certains équipements nécessitent d'être périodiquement sollicités pour empêcher un arrêt de sécurité. Connu sous le nom de "keep-alive" cette fonction est activable en entrant un nombre de secondes non nul dans le champ d'intervalle keep-alive du thermostat. Pour désactiver la fonction ou en cas de doute, laissez-le vide ou entrez zéro (valeur par défaut).
L'algorithme à utiliser est aujourd'hui limité à TPI est disponible. Voir algorithme. Si plusieurs entités de type sont configurées, la thermostat décale les activations afin de minimiser le nombre de switch actif à un instant t. Ca permet une meilleure répartition de la puissance puisque chaque radiateur va s'allumer à son tour. Exemple de déclenchement synchronisé :
Il est possible de choisir un thermostat over switch qui commande une climatisation en cochant la case "AC Mode". Dans ce cas, seul le mode refroidissement sera visible.
Si votre équipement est commandé par un fil pilote avec un diode, vous aurez certainement besoin de cocher la case "Inverser la case". Elle permet de mettre le switch à On lorsqu'on doit étiendre l'équipement et à Off lorsqu'on doit l'allumer.
Il est possible de choisir un thermostat over climate qui commande une climatisation réversible en cochant la case "AC Mode". Dans ce cas, selon l'équipement commandé vous aurez accès au chauffage et/ou au réfroidissement.
Depuis la release 3.8, vous avez la possibilité d'activer la fonction d'auto-régulation. Cette fonction autorise VersatileThermostat à adapter la consigne de température donnée au climate sous-jacent afin que la température de la pièce atteigne réellement la consigne. Pour faire ça, le VersatileThermostat calcule un décalage basé sur les informations suivantes :
- la différence actuelle entre la température réelle et la température de consigne, appelé erreur brute,
- l'accumulation des erreurs passées,
- la différence entre la température extérieure et la consigne
Ces trois informations sont combinées pour calculer le décalage qui sera ajouté à la consigne courante et envoyé au climate sous-jacent.
La fonction d'auto-régulation se paramètre avec :
- une dégré de régulation :
- Légère - pour des faibles besoin en auto-régulation. Dans ce mode, le décalage maximal sera de 1,5°,
- Medium - pour une auto-régulation moyenne. Un décalage maximal de 2° est possible dans ce mode,
- Forte - pour un fort besoin d'auto-régulation. Le décalage maximal est de 3° dans ce mode et l'auto-régulation réagira fortement aux changements de température.
- Un seuil d'auto-régulation : valeur en dessous de laquelle une nouvelle régulation ne sera pas appliquée. Imaginons qu'à un instant t, le décalage soit de 2°. Si au prochain calcul, le décalage est de 2.4°, il sera pas appliqué. Il ne sera appliqué que la différence entre 2 décalages sera au moins égal à ce seuil,
- Période minimal entre 2 auto-régulation : ce nombre, exprimé en minute, indique la durée entre 2 changements de régulation.
Ces trois paramètres permettent de moduler la régulation et éviter de multiplier les envois de régulation. Certains équipements comme les TRV, les chaudières n'aiment pas qu'on change la consigne de température trop souvent.
- Ne démarrez pas tout de suite l'auto-régulation. Regardez comment se passe la régulation naturelle de votre équipement. Si vous constatez que la température de consigne n'est pas atteinte ou qu'elle met trop de temps à être atteinte, démarrez la régulation,
- D'abord commencez par une légère auto-régulation et gardez les deux paramètres avec leur valeurs par défaut. Attendez quelques jours et vérifiez si la situation s'est améliorée,
- Si ce n'est pas suffisant, passez en auto-régulation Medium, attendez une stabilisation,
- Si ce n'est toujours pas suffisant, passez en auto-régulation Forte,
- Si ce n'est toujours pas bon, il faudra passer en mode expert pour pouvoir régler les paramètres de régulation de façon fine. Voir en-dessous
L'auto-régulation consiste à forcer l'équipement a aller plus loin en lui forçant sa température de consigne régulièrement. Sa consommation peut donc être augmentée, ainsi que son usure.
En mode Expert pouvez régler finement les paramètres de l'auto-régulation pour atteindre vos objeetifs et optimiser au mieux. L'algorithme calcule l'écart entre la consigne et la température réelle de la pièce. Cet écard est appelé erreur. Les paramètres réglables sont les suivants :
kp
: le facteur appliqué à l'erreur brute,ki
: le facteur appliqué à l'accumulation des erreurs,k_ext
: le facteur appliqué à la différence entre la température intérieure et la température externe,offset_max
: le maximum de correction (offset) que la régulation peut appliquer,stabilization_threshold
: un seuil de stabilisation qui lorsqu'il est atteint par l'erreur remet à 0, l'accumulation des erreurs,accumulated_error_threshold
: le maximum pour l'accumulation d'erreur.
Pour le tuning il faut tenir compte de ces observations :
kp * erreur
va donner l'offset lié à l'erreur brute. Cet offset est directement proportionnel à l'erreur et sera à 0 lorsque la target sera atteinte,- l'accumulation de l'erreur permet de corriger le stabilisation de la courbe alors qu'il reste une erreur. L'erreur s'accumule et l'offset augmente donc progressivement ce qui devrait finir par stabiliser sur la température cible. Pour que ce paramètre fondamental est un effet il faut qu'il soit pas trop petit. Une valeur moyenne est 30
ki * accumulated_error_threshold
va donner l'offset maximal lié à l'accumulation de l'erreur,k_ext
permet d'appliquer tout de suite (sans attendre une accumulation des erreurs) une correction lorsque la température extérieure est très différente de la température cible. Si la stabilisation se fait trop haut lorsqu'il les écarts de température sont importants, c'est que ce paramètre est trop fort. Il devrait pouvoir être annulé totalement pour laisser faire les 2 premiers offset
Les valeurs préprogrammées sont les suivantes :
Slow régulation :
kp: 0.2 # 20% of the current internal regulation offset are caused by the current difference of target temperature and room temperature
ki: 0.8 / 288.0 # 80% of the current internal regulation offset are caused by the average offset of the past 24 hours
k_ext: 1.0 / 25.0 # this will add 1°C to the offset when it's 25°C colder outdoor than indoor
offset_max: 2.0 # limit to a final offset of -2°C to +2°C
stabilization_threshold: 0.0 # this needs to be disabled as otherwise the long term accumulated error will always be reset when the temp briefly crosses from/to below/above the target
accumulated_error_threshold: 2.0 * 288 # this allows up to 2°C long term offset in both directions
Light régulation :
kp: 0.2
ki: 0.05
k_ext: 0.05
offset_max: 1.5
stabilization_threshold: 0.1
accumulated_error_threshold: 10
Medium régulation :
kp: 0.3
ki: 0.05
k_ext: 0.1
offset_max: 2
stabilization_threshold: 0.1
accumulated_error_threshold: 20
Strong régulation :
"""Strong parameters for regulation
A set of parameters which doesn't take into account the external temp
and concentrate to internal temp error + accumulated error.
This should work for cold external conditions which else generates
high external_offset"""
kp: 0.4
ki: 0.08
k_ext: 0.0
offset_max: 5
stabilization_threshold: 0.1
accumulated_error_threshold: 50
Pour utiliser le mode Expert il vous faut déclarer les valeurs que vous souhaitez utiliser pour chacun de ces paramètres dans votre configuration.yaml
sous la forme suivante :
versatile_thermostat:
auto_regulation_expert:
kp: 0.4
ki: 0.08
k_ext: 0.0
offset_max: 5
stabilization_threshold: 0.1
accumulated_error_threshold: 50
et bien sur, configurer le mode auto-régulation du VTherm en mode Expert. Tous les VTherm en mode Expert utiliseront ces mêmes paramètres.
Pour que les modifications soient prises en compte, il faut soit relancer totalement Home Assistant soit juste l'intégration Versatile Thermostat (Outils de dev / Yaml / rechargement de la configuration / Versatile Thermostat).
Quelque fois, il arrive que le thermomètre interne du sous-jacent (TRV, climatisation, ...) soit tellement faux que l' auto-régulation ne suffise pas à réguler. Cela arrive lorsque le thermomètre interne est trop près de la source de chaleur. La température interne monte alors beaucoup plus vite que la température de la pièce, ce qui génère des défauts dans la régulation. Exemple :
- la température de la pièce est 18°, la consigne est à 20°,
- la température interne de l'équipement est de 22°,
- si VTherm envoie 21° comme consigne (= 20° + 1° d'auto-regulation), alors l'équipement ne chauffera pas car sa température interne (22°) est au-dessus de la consigne (21°)
Pour palier à ça, une nouvelle option facultative a été ajoutée en version 5.4 :
Lorsqu'elle est activée, cette fonction ajoutera l'écart entre la température interne et la température de la pièce à la consigne pour forcer le chauffage. Dans l'exemple ci-dessus, l'écart est de +4° (22° - 18°), donc VTherm enverra 25° (21°+4°) à l'équipement le forçant ainsi à chauffer.
Cet écart est calculé pour chaque sous-jacent car chacun à sa propre température interne. Pensez à un VTherm qui serait relié à 3 TRV chacun avec sa température interne par exemple.
On obtient alors une auto-régulation bien plus efficace qui évite l'eccueil des gros écarts de température interne défaillante.
L'algorithme d'auto-régulation peut être synthétisé comme suit:
- initialiser la température cible comme la consigne du VTherm,
- Si l'auto-régulation est activée,
- calcule de la température régulée (valable pour un VTherm),
- prendre cette température comme cible,
- Pour chaque sous-jacent du VTherm,
- Si "utiliser la température interne" est cochée,
- calcule de l'écart (trv internal temp - room temp),
- ajout de l'écart à la température cible,
- envoie de la température cible ( = temp regulee + (temp interne - temp pièce)) au sous-jacent
- Si "utiliser la température interne" est cochée,
Ce mode introduit en 4.3 permet de forcer l'usage de la ventilation si l'écart de température est important. En effet, en activant la ventilation, la répartition se fait plus rapidement ce qui permet de gagner du temps dans l'atteinte de la température cible. Vous pouvez choisir quelle ventilation vous voulez activer entre les paramètres suivants : Faible, Moyenne, Forte, Turbo.
Il faut évidemment que votre équipement sous-jacent soit équipée d'une ventilation et quelle soit pilotable pour que cela fonctionne.
Si votre équipement ne comprend pas le mode Turbo, le mode Fortesera utilisé en remplacement. Une fois l'écart de température redevenu faible, la ventilation se mettra dans un mode "normal" qui dépend de votre équipement à savoir (dans l'ordre) :
Silence (mute),
Auto (auto),
Faible (low)`. La première valeur qui est possible pour votre équipement sera choisie.
Cette fonction a été introduite en 6.5.0. Elle permet d'autoriser VTherm a stopper un équipement qui n'a pas besoin d'être allumé et de le redémarrer lorsque les conditions le réclame. Cette fonction est munie de 3 réglages qui permettent d'arrêter / relancer plus ou moins rapidement l'équipement.
Pour l'utiliser, vous devez :
- Ajouter la fonction
Avec démmarrage et extinction automatique
dans le menu 'Fonctions', - Paramétrer le niveau de détection dans l'option 'Allumage/extinction automatique' qui s'affiche lorsque la fonction a été activée. Vous choisissez le niveau de détection entre 'Lent', 'Moyen' et 'Rapide'. Les arrêts/relances seront plus nombreux avec le niveau 'Rapide'.
Une fois paramétré, vous aurez maintenant une nouvelle entité de type switch
qui vous permet d'autoriser ou non l'arrêt/relance automatique sans toucher à la configuration. Cette entité est disponible sur l'appareil VTherm et se nomme switch.<name>_enable_auto_start_stop
. Cochez la pour autoriser le démarrage et extinction automatique.
L'algorithme de détection est décrit ici.
Vous pouvez choisir jusqu'à entité du domaine number
ou ìnput_number
qui vont commander les vannes.
L'algorithme à utiliser est aujourd'hui limité à TPI est disponible. Voir algorithme.
Il est possible de choisir un thermostat over valve qui commande une climatisation en cochant la case "AC Mode". Dans ce cas, seul le mode refroidissement sera visible.
Si vous avez choisi un thermostat de type over_switch
ou over_valve
et que vous sélectionnez l'option "TPI" vous menu, vous arriverez sur cette page :
Vous devez donner :
- le coefficient coef_int de l'algorithme TPI,
- le coefficient coef_ext de l'algorithme TPI
Pour plus d'informations sur l'algorithme TPI et son réglage, veuillez vous référer à algorithm.
Le mode préréglé (preset) vous permet de préconfigurer la température ciblée. Utilisé en conjonction avec Scheduler (voir scheduler vous aurez un moyen puissant et simple d'optimiser la température par rapport à la consommation électrique de votre maison. Les préréglages gérés sont les suivants :
- Eco : l'appareil est en mode d'économie d'énergie
- Confort : l'appareil est en mode confort
- Boost : l'appareil tourne toutes les vannes à fond
Si le mode AC est utilisé, vous pourrez aussi configurer les températures lorsque l'équipement en mode climatisation.
Aucun est toujours ajouté dans la liste des modes, car c'est un moyen de ne pas utiliser les preset mais une température manuelle à la place.
Les pré-réglages se font (depuis v6.0) directement depuis les entités du VTherm ou de la configuration centrale si vous utilisez la configuration centrale.
- En modifiant manuellement la température cible, réglez le préréglage sur Aucun (pas de préréglage). De cette façon, vous pouvez toujours définir une température cible même si aucun préréglage n'est disponible.
- Le préréglage standard
Away
est un préréglage caché qui n'est pas directement sélectionnable. Versatile Thermostat utilise la gestion de présence ou la gestion de mouvement pour régler automatiquement et dynamiquement la température cible en fonction d'une présence dans le logement ou d'une activité dans la pièce. Voir gestion de la présence.- Si vous utilisez la gestion du délestage, vous verrez un préréglage caché nommé
power
. Le préréglage de l'élément chauffant est réglé sur « puissance » lorsque des conditions de surpuissance sont rencontrées et que le délestage est actif pour cet élément chauffant. Voir gestion de l'alimentation.- si vous utilisez la configuration avancée, vous verrez le préréglage défini sur
sécurité
si la température n'a pas pu être récupérée après un certain délai- Si vous ne souhaitez pas utiliser le préréglage, indiquez 0 comme température. Le préréglage sera alors ignoré et ne s'affichera pas dans le composant front
Vous devez avoir choisi la fonctionnalité Avec détection des ouvertures
dans la première page pour arriver sur cette page.
La détecttion des ouvertures peut se faire de 2 manières:
- soit avec un capteur placé sur l'ouverture (mode capteur),
- soit en détectant une chute brutale de température (mode auto)
En mode capteur, vous devez renseigner les informations suivantes:
- un identifiant d'entité d'un capteur de fenêtre/porte. Cela devrait être un binary_sensor ou un input_boolean. L'état de l'entité doit être 'on' lorsque la fenêtre est ouverte ou 'off' lorsqu'elle est fermée
- un délai en secondes avant tout changement. Cela permet d'ouvrir rapidement une fenêtre sans arrêter le chauffage.
En mode auto, la configuration est la suivante:
- un seuil de détection en degré par minute. Lorsque la température chute au delà de ce seuil, le thermostat s'éteindra. Plus cette valeur est faible et plus la détection sera rapide (en contre-partie d'un risque de faux positif),
- un seuil de fin de détection en degré par minute. Lorsque la chute de température repassera au-dessus cette valeur, le thermostat se remettra dans le mode précédent (mode et preset),
- une durée maximale de détection. Au delà de cette durée, le thermostat se remettra dans son mode et preset précédent même si la température continue de chuter.
Pour régler les seuils il est conseillé de commencer avec les valeurs de référence et d'ajuster les seuils de détection. Quelques essais m'ont donné les valeurs suivantes (pour un bureau):
- seuil de détection : 0,05 °C/min
- seuil de non détection: 0 °C/min
- durée max : 60 min.
Un nouveau capteur "slope" a été ajouté pour tous les thermostats. Il donne la pente de la courbe de température en °C/min (ou °K/min). Cette pente est lissée et filtrée pour éviter les valeurs abérrantes des thermomètres qui viendraient pertuber la mesure.
Pour bien régler il est conseillé d'affocher sur un même graphique historique la courbe de température et la pente de la courbe (le "slope") :
Et c'est tout ! votre thermostat s'éteindra lorsque les fenêtres seront ouvertes et se rallumera lorsqu'il sera fermé.
- Si vous souhaitez utiliser plusieurs capteurs de porte/fenêtre pour automatiser votre thermostat, créez simplement un groupe avec le comportement habituel (https://www.home-assistant.io/integrations/binary_sensor.group/)
- Si vous n'avez pas de capteur de fenêtre/porte dans votre chambre, laissez simplement l'identifiant de l'entité du capteur vide,
- Un seul mode est permis. On ne peut pas configurer un thermostat avec un capteur et une détection automatique. Les 2 modes risquant de se contredire, il n'est pas possible d'avoir les 2 modes en même temps,
- Il est déconseillé d'utiliser le mode automatique pour un équipement soumis à des variations de température fréquentes et normales (couloirs, zones ouvertes, ...)
Si vous avez choisi la fonctionnalité Avec détection de mouvement
, cliquez sur 'Valider' sur la page précédente et vous y arriverez :
Nous allons maintenant voir comment configurer le nouveau mode Activité. Ce dont nous avons besoin:
- un capteur de mouvement. ID d'entité d'un capteur de mouvement. Les états du capteur de mouvement doivent être « on » (mouvement détecté) ou « off » (aucun mouvement détecté)
- une durée de délai de mouvement (en secondes) définissant combien de temps nous attendons la confirmation du mouvement avant de considérer le mouvement. Ce paramètre peut être supérieur à la temporision de votre détecteur de mouvement, sinon la détection se fera à chaque mouvement signalé par le détecteur,
- une durée de fin délai de mouvement (en secondes) définissant combien de temps nous attendons la confirmation d'une fin de mouvement avant de ne plus considérer le mouvement.
- un **préréglage de "mouvement" **. Nous utiliserons la température de ce préréglage lorsqu'une activité sera détectée.
- un préréglage "pas de mouvement". Nous utiliserons la température de ce deuxième préréglage lorsqu'aucune activité n'est détectée.
Alors imaginons que nous voulions avoir le comportement suivant :
- nous avons une pièce avec un thermostat réglé en mode activité, le mode "mouvement" choisi est confort (21,5°C), le mode "pas de mouvement" choisi est Eco (18.5°C) et la temporisation du mouvement est de 30 sec lors de la détection et de 5 minutes sur fin de détection.
- la pièce est vide depuis un moment (aucune activité détectée), la température de cette pièce est de 18,5°
- quelqu'un entre dans la pièce, une activité est détectée si le mouvement est présent pendant au moins 30 sec. La température passe alors à 21,5°
- si le mouvement est présent pendant moins de 30 sec (passage rapide), la température reste sur 18,5°,
- imaginons que la température soit passée sur 21,5°, lorsque la personne quitte la pièce, au bout de 5 min la température est ramenée à 18,5°.
- si la personne revient avant les 5 minutes, la température reste sur 21,5°
Pour que cela fonctionne, le thermostat doit être en mode préréglé « Activité ».
Notes 1. Sachez que comme pour les autres modes prédéfinis,
Activity
ne sera proposé que s'il est correctement configuré. En d'autres termes, les 4 clés de configuration doivent être définies si vous souhaitez voir l'activité dans l'interface de l'assistant domestique
Si vous avez choisi la fonctionnalité Avec détection de la puissance
, cliquez sur 'Valider' sur la page précédente et vous arriverez ici :
Cette fonction vous permet de réguler la consommation électrique de vos radiateurs. Connue sous le nom de délestage, cette fonction vous permet de limiter la consommation électrique de votre appareil de chauffage si des conditions de surpuissance sont détectées. Donnez un capteur à la consommation électrique actuelle de votre maison, un capteur à la puissance max qu'il ne faut pas dépasser, la consommation électrique totale des équipements du VTherm (en étape 1 de la configuration) et l'algorithme ne démarrera pas un radiateur si la puissance maximale sera dépassée après le démarrage du radiateur.
Notez que toutes les valeurs de puissance doivent avoir les mêmes unités (kW ou W par exemple). Cela vous permet de modifier la puissance maximale au fil du temps à l'aide d'un planificateur ou de ce que vous voulez.
- En cas de délestage, le radiateur est réglé sur le préréglage nommé
power
. Il s'agit d'un préréglage caché, vous ne pouvez pas le sélectionner manuellement.- Je l'utilise pour éviter de dépasser la limite de mon contrat d'électricité lorsqu'un véhicule électrique est en charge. Cela crée une sorte d'autorégulation.
- Gardez toujours une marge, car la puissance max peut être brièvement dépassée en attendant le calcul du prochain cycle typiquement ou par des équipements non régulés.
- Si vous ne souhaitez pas utiliser cette fonctionnalité, laissez simplement l'identifiant des entités vide
- Si vous controlez plusieurs radiateurs, la consommation électrique de votre chauffage renseigné doit correspondre à la somme des puissances.
Si sélectionnée en première page, cette fonction vous permet de modifier dynamiquement la température de tous les préréglages du thermostat configurés lorsque personne n'est à la maison ou lorsque quelqu'un rentre à la maison. Pour cela, vous devez configurer la température qui sera utilisée pour chaque préréglage lorsque la présence est désactivée. Lorsque le capteur de présence s'éteint, ces températures seront utilisées. Lorsqu'il se rallume, la température "normale" configurée pour le préréglage est utilisée. Voir gestion des préréglages. Pour configurer la présence remplissez ce formulaire :
Pour cela, vous devez configurer :
- Un capteur d'occupation dont l'état doit être 'on' ou 'home' si quelqu'un est présent ou 'off' ou 'not_home' sinon,
- La température utilisée en Eco prédéfinie en cas d'absence,
- La température utilisée en Confort préréglée en cas d'absence,
- La température utilisée en Boost préréglée en cas d'absence
Si le mode AC est utilisé, vous pourrez aussi configurer les températures lorsque l'équipement en mode climatisation.
ATTENTION : les groupes de personnes ne fonctionnent pas en tant que capteur de présence. Ils ne sont pas reconnus comme un capteur de présence. Vous devez utiliser, un template comme décrit ici Utilisation d'un groupe de personnes comme capteur de présence.
- le changement de température est immédiat et se répercute sur le volet avant. Le calcul prendra en compte la nouvelle température cible au prochain calcul du cycle,
- vous pouvez utiliser le capteur direct person.xxxx ou un groupe de capteurs de Home Assistant. Le capteur de présence gère les états
on
ouhome
comme présents et les étatsoff
ounot_home
comme absents.
Ces paramètres permettent d'affiner le réglage du thermostat. Le formulaire de configuration avancée est le suivant :
Le premier délai (minimal_activation_delay_sec) en secondes est le délai minimum acceptable pour allumer le chauffage. Lorsque le calcul donne un délai de mise sous tension inférieur à cette valeur, le chauffage reste éteint.
Le deuxième délai (security_delay_min
) est le délai maximal entre deux mesures de température avant de régler le préréglage sur security
. Si le capteur de température ne donne plus de mesures de température, le thermostat et le radiateur passeront en mode security
après ce délai. Ceci est utile pour éviter une surchauffe si la batterie de votre capteur de température est trop faible.
Le troisième paramétre (security_min_on_percent
) est la valeur minimal de on_percent
en dessous de laquelle le préréglage sécurité ne sera pas activé. Ce paramètre permet de ne pas mettre en sécurité un thermostat, si le radiateur piloté ne chauffe pas suffisament.
Mettre ce paramètre à 0.00
déclenchera le préréglage sécurité quelque soit la dernière consigne de chauffage, à l'inverse 1.00
ne déclenchera jamais le préréglage sécurité ( ce qui revient à désactiver la fonction).
Le quatrième param§tre (security_default_on_percent
) est la valeur de on_percent
qui sera utilisée lorsque le thermostat passe en mode security
. Si vous mettez 0
alors le thermostat sera coupé lorsqu'il passe en mode security
, mettre 0,2% par exemple permet de garder un peu de chauffage (20% dans ce cas), même en mode security
. Ca évite de retrouver son logement totalement gelé lors d'une panne de thermomètre.
Note: les paramètres security_min_on_percent
et security_default_on_percent
ne s'applique pas aux VTherms over_climate
.
Depuis la version 5.3 il est possible de désactiver la mise en sécurité suite à une absence de données du thermomètre extérieure. En effet, celui-ci ayant la plupart du temps un impact faible sur la régulation (dépendant de votre paramètrage), il est possible qu'il soit absent sans mettre en danger le logement. Pour cela, il faut ajouter les lignes suivantes dans votre configuration.yaml
:
versatile_thermostat:
...
safety_mode:
check_outdoor_sensor: false
Par défaut, le thermomètre extérieur peut déclencher une mise en sécurité si il n'envoit plus de valeur.
Voir exemple de réglages pour avoir des exemples de réglage communs
- Lorsque le capteur de température viendra à la vie et renverra les températures, le préréglage sera restauré à sa valeur précédente,
- Attention, deux températures sont nécessaires : la température interne et la température externe et chacune doit donner la température, sinon le thermostat sera en préréglage "security",
- Un service est disponible qui permet de régler les 3 paramètres de sécurité. Ca peut servir à adapter la fonction de sécurité à votre usage,
- Pour un usage naturel, le
security_default_on_percent
doit être inférieur àsecurity_min_on_percent
,- Les thermostats de type
thermostat_over_climate
ne sont pas concernés par le mode security.
Depuis la release 5.2, si vous avez défini une configuration centralisée, vous avez une nouvelle entité nommée select.central_mode
qui permet de piloter tous les VTherms avec une seule action. Pour qu'un VTherm soit contrôlable de façon centralisée, il faut que son attribut de configuration nommé use_central_mode
soit vrai.
Cette entité se présente sous la forme d'une liste de choix qui contient les choix suivants :
Auto
: le mode 'normal' dans lequel chaque VTherm se comporte comme dans les versions précédentes,Stooped
: tous les VTherms sont mis à l'arrêt (hvac_off
),Heat only
: tous les VTherms sont mis en mode chauffage lorsque ce mode est supporté par le VTherm, sinon il est stoppé,Cool only
: tous les VTherms sont mis en mode climatisation lorsque ce mode est supporté par le VTherm, sinon il est stoppé,Frost protection
: tous les VTherms sont mis en preset hors-gel lorsque ce preset est supporté par le VTherm, sinon il est stoppé.
Il est donc possible de contrôler tous les VTherms (que ceux que l'on désigne explicitement) avec un seul contrôle. Exemple de rendu :
Depuis la release 5.3, vous avez la possibilité de contrôler une chaudière centralisée. A partir du moment où il est possible de déclencher ou stopper cette chaudière depuis Home Assistant, alors Versatile Thermostat va pouvoir la commander directement.
Le principe mis en place est globalement le suivant :
- une nouvelle entité de type
binary_sensor
et nommée par défautbinary_sensor.central_boiler
est ajoutée, - dans la configuration des VTherms vous indiquez si le VTherm doit contrôler la chaudière. En effet, dans une installation hétérogène, certains VTherm doivent commander la chaudière et d'autres non. Vous devez donc indiquer dans chaque configuration de VTherm si il contrôle la chaudière ou pas,
- le
binary_sensor.central_boiler
écoute les changements d'états des équipements des VTherm marqués comme contrôlant la chaudière, - dès que le nombre d'équipements pilotés par le VTherm demandant du chauffage (ie son
hvac_action
passe àHeating
) dépasse un seuil paramétrable, alors lebinary_sensor.central_boiler
passe àon
et si un service d'activation a été configuré, alors ce service est appelé, - si le nombre d'équipements nécessitant du chauffage repasse en dessous du seuil, alors le
binary_sensor.central_boiler
passe àoff
et si un service de désactivation a été configuré, alors ce service est appelé, - vous avez accès à deux entités :
- une de type
number
nommé par défautnumber.boiler_activation_threshold
, donne le seuil de déclenchement. Ce seuil est en nombre d'équipements (radiateurs) qui demande du chauffage. - une de type
sensor
nommé par défautsensor.nb_device_active_for_boiler
, donne le nombre d'équipements qui demande du chauffage. Par exemple, un VTherm ayant 4 vannes dont 3 demandes du chauffage fera passé ce capteur à 3. Seuls les équipements des VTherms qui sont marqués pour contrôler la chaudière centrale sont comptabilisés.
- une de type
Vous avez donc en permanence, les informations qui permettent de piloter et régler le déclenchement de la chaudière.
Toutes ces entités sont rattachés au service de configuration centrale :
Pour configurer cette fonction, vous devez avoir une configuration centralisée (cf. Configuration) et cochez la case 'Ajouter une chuadière centrale' :
Sur la page suivante vous pouvez donner la configuration des services à appeler lors de l'allumage / extinction de la chaudière :
Les services se configurent comme indiqués dans la page :
- le format général est
entity_id/service_id[/attribut:valeur]
(où/attribut:valeur
est facultatif), entity_id
est le nom de l'entité qui commande la chaudière sous la formedomain.entity_name
. Par exemple:switch.chaudiere
pour les chaudière commandée par un switch ouclimate.chaudière
pour une chaudière commandée par un thermostat ou tout autre entité qui permet le contrôle de la chaudière (il n'y a pas de limitation). On peut aussi commuter des entrées (helpers
) comme desinput_boolean
ouinput_number
.service_id
est le nom du service à appeler sous la formedomain.service_name
. Par exemple:switch.turn_on
,switch.turn_off
,climate.set_temperature
,climate.set_hvac_mode
sont des exemples valides.- pour certain service vous aurez besoin d'un paramètre. Cela peut être le 'Mode CVC'
climate.set_hvac_mode
ou la température cible pourclimate.set_temperature
. Ce paramètre doit être configuré sous la formeattribut:valeur
en fin de chaine.
Exemples (à ajuster à votre cas) :
climate.chaudiere/climate.set_hvac_mode/hvac_mode:heat
: pour allumer le thermostat de la chaudière en mode chauffage,climate.chaudiere/climate.set_hvac_mode/hvac_mode:off
: pour stopper le thermostat de la chaudière,switch.pompe_chaudiere/switch.turn_on
: pour allumer le swicth qui alimente la pompe de la chaudière,switch.pompe_chaudiere/switch.turn_off
: pour allumer le swicth qui alimente la pompe de la chaudière,- ...
Pour trouver le services a utiliser, le mieux est d'aller dans "Outils de développement / Services", chercher le service a appelé, l'entité à commander et l'éventuel paramètre à donner. Cliquez sur 'Appeler le service'. Si votre chaudière s'allume vous avez la bonne configuration. Passez alors en mode Yaml et recopiez les paramètres.
Exemple:
Sous "Outils de développement / Service" :
En mode yaml :
Le service à configurer est alors le suivant: climate.empty_thermostast/climate.set_hvac_mode/hvac_mode:heat
(notez la suppression du blanc dans hvac_mode:heat
)
Faite alors de même pour le service d'extinction et vous êtes parés.
A chaque allumage ou extinction réussie de la chaudière un évènement est envoyé par Versatile Thermostat. Il peut avantageusement être capté par une automatisation, par exemple pour notifier un changement. Les évènements ressemblent à ça :
Un évènement d'allumage :
event_type: versatile_thermostat_central_boiler_event
data:
central_boiler: true
entity_id: binary_sensor.central_boiler
name: Central boiler
state_attributes: null
origin: LOCAL
time_fired: "2024-01-14T11:33:52.342026+00:00"
context:
id: 01HM3VZRJP3WYYWPNSDAFARW1T
parent_id: null
user_id: null
Un évènement d'extinction :
event_type: versatile_thermostat_central_boiler_event
data:
central_boiler: false
entity_id: binary_sensor.central_boiler
name: Central boiler
state_attributes: null
origin: LOCAL
time_fired: "2024-01-14T11:43:52.342026+00:00"
context:
id: 01HM3VZRJP3WYYWPNSDAFBRW1T
parent_id: null
user_id: null
Notes Le contrôle par du logiciel ou du matériel de type domotique d'une chaudière centrale peut induire des risques pour son bon fonctionnement. Assurez-vous avant d'utiliser ces fonctions, que votre chaudière possède bien des fonctions de sécurité et que celles-ci fonctionnent. Allumer une chaudière si tous les robinets sont fermés peut générer de la sur-pression par exemple.
Synthèse des paramètres
Paramètre | Libellé | "over switch" | "over climate" | "over valve" | "configuration centrale" |
---|---|---|---|---|---|
name |
Nom | X | X | X | - |
thermostat_type |
Type de thermostat | X | X | X | - |
temperature_sensor_entity_id |
Temperature sensor entity id | X | X (auto-regulation) | X | - |
external_temperature_sensor_entity_id |
Température de l'exterieur sensor entity id | X | X (auto-regulation) | X | X |
cycle_min |
Durée du cycle (minutes) | X | X | X | - |
temp_min |
Température minimale permise | X | X | X | X |
temp_max |
Température maximale permise | X | X | X | X |
device_power |
Puissance de l'équipement | X | X | X | - |
use_central_mode |
Autorisation du contrôle centralisé | X | X | X | - |
use_window_feature |
Avec détection des ouvertures | X | X | X | - |
use_motion_feature |
Avec détection de mouvement | X | X | X | - |
use_power_feature |
Avec gestion de la puissance | X | X | X | - |
use_presence_feature |
Avec détection de présence | X | X | X | - |
heater_entity1_id |
1er radiateur | X | - | - | - |
heater_entity2_id |
2ème radiateur | X | - | - | - |
heater_entity3_id |
3ème radiateur | X | - | - | - |
heater_entity4_id |
4ème radiateur | X | - | - | - |
heater_keep_alive |
Intervalle de rafraichissement du switch | X | - | - | - |
proportional_function |
Algorithme | X | - | - | - |
climate_entity1_id |
Thermostat sous-jacent | - | X | - | - |
climate_entity2_id |
2ème thermostat sous-jacent | - | X | - | - |
climate_entity3_id |
3ème thermostat sous-jacent | - | X | - | - |
climate_entity4_id |
4ème thermostat sous-jacent | - | X | - | - |
valve_entity1_id |
Vanne sous-jacente | - | - | X | - |
valve_entity2_id |
2ème vanne sous-jacente | - | - | X | - |
valve_entity3_id |
3ème vanne sous-jacente | - | - | X | - |
valve_entity4_id |
4ème vanne sous-jacente | - | - | X | - |
ac_mode |
utilisation de l'air conditionné (AC) ? | X | X | X | - |
tpi_coef_int |
Coefficient à utiliser pour le delta de température interne | X | - | X | X |
tpi_coef_ext |
Coefficient à utiliser pour le delta de température externe | X | - | X | X |
frost_temp |
Température en preset Hors-gel | X | X | X | X |
window_sensor_entity_id |
Détecteur d'ouverture (entity id) | X | X | X | - |
window_delay |
Délai avant extinction (secondes) | X | X | X | X |
window_auto_open_threshold |
Seuil haut de chute de température pour la détection automatique (en °/min) | X | X | X | X |
window_auto_close_threshold |
Seuil bas de chute de température pour la fin de détection automatique (en °/min) | X | X | X | X |
window_auto_max_duration |
Durée maximum d'une extinction automatique (en min) | X | X | X | X |
motion_sensor_entity_id |
Détecteur de mouvement entity id | X | X | X | - |
motion_delay |
Délai avant prise en compte du mouvement (seconds) | X | X | X | - |
motion_off_delay |
Délai avant prise en compte de la fin de mouvement (seconds) | X | X | X | X |
motion_preset |
Preset à utiliser si mouvement détecté | X | X | X | X |
no_motion_preset |
Preset à utiliser si pas de mouvement détecté | X | X | X | X |
power_sensor_entity_id |
Capteur de puissance totale (entity id) | X | X | X | X |
max_power_sensor_entity_id |
Capteur de puissance Max (entity id) | X | X | X | X |
power_temp |
Température si délestaqe | X | X | X | X |
presence_sensor_entity_id |
Capteur de présence entity id (true si quelqu'un est présent) | X | X | X | - |
minimal_activation_delay |
Délai minimal d'activation | X | - | - | X |
security_delay_min |
Délai maximal entre 2 mesures de températures | X | - | X | X |
security_min_on_percent |
Pourcentage minimal de puissance pour passer en mode sécurité | X | - | X | X |
auto_regulation_mode |
Le mode d'auto-régulation | - | X | - | - |
auto_regulation_dtemp |
La seuil d'auto-régulation | - | X | - | - |
auto_regulation_period_min |
La période minimale d'auto-régulation | - | X | - | - |
inverse_switch_command |
Inverse la commande du switch (pour switch avec fil pilote) | X | - | - | - |
auto_fan_mode |
Mode de ventilation automatique | - | X | - | - |
auto_regulation_use_device_temp |
Utilisation de la température interne du sous-jacent | - | X | - | - |
use_central_boiler_feature |
Ajout du controle d'une chaudière centrale | - | - | - | X |
central_boiler_activation_service |
Service d'activation de la chaudière | - | - | - | X |
central_boiler_deactivation_service |
Service de desactivation de la chaudière | - | - | - | X |
used_by_controls_central_boiler |
Indique si le VTherm contrôle la chaudière centrale | X | X | X | - |
use_auto_start_stop_feature |
Indique si la fonction de démarrage/extinction automatique est activée | - | X | - | - |
auto_start_stop_lvel |
Le niveau de détection de l'auto start/stop | - | X | - | - |
- cycle : entre 5 et 10 minutes,
- minimal_activation_delay_sec : 30 secondes
- cycle : entre 30 et 60 min,
- minimal_activation_delay_sec : 300 secondes (à cause du temps de réponse)
- security_delay_min : 60 min (parce que ces capteurs sont paresseux)
- security_min_on_percent : 0,5 (50% - on passe en preset
security
si le radiateur chauffait plus de 50% du temps) - security_default_on_percent : 0,1 (10% - en preset
security
, on garde un fond de chauffe de 20% du temps)
Il faut comprendre ces réglages comme suit :
Si le thermomètre n'envoie plus la température pendant 1 heure et que le pourcentage de chauffe (
on_percent
) était supérieur à 50 %, alors on ramène ce pourcentage de chauffe à 10 %.
A vous d'adapter ces réglages à votre cas !
Ce qui est important c'est de ne pas prendre trop de risque avec ces paramètres : supposez que vous êtes absent pour une longue période, que les piles de votre thermomètre arrivent en fin de vie, votre radiateur va chauffer 10% du temps pendant toute la durée de la panne.
Versatile Thermostat vous permet d'être notifié lorsqu'un évènement de ce type survient. Mettez en place, les alertes qui vont bien dès l'utilisation de ce thermostat. Cf. (#notifications)
- security_delay_min : 15 min
- security_min_on_percent : 0,7 (70% - on passe en preset
security
si le radiateur chauffait plus de 70% du temps) - security_default_on_percent : 0,25 (25% - en preset
security
, on garde un fond de chauffe de 25% du temps)
Ceci est juste un exemple de la façon dont j'utilise le préréglage. A vous de vous adapter à votre configuration mais cela peut être utile pour comprendre son fonctionnement.
Hors gel
: 10 °C
Éco
: 17 °C
Confort
: 19 °C
Boost
: 20 °C
Lorsque la présence est désactivée :
Hors gel
: 10 °C
Éco
: 16,5 °C
Confort
: 17 °C
Boost
: 18 °C
Le détecteur de mouvement de mon bureau est configuré pour utiliser Boost
lorsqu'un mouvement est détecté et Eco
sinon.
Cette intégration utilise un algorithme proportionnel. Un algorithme proportionnel est utile pour éviter l'oscillation autour de la température cible. Cet algorithme est basé sur un cycle qui alterne le chauffage et l'arrêt du chauffage. La proportion de chauffage par rapport à l'absence de chauffage est déterminée par la différence entre la température et la température cible. Plus grande est la différence et plus grande est la proportion de chauffage à l'intérieur du cycle.
Cet algorithme fait converger la température et arrête d'osciller.
L'algorithme TPI consiste à calculer à chaque cycle un pourcentage d'état On vs Off pour le radiateur en utilisant la température cible, la température actuelle dans la pièce et la température extérieure actuelle. Cet algorithme n'est donc valable que pour les Versatile Thermostat qui régulent : over_switch
et over_valve
.
Le pourcentage est calculé avec cette formule :
on_percent = coef_int * (température cible - température actuelle) + coef_ext * (température cible - température extérieure)
Ensuite, l'algo fait en sorte que 0 <= on_percent <= 1
Les valeurs par défaut pour coef_int et coef_ext sont respectivement : 0.6
et 0.01
. Ces valeurs par défaut conviennent à une pièce standard bien isolée.
Pour régler ces coefficients, gardez à l'esprit que :
- si la température cible n'est pas atteinte après une situation stable, vous devez augmenter le
coef_ext
(leon_percent
est trop bas), - si la température cible est dépassée après une situation stable, vous devez diminuer le
coef_ext
(leon_percent
est trop haut), - si l'atteinte de la température cible est trop lente, vous pouvez augmenter le
coef_int
pour donner plus de puissance au réchauffeur, - si l'atteinte de la température cible est trop rapide et que des oscillations apparaissent autour de la cible, vous pouvez diminuer le
coef_int
pour donner moins de puissance au radiateur.
En type over_valve
le on_percent
est ramené à une valeur entre 0 et 100% et sert directement à commander l'ouverture de la vanne.
Voir quelques situations à examples.
Avec le thermostat sont disponibles des capteurs qui permettent de visualiser les alertes et l'état interne du thermostat. Ils sont disponibles dans les entités de l'appareil associé au thermostat :
Dans l'ordre, il y a :
- l'entité principale climate de commande du thermostat,
- l'énergie consommée par le thermostat (valeur qui s'incrémente en permanence),
- l'heure de réception de la dernière température extérieure,
- l'heure de réception de la dernière température intérieure,
- la puissance moyenne de l'appareil sur le cycle (pour les TPI seulement),
- le temps passé à l'état éteint dans le cycle (TPI seulement),
- le temps passé à l'état allumé dans le cycle (TPI seulement),
- l'état de délestage,
- le pourcentage de puissance sur le cycle (TPI seulement),
- l'état de présence (si la gestion de la présence est configurée),
- l'état de sécurité,
- l'état de l'ouverture (si la gestion des ouvertures est configurée),
- l'état du mouvement (si la gestion du mouvements est configurée)
- le pourcentage d'ouverture de la vanne (pour le type
over_valve
)
Pour colorer les capteurs, ajouter ces lignes et personnalisez les au besoin, dans votre configuration.yaml :
frontend:
themes:
versatile_thermostat_theme:
state-binary_sensor-safety-on-color: "#FF0B0B"
state-binary_sensor-power-on-color: "#FF0B0B"
state-binary_sensor-window-on-color: "rgb(156, 39, 176)"
state-binary_sensor-motion-on-color: "rgb(156, 39, 176)"
state-binary_sensor-presence-on-color: "lightgreen"
state-binary_sensor-running-on-color: "orange"
et choisissez le thème versatile_thermostat_theme
dans la configuration du panel. Vous obtiendrez quelque-chose qui va ressembler à ça :
Cette implémentation personnalisée offre des services spécifiques pour faciliter l'intégration avec d'autres composants Home Assistant.
Ce service permet de forcer l'état de présence indépendamment du capteur de présence. Cela peut être utile si vous souhaitez gérer la présence via un service et non via un capteur. Par exemple, vous pouvez utiliser votre réveil pour forcer l'absence lorsqu'il est allumé.
Le code pour appeler ce service est le suivant :
service : versatile_thermostat.set_presence
Les données:
présence : "off"
cible:
entity_id : climate.my_thermostat
Ce service est utile si vous souhaitez modifier dynamiquement la température préréglée. Au lieu de changer de préréglage, certains cas d'utilisation doivent modifier la température du préréglage. Ainsi, vous pouvez garder le Programmateur inchangé pour gérer le préréglage et ajuster la température du préréglage. Si le préréglage modifié est actuellement sélectionné, la modification de la température cible est immédiate et sera prise en compte au prochain cycle de calcul.
Vous pouvez modifier l'une ou les deux températures (lorsqu'elles sont présentes ou absentes) de chaque préréglage.
Utilisez le code suivant pour régler la température du préréglage :
service : versatile_thermostat.set_preset_temperature
date:
preset : boost
temperature : 17,8
temperature_away : 15
target:
entity_id : climate.my_thermostat
Ou pour changer le pré-réglage du mode Air Conditionné (AC) ajoutez un préfixe `_ac`` au nom du preset comme ceci :
service: versatile_thermostat.set_preset_temperature
data:
preset: boost_ac
temperature: 25
temperature_away: 30
target:
entity_id: climate.my_thermostat
Notes - après un redémarrage, les préréglages sont réinitialisés à la température configurée. Si vous souhaitez que votre changement soit permanent, vous devez modifier le préréglage de la température dans la configuration de l'intégration.
Ce service permet de modifier dynamiquement les paramètres de sécurité décrits ici Configuration avancée.
Si le thermostat est en mode security
les nouveaux paramètres sont appliqués immédiatement.
Pour changer les paramètres de sécurité utilisez le code suivant :
service : versatile_thermostat.set_security
data:
min_on_percent: "0.5"
default_on_percent: "0.1"
delay_min: 60
target:
entity_id : climate.my_thermostat
Ce service permet d'activer ou non un bypass de la vérification des fenetres.
Il permet de continuer à chauffer même si la fenetre est detectée ouverte.
Mis à true
les modifications de status de la fenetre n'auront plus d'effet sur le thermostat, remis à false
cela s'assurera de désactiver le thermostat si la fenetre est toujours ouverte.
Pour changer le paramètre de bypass utilisez le code suivant :
service : versatile_thermostat.set_window_bypass
data:
window_bypass: true
target:
entity_id : climate.my_thermostat
Les évènements marquant du thermostat sont notifiés par l'intermédiaire du bus de message. Les évènements notifiés sont les suivants:
versatile_thermostat_security_event
: un thermostat entre ou sort du presetsecurity
versatile_thermostat_power_event
: un thermostat entre ou sort du presetpower
versatile_thermostat_temperature_event
: une ou les deux mesures de température d'un thermostat n'ont pas été mis à jour depuis plus de `security_delay_min`` minutesversatile_thermostat_hvac_mode_event
: le thermostat est allumé ou éteint. Cet évènement est aussi diffusé au démarrage du thermostatversatile_thermostat_preset_event
: un nouveau preset est sélectionné sur le thermostat. Cet évènement est aussi diffusé au démarrage du thermostatversatile_thermostat_central_boiler_event
: un évènement indiquant un changement dans l'état de la chaudière.
Si vous avez bien suivi, lorsqu'un thermostat passe en mode sécurité, 3 évènements sont déclenchés :
versatile_thermostat_temperature_event
pour indiquer qu'un thermomètre ne répond plus,versatile_thermostat_preset_event
pour indiquer le passage en presetsecurity
,versatile_thermostat_hvac_mode_event
pour indiquer l'extinction éventuelle du thermostat
Chaque évènement porte les valeurs clés de l'évènement (températures, preset courant, puissance courante, ...) ainsi que les états du thermostat.
Vous pouvez très facilement capter ses évènements dans une automatisation par exemple pour notifier les utilisateurs.
Pour régler l'algorithme, vous avez accès à tout le contexte vu et calculé par le thermostat via des attributs dédiés. Vous pouvez voir (et utiliser) ces attributs dans l'IHM "Outils de développement / états" de HA. Entrez votre thermostat et vous verrez quelque chose comme ceci :
Les attributs personnalisés sont les suivants :
Attribut | Signification |
---|---|
hvac_modes |
La liste des modes supportés par le thermostat |
temp_min |
La température minimale |
temp_max |
La température maximale |
preset_modes |
Les préréglages visibles pour ce thermostat. Les préréglages cachés ne sont pas affichés ici |
temperature_actuelle |
La température actuelle telle que rapportée par le capteur |
temperature |
La température cible |
action_hvac |
L'action en cours d'exécution par le réchauffeur. Peut être inactif, chauffage |
preset_mode |
Le préréglage actuellement sélectionné. Peut être l'un des 'preset_modes' ou un préréglage caché comme power |
[eco/confort/boost]_temp |
La température configurée pour le préréglage xxx |
[eco/confort/boost]_away_temp |
La température configurée pour le préréglage xxx lorsque la présence est désactivée ou not_home |
temp_power |
La température utilisée lors de la détection de la perte |
on_percent |
Le pourcentage sur calculé par l'algorithme TPI |
on_time_sec |
La période On en sec. Doit être on_percent * cycle_min |
off_time_sec |
La période d'arrêt en sec. Doit être (1 - on_percent) * cycle_min |
cycle_min |
Le cycle de calcul en minutes |
function |
L'algorithme utilisé pour le calcul du cycle |
tpi_coef_int |
Le coef_int de l'algorithme TPI |
tpi_coef_ext |
Le coef_ext de l'algorithme TPI |
saved_preset_mode |
Le dernier preset utilisé avant le basculement automatique du preset |
saved_target_temp |
La dernière température utilisée avant la commutation automatique |
window_state |
Le dernier état connu du capteur de fenêtre. Aucun si la fenêtre n'est pas configurée |
window_bypass_state |
True si le bypass de la détection d'ouverture et activé |
motion_state |
Le dernier état connu du capteur de mouvement. Aucun si le mouvement n'est pas configuré |
overpowering_state |
Le dernier état connu du capteur surpuissant. Aucun si la gestion de l'alimentation n'est pas configurée |
presence_state |
Le dernier état connu du capteur de présence. Aucun si la gestion de présence n'est pas configurée |
security_delay_min |
Le délai avant d'activer le mode de sécurité lorsque un des 2 capteurs de température n'envoie plus de mesures |
security_min_on_percent |
Pourcentage de chauffe en dessous duquel le thermostat ne passera pas en sécurité |
security_default_on_percent |
Pourcentage de chauffe utilisé lorsque le thermostat est en sécurité |
last_temperature_datetime |
La date et l'heure au format ISO8866 de la dernière réception de température interne |
last_ext_temperature_datetime |
La date et l'heure au format ISO8866 de la dernière réception de température extérieure |
security_state |
L'état de sécurité. vrai ou faux |
minimal_activation_delay_sec |
Le délai d'activation minimal en secondes |
last_update_datetime |
La date et l'heure au format ISO8866 de cet état |
friendly_name |
Le nom du thermostat |
supported_features |
Une combinaison de toutes les fonctionnalités prises en charge par ce thermostat. Voir la documentation officielle sur l'intégration climatique pour plus d'informations |
valve_open_percent |
Le pourcentage d'ouverture de la vanne |
regulated_target_temperature |
La température de consigne calculée par l'auto-régulation |
is_inversed |
True si la commande est inversée (fil pilote avec diode) |
is_controlled_by_central_mode |
True si le VTherm peut être controlé de façon centrale |
last_central_mode |
Le dernier mode central utilisé (None si le VTherm n'est pas controlé en central) |
is_used_by_central_boiler |
Indique si le VTherm peut contrôler la chaudière centrale |
auto_start_stop_enable |
Indique si le VTherm est autorisé à s'auto démarrer/arrêter |
auto_start_stop_level |
Indique le niveau d'auto start/stop |
hvac_off_reason |
Indique la raison de l'arrêt (hvac_off) du VTherm. Ce peut être Window, Auto-start/stop ou Manuel |
Convergence de la température vers la cible configurée par preset:
Cycle de marche/arrêt calculé par l'intégration :
Coef_int trop élevé (oscillations autour de la cible)
Évolution du calcul de l'algorithme Voir le code de ce composant [ci-dessous]
Thermostat finement réglé Merci impuR_Shozz ! On peut voir une stabilité autour de la température cible (consigne) et lorsqu'à cible le on_percent (puissance) est proche de 0,3 ce qui semble une très bonne valeur.
Enjoy !
Une carte spéciale pour le Versatile Thermostat a été développée (sur la base du Better Thermostat). Elle est dispo ici Versatile Thermostat UI Card et propose une vision moderne de tous les status du VTherm :
Afin de profiter de toute la puissance du Versatile Thermostat, je vous invite à l'utiliser avec https://github.com/nielsfaber/scheduler-component En effet, le composant scheduler propose une gestion de la base climatique sur les modes prédéfinis. Cette fonctionnalité a un intérêt limité avec le thermostat générique mais elle devient très puissante avec le Versatile Thermostat :
À partir d'ici, je suppose que vous avez installé Versatile Thermostat et Scheduler Component.
Dans Scheduler, ajoutez un planning :
Choisissez le groupe "climat", choisissez une (ou plusieurs) entité(s), sélectionnez "MAKE SCHEME" et cliquez sur suivant : (il est possible de choisir "SET PRESET", mais je préfère utiliser "MAKE SCHEME")
Définissez votre schéma de mode et enregistrez :
Dans cet exemple, j'ai réglé le mode ECO pendant la nuit et le jour lorsqu'il n'y a personne à la maison BOOST le matin et CONFORT le soir.
J'espère que cet exemple vous aidera, n'hésitez pas à me faire part de vos retours !
Le custom:simple-thermostat
ici est une excellente intégration qui permet une certaine personnalisation qui s'adapte bien à ce thermostat.
Vous pouvez avoir quelque chose comme ça très facilement
Exemple de configuration :
type: custom:simple-thermostat
entity: climate.thermostat_sam2
layout:
step: row
label:
temperature: T°
state: Etat
hide:
state: false
control:
hvac:
_name: Mode
preset:
_name: Preset
sensors:
- entity: sensor.total_puissance_radiateur_sam2
icon: mdi:lightning-bolt-outline
header:
toggle:
entity: input_boolean.etat_ouverture_porte_sam
name: Porte sam
Vous pouvez personnaliser ce composant à l'aide du composant HACS card-mod pour ajuster les couleurs des alertes. Exemple pour afficher en rouge les alertes sécurité et délestage :
card_mod:
style: |
{% if is_state('binary_sensor.thermostat_chambre_security_state', 'on') %}
ha-card .body .sensor-heading ha-icon[icon="mdi:alert-outline"] {
color: red;
}
{% endif %}
{% if is_state('binary_sensor.thermostat_chambre_overpowering_state', 'on') %}
ha-card .body .sensor-heading ha-icon[icon="mdi:flash"] {
color: red;
}
{% endif %}
Vous pouvez obtenir une courbe comme celle présentée dans some results avec une sorte de configuration de graphique Plotly uniquement en utilisant les attributs personnalisés du thermostat décrits ici :
Remplacez les valeurs entre [[ ]] par les votres.
- type: custom:plotly-graph
entities:
- entity: '[[climate]]'
attribute: temperature
yaxis: y1
name: Consigne
- entity: '[[climate]]'
attribute: current_temperature
yaxis: y1
name: T°
- entity: '[[climate]]'
attribute: ema_temp
yaxis: y1
name: Ema
- entity: '[[climate]]'
attribute: regulated_target_temperature
yaxis: y1
name: Regulated T°
- entity: '[[slope]]'
name: Slope
fill: tozeroy
yaxis: y9
fillcolor: rgba(100, 100, 100, 0.3)
line:
color: rgba(100, 100, 100, 0.9)
hours_to_show: 4
refresh_interval: 10
height: 800
config:
scrollZoom: true
layout:
margin:
r: 50
legend:
x: 0
'y': 1.2
groupclick: togglegroup
title:
side: top right
yaxis:
visible: true
position: 0
yaxis9:
visible: true
fixedrange: false
range:
- -0.5
- 0.5
position: 1
xaxis:
rangeselector:
'y': 1.1
x: 0.7
buttons:
- count: 1
step: hour
- count: 12
step: hour
- count: 1
step: day
- count: 7
step: day
Exemple de courbes obtenues avec Plotly :
Cette automatisation utilise l'excellente App Daemon nommée NOTIFIER développée par Horizon Domotique que vous trouverez en démonstration ici et le code est ici. Elle permet de notifier les utilisateurs du logement lorsqu'un des évènements touchant à la sécurité survient sur un des Versatile Thermostats.
C'est un excellent exemple de l'utilisation des notifications décrites ici notification.
alias: Surveillance Mode Sécurité chauffage
description: Envoi une notification si un thermostat passe en mode sécurité ou power
trigger:
- platform: event
event_type: versatile_thermostat_security_event
id: versatile_thermostat_security_event
- platform: event
event_type: versatile_thermostat_power_event
id: versatile_thermostat_power_event
- platform: event
event_type: versatile_thermostat_temperature_event
id: versatile_thermostat_temperature_event
condition: []
action:
- choose:
- conditions:
- condition: trigger
id: versatile_thermostat_security_event
sequence:
- event: NOTIFIER
event_data:
action: send_to_jmc
title: >-
Radiateur {{ trigger.event.data.name }} - {{
trigger.event.data.type }} Sécurité
message: >-
Le radiateur {{ trigger.event.data.name }} est passé en {{
trigger.event.data.type }} sécurité car le thermomètre ne répond
plus.\n{{ trigger.event.data }}
callback:
- title: Stopper chauffage
event: stopper_chauffage
image_url: /media/local/alerte-securite.jpg
click_url: /lovelace-chauffage/4
icon: mdi:radiator-off
tag: radiateur_security_alerte
persistent: true
- conditions:
- condition: trigger
id: versatile_thermostat_power_event
sequence:
- event: NOTIFIER
event_data:
action: send_to_jmc
title: >-
Radiateur {{ trigger.event.data.name }} - {{
trigger.event.data.type }} Délestage
message: >-
Le radiateur {{ trigger.event.data.name }} est passé en {{
trigger.event.data.type }} délestage car la puissance max est
dépassée.\n{{ trigger.event.data }}
callback:
- title: Stopper chauffage
event: stopper_chauffage
image_url: /media/local/alerte-delestage.jpg
click_url: /lovelace-chauffage/4
icon: mdi:radiator-off
tag: radiateur_power_alerte
persistent: true
- conditions:
- condition: trigger
id: versatile_thermostat_temperature_event
sequence:
- event: NOTIFIER
event_data:
action: send_to_jmc
title: >-
Le thermomètre du radiateur {{ trigger.event.data.name }} ne
répond plus
message: >-
Le thermomètre du radiateur {{ trigger.event.data.name }} ne
répond plus depuis longtemps.\n{{ trigger.event.data }}
image_url: /media/local/thermometre-alerte.jpg
click_url: /lovelace-chauffage/4
icon: mdi:radiator-disabled
tag: radiateur_thermometre_alerte
persistent: true
mode: queued
max: 30
Si vous souhaitez contribuer, veuillez lire les directives de contribution
Utilisation d'un Heatzy
L'utilisation d'un Heatzy est possible à la condition d'utiliser un switch virtuel sur ce modèle :
- platform: template
switches:
chauffage_sdb:
unique_id: chauffage_sdb
friendly_name: Chauffage salle de bain
value_template: "{{ is_state_attr('climate.salle_de_bain', 'preset_mode', 'comfort') }}"
icon_template: >-
{% if is_state_attr('climate.salle_de_bain', 'preset_mode', 'comfort') %}
mdi:radiator
{% elif is_state_attr('climate.salle_de_bain', 'preset_mode', 'away') %}
mdi:snowflake
{% else %}
mdi:radiator-disabled
{% endif %}
turn_on:
service: climate.set_preset_mode
entity_id: climate.salle_de_bain
data:
preset_mode: "comfort"
turn_off:
service: climate.set_preset_mode
entity_id: climate.salle_de_bain
data:
preset_mode: "eco"
Merci à @gael pour cet exemple.
Utilisation d'un radiateur avec un fil pilote
Comme pour le Heatzy ci-dessus vous pouvez utiliser un switch virtuel qui va changer le preset de votre radiateur en fonction de l'état d'allumage du VTherm. Exemple :
- platform: template
switches:
radiateur_soan:
friendly_name: radiateur_soan_inv
value_template: "{{ is_state('switch.radiateur_soan', 'off') }}"
turn_on:
service: switch.turn_off
data:
entity_id: switch.radiateur_soan
turn_off:
service: switch.turn_on
data:
entity_id: switch.radiateur_soan
icon_template: "{% if is_state('switch.radiateur_soan', 'on') %}mdi:radiator-disabled{% else %}mdi:radiator{% endif %}"
Utilisation d'un radiateur avec un module Nodon
Comme pour le Heatzy ci-dessus vous pouvez utiliser un switch virtuel qui va changer le preset de votre radiateur en fonction de l'état d'allumage du VTherm. Exemple :
- platform: template
switches:
chauffage_chb_parents:
unique_id: chauffage_chb_parents
friendly_name: Chauffage chambre parents
value_template: "{{ is_state('select.fp_chb_parents_pilot_wire_mode', 'comfort') }}"
icon_template: >-
{% if is_state('select.fp_chb_parents_pilot_wire_mode', 'comfort') %}
mdi:radiator
{% elif is_state('select.fp_chb_parents_pilot_wire_mode', 'frost_protection') %}
mdi:snowflake
{% else %}
mdi:radiator-disabled
{% endif %}
turn_on:
service: select.select_option
target:
entity_id: select.fp_chb_parents_pilot_wire_mode
data:
option: comfort
turn_off:
service: select.select_option
target:
entity_id: select.fp_chb_parents_pilot_wire_mode
data:
option: eco
Seul le premier radiateur chauffe
En mode over_switch
si plusieurs radiateurs sont configurés pour un même VTherm, l'alllumage va se faire de façon séquentiel pour lisser au plus possible les pics de consommation.
Cela est tout à fait normal et voulu. C'est décrit ici : Pour un thermostat de type thermostat_over_switch
Le radiateur chauffe alors que la température de consigne est dépassée ou ne chauffe pas alors que la température de la pièce est bien en-dessous de la consigne
Le radiateur chauffe alors que la température de consigne est dépassée ou ne chauffe pas alors que la température de la pièce est bien en-dessous de la consigne
Avec un VTherm de type over_switch
ou over_valve
, ce défaut montre juste que les paramètres de l'algorithme TPI sont mal réglés. Voir Algorithme TPI pour optimiser les réglages.
Avec un VTherm de type over_climate
, la régulation est faite par le climate
sous-jacent directement et VTherm se contente de lui transmettre les consignes. Donc si le radiateur chauffe alors que la température de consigne est dépassée, c'est certainement que sa mesure de température interne est biaisée. Ca arrive très souvent avec les TRV et les clims réversibles qui ont un capteur de température interne, soit trop près de l'élément de chauffe (donc trop froid l'hiver).
Exemple de discussion autour de ces sujets: #348, #316, #312, #278
Pour s'en sortir, VTherm est équipé d'une fonction nommée auto-régulation qui permet d'adapter la consigne envoyée au sous-jacent jusqu'à ce que la consigne soit respectée. Cette fonction permet de compenser le biais de mesure des thermomètres internes. Si le biais est important la régulation doit être importante. Voir L'auto-régulation pour configurer l'auto-régulation.
Régler les paramètres de détection d'ouverture de fenêtre en mode auto
Si vous n'arrivez pas à régler la fonction de détection des ouvertures en mode auto (cf. auto), vous pouvez essayer de modifier les paramètres de l'algorithme de lissage de la température. En effet, la détection automatique d'ouverture est basée sur le calcul de la pente de la température (slope). Pour éviter les artefacts due à un capteur de température imprécis, cette pente est calculée sur une température lissée avec un algorithme de lissage nommée Exponential Moving Average (Moyenne mobile exponentielle). Cet algorithm possède 3 paramètres :
lifecycle_sec
: la durée en secondes prise en compte pour le lissage. Plus elle est forte et plus le lissage sera important mais plus il y aura de délai de détection,max_alpha
: si deux mesures de température sont éloignées dans le temps, la deuxième aura un poid beaucoup fort. Le paramètre permet de limiter le poid d'une mesure qui arrive bien après la précédente. Cette valeur doit être comprise entre 0 et 1. Plus elle est faible et moins les valeurs éloignées sont prises en compte. La valeur par défaut est de 0,5. Cela fait que lorsqu'une nouvelle valeur de température ne pèsera jamais plus que la moitié de la moyenne mobile,precision
: le nombre de chiffre après la virgule conservée pour le calcul de la moyenne mobile.
Pour changer ses paramètres, il faut modifier le fichier configuration.yaml
et ajouter la section suivante (les valeurs sont les valeurs par défaut):
versatile_thermostat:
short_ema_params:
max_alpha: 0.5
halflife_sec: 300
precision: 2
Ces paramètres sont sensibles et assez difficiles à régler. Merci de ne les utiliser que si vous savez ce que vous faites et que vos mesures de température ne sont pas déjà lisses.
Pourquoi mon Versatile Thermostat se met en Securite ?
Le mode sécurité est possible sur tous les types de VTherm . Il survient lorsqu'un des 2 thermomètres qui donne la température de la pièce ou la température extérieure n'a pas envoyé de valeur depuis plus de security_delay_min
minutes et que le radiateur chauffait à au moins security_min_on_percent
.
Comme l'algorithme est basé sur les mesures de température, si elles ne sont plus reçues par le VTherm, il y a un risque de surchauffe et d'incendie. Pour éviter ça, lorsque les conditions rappelées ci-dessus sont détectées, la chauffe est limité au paramètre security_default_on_percent
. Cette valeur doit donc être raisonnablement faible (10% est une bonne valeur). Elle permet d'éviter un incendie tout en évitant de couper totalement le radiateur (risque de gel).
Tous ces paramètres se règlent dans la dernière page de la configuration du VTherm : "Paramètres avancés".
Le premier symptôme est une température anormalement basse avec un temps de chauffe faible à chaque cycle et régulier. Exemple:
Si vous avez installé la carte Versatile Thermostat UI Card, le VTherm en question aura cette forme là :
Vous pouvez aussi vérifier dans les attributs du VTherm les dates de réception des différentes dates. Les attributs sont disponibles dans les Outils de développement / Etats.
Exemple :
security_state: true
last_temperature_datetime: "2023-12-06T18:43:28.346010+01:00"
last_ext_temperature_datetime: "2023-12-06T13:04:35.164367+01:00"
last_update_datetime: "2023-12-06T18:43:28.351103+01:00"
...
security_delay_min: 60
On voit que :
- le VTherm est bien en mode sécurité (
security_state: true
), - l'heure courante est le 06/12/2023 à 18h43:28 (
last_update_datetime: "2023-12-06T18:43:28.351103+01:00"
), - l'heure de dernière réception de la température intérieure est le 06/12/2023 à 18h43:28 (
last_temperature_datetime: "2023-12-06T18:43:28.346010+01:00"
). Elle est donc récente, - l'heure de dernière réception de la température extérieure est le 06/12/2023 à 13h04:35 (
last_ext_temperature_datetime: "2023-12-06T13:04:35.164367+01:00
). C'est donc l'heure extérieure qui a plus de 5 h de retard et qui a provoquée le passage en mode sécurité, car le seuil est limité à 60 min (security_delay_min: 60
).
Pour être averti, le VTherm envoie un évènement dès que ça se produit et un en fin d'alerte sécurité. Vous pouvez capter ces évènements dans une automatisation et envoyer une notification par exemple, faire clignoter un voyant, déclencher une sirène, ... A vous de voir.
Pour manipuler les évènements générés par le VTherm, cf. Eveènements.
Cela va dépendre de la cause du problème :
- Si un capteur est en défaut, il faut le réparer (remettre des piles, le changer, vérifier l'intégration Météo qui donne la température extérieure, ...),
- Si le paramètre
security_delay_min
est trop petit, cela rsique de générer beaucoup de fausses alertes. Une valeur correcte est de l'ordre de 60 min, surtout si vous avez des capteurs de température à pile. - Certains capteurs de température, n'envoie pas de mesure si la température n'a pas changée. Donc en cas de température très stable pendant longtemps, le mode sécurité peut se déclencher. Ce n'est pas très grave puisqu'il s'enlève dès que le VTherm reçoit à nouveau une température. Sur certain thermomètre (TuYA par exemple), on peut forcer le délai max entre 2 mesures. Il conviendra de mettre un délai max <
security_delay_min
, - Dès que la température sera a nouveau reçue le mode sécurité s'enlèvera et les valeurs précédentes de preset, température cible et mode seront restaurées.
Utilisation d'un groupe de personnes comme capteur de présence
Malheureusement, les groupes de personnes ne sont pas reconnus comme des capteurs de présence. On ne peut donc pas les utiliser directement dans VTherm. Le contournement est de créer un template de binary_sensor avec le code suivant :
Fichier template.yaml
:
- binary_sensor:
- name: maison_occupee
unique_id: maison_occupee
state: "{{is_state('person.person1', 'home') or is_state('person.person2', 'home') or is_state('input_boolean.force_presence', 'on')}}"
device_class: occupancy
Vous noterez dans cet exemple, l'utilisation d'un input_boolean nommé force_presence qui permet de forcer le capteur à True
et ainsi de forcer les VTherm qui l'utilise avec présence active. Ca permet par exemple, de forcer un pré-chauffage du logement lors du départ du travail, ou lorsqu'une personne non reconnue nativement dans HA est présente.
Fichier configuration.yaml
:
...
template: !include templates.yaml
...
Activer les logs du Versatile Thermostat
Des fois, vous aurez besoin d'activer les logs pour afiner les analyses. Pour cela, éditer le fichier logger.yaml
de votre configuration et configurer les logs comme suit :
default: xxxx
logs:
custom_components.versatile_thermostat: info
Vous devez recharger la configuration yaml (Outils de dev / Yaml / Toute la configuration Yaml) ou redémarrer Home Assistant pour que ce changement soit pris en compte.