Morg Ich habe gerade mal in den Daten der Vitosoft gestöbert und bin auf folgendes gestoßen,
Die "Datenpunkte" scheinen für falle Geräte gleich zu sein. Nur gibt es pro Gerät immer nur bestimmte. Die Interpretation z.B. enums sind aber unterschiedlich.
Wenn man sich die Demo der Vitosoft installiert, findet man eine Sql-Server-Datei durch die man die Zuordung von EventTypes (also die Datenpunkte) zu Geräten findet (mit Bedingungen wann welcher Datenpunkt da ist usw.)
Die Datenpunkte mit Blocklänge, Bitposition usw. sind dann in einer xml-Datei in C:\Program Files\Viessmann Vitosoft 300 SID1\ServiceTool\MobileClient\Config
Die Gruppierung gibt es dort auch in einer xml-Datei. Wass die Software genau nutzt weiß ich nicht.
Man können nun aus den Daten:
- Eine commands-py mit allen Datenpunkten
- pro Geräte eine struct-Datei für Items
generieren. Ein kleines Programm zum Stöbern findet man hier https://github.com/thelsing/viessman...r/viessmannAdr
Ich glaube man musste da Plugin für Geräteunabhängige Datenpunkte noch anpassen, oder?
Ankündigung
Einklappen
Keine Ankündigung bisher.
Viessmann Plugin Neuentwicklung Python Hilfe
Einklappen
X
-
So läuft nun erstmal ein bisschen mit. Allerdings lese ich auch nur Werte aus. Mal gucken, ob es zu Problemen kommt. Sieht aber erstmal gut aus. Danke für das neue Plugin.
Einen Kommentar schreiben:
-
Klar kannst Du die übernehmen. Das ist auch so gedacht und wenn alles mal läuft hätte ich sie dir sowieso nochmal geschickt. Anbei mal der aktuelle Stand. Wenn alles mal läuft, dann schicke ich sie Dir nochmal, damit Du sie mit aufnehmen kannst.
Habe den Fehler gefunden. Hatte an einer Stelle versehentlich eine 0 anstatt eines O geschrieben. Da konnte das Plugin natürlich nichts finden. Ist in dem unten genannten Code schon korrigiert.
Code:# !/usr/bin/env python # ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## # Copyright 2020 Michael Wenzel # ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## # Viessmann-Plugin for SmartHomeNG. https://github.com/smarthomeNG// # # This plugin is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This plugin is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this plugin. If not, see <http://www.gnu.org/licenses/>. # ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## ## controlset = { 'P300': { 'Baudrate': 4800, 'Bytesize': 8, # 'EIGHTBITS' 'Parity': 'E', # 'PARITY_EVEN', 'Stopbits': 2, # 'STOPBITS_TWO', 'StartByte': 0x41, 'Request': 0x00, 'Response': 0x01, 'Error': 0x03, 'Read': 0x01, 'Write': 0x02, 'Function_Call': 0x7, 'Acknowledge': 0x06, 'Not_initiated': 0x05, 'Init_Error': 0x15, 'Reset_Command': 0x04, 'Reset_Command_Response': 0x05, 'Sync_Command': 0x160000, 'Sync_Command_Response': 0x06, 'Command_bytes_read': 5, 'Command_bytes_write': 5, # init: send'Reset_Command' receive'Reset_Command_Response' send'Sync_Command' # request: send('StartByte' 'Länge der Nutzdaten als Anzahl der Bytes zwischen diesem Byte und der Prüfsumme' 'Request' 'Read' 'addr' 'checksum') # request_response: receive('Acknowledge' 'StartByte' 'Länge der Nutzdaten als Anzahl der Bytes zwischen diesem Byte und der Prüfsumme' 'Response' 'Read' 'addr' 'Anzahl der Bytes des Wertes' 'Wert' 'checksum') }, 'KW': { 'StartByte': 0x01, 'Read': 0xF7, 'Write': 0xF4, 'Acknowledge': 0x05, }, } commandset = { 'V200KO1B': { # Kessel 'Aussentemperatur': {'addr': '0800', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur 'Aussentemperatur_TP': {'addr': '5525', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur_tiefpass 'Aussentemperatur_Dp': {'addr': '5527', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur in Grad C (Gedaempft) 'Kesseltemperatur': {'addr': '0802', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesseltemperatur 'Kesseltemperatur_TP': {'addr': '0810', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesseltemperatur_tiefpass 'Kesselsolltemperatur': {'addr': '555A', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesselsolltemperatur 'Temp_Speicher_Ladesensor': {'addr': '0812', 'len': 2, 'unit': 'IU10', 'set': False}, # Temperatur Speicher Ladesensor Komfortsensor 'Auslauftemperatur': {'addr': '0814', 'len': 2, 'unit': 'IU10', 'set': False}, # Auslauftemperatur 'Abgastemperatur': {'addr': '0816', 'len': 2, 'unit': 'IU10', 'set': False}, # Abgastemperatur 'Gem_Vorlauftemperatur': {'addr': '081a', 'len': 2, 'unit': 'IU10', 'set': False}, # Gem. Vorlauftemperatur 'Relais_K12': {'addr': '0842', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Relais K12 Interne Anschlußerweiterung 'Eingang_0-10_V': {'addr': '0a86', 'len': 1, 'unit': 'IUINT', 'set': False}, # Eingang 0-10 V 'EA1_Kontakt_0': {'addr': '0a90', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # EA1: Kontakt 0 'EA1_Kontakt_1': {'addr': '0a91', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # EA1: Kontakt 1 'EA1_Kontakt_2': {'addr': '0a92', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # EA1: Kontakt 2 'EA1_Externer_Soll_0-10V': {'addr': '0a93', 'len': 1, 'unit': 'IUINT', 'set': False}, # EA1: Externer Sollwert 0-10V 'EA1_Relais_0': {'addr': '0a95', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # EA1: Relais 0 'AM1_Ausgang_1': {'addr': '0aa0', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # AM1 Ausgang 1 'AM1_Ausgang_2': {'addr': '0aa1', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # AM1 Ausgang 2 'TempKOffset': {'addr': '6760', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Kesseloffset KT ueber WWsoll in Grad C 'Systemtime': {'addr': '088E', 'len': 8, 'unit': 'TI', 'set': True}, # Systemzeit 'Anlagenschema': {'addr': '7700', 'len': 2, 'unit': 'SC', 'set': False}, # Anlagenschema 'DevType': {'addr': '00F8', 'len': 8, 'unit': 'DT', 'set': False}, # Heizungstyp 'Inventory': {'addr': '08E0', 'len': 7, 'unit': 'SN', 'set': False}, # Sachnummer 'CtrlId': {'addr': '08E0', 'len': 7, 'unit': 'DT', 'set': False}, # Reglerkennung # Fehler 'Sammelstoerung': {'addr': '0a82', 'len': 1, 'unit': 'RT', 'set': False}, # Sammelstörung 'Error0': {'addr': '7507', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 1 'Error1': {'addr': '7510', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 2 'Error2': {'addr': '7519', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 3 'Error3': {'addr': '7522', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 4 'Error4': {'addr': '752B', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 5 'Error5': {'addr': '7534', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 6 'Error6': {'addr': '753D', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 7 'Error7': {'addr': '7546', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 8 'Error8': {'addr': '754F', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 9 'Error9': {'addr': '7558', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 10 # Pumpen 'Speicherladepumpe': {'addr': '6513', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Speicherladepumpe 'Zirkulationspumpe': {'addr': '6515', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Zirkulationspumpe 'Interne_Pumpe': {'addr': '7660', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Interne Pumpe 'Heizkreispumpe_A1M1': {'addr': '2906', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Heizkreispumpe A1 'Heizkreispumpe_A1M1_RPM': {'addr': '7663', 'len': 1, 'unit': 'IUNON', 'set': False}, # Heizkreispumpe A1M1 Drehzahl 'Heizkreispumpe_M2': {'addr': '3906', 'len': 1, 'unit': 'IUINT', 'set': False}, # Heizkreispumpe M2 'Heizkreispumpe_M2_RPM': {'addr': '7665', 'len': 1, 'unit': 'IUNON', 'set': False}, # Heizkreispumpe M2 Drehzahl 'Relais_Status_Pumpe_A1M1': {'addr': 'a152', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Relais-Status Heizkreispumpe 1 # Brenner 'Brennerstarts': {'addr': '088a', 'len': 4, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brennerstarts 'Brenner_Betriebsstunden': {'addr': '08a7', 'len': 4, 'unit': 'IU3600', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brenner-Betriebsstunden 'Brennerstatus_1': {'addr': '0842', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Brennerstatus Stufe1 'Brennerstatus_2': {'addr': '0849', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Brennerstatus Stufe2 'Oeldurchsatz': {'addr': '5726', 'len': 4, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Oeldurchsatz Brenner in Dezi-Liter pro Stunde 'Oelverbrauch': {'addr': '7574', 'len': 4, 'unit': 'IS1000', 'set': True}, # Oelverbrauch kumuliert #Solar 'Nachladeunterdrueckung': {'addr': '6551', 'len': 1, 'unit': 'IUBOOL', 'set': False}, 'SolarPumpe': {'addr': '6552', 'len': 1, 'unit': 'IUBOOL', 'set': False}, 'Kollektortemperatur': {'addr': '6564', 'len': 2, 'unit': 'IS10', 'set': False}, 'Speichertemperatur': {'addr': '6566', 'len': 2, 'unit': 'IU10', 'set': False}, 'Solar_Betriebsstunden': {'addr': '6568', 'len': 4, 'unit': 'IU100', 'set': False}, 'Solarsteuerung': {'addr': '7754', 'len': 2, 'unit': 'IUINT', 'set': False}, # Heizkreis A1M1 'Raumtemperatur_A1M1': {'addr': '0896', 'len': 1, 'unit': 'ISNON', 'set': False}, # Raumtemperatur A1M1 'Raumtemperatur_Soll_Normalbetrieb_A1M1': {'addr': '2306', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Normalbetrieb A1M1 'Raumtemperatur_Soll_Red_Betrieb_A1M1': {'addr': '2307', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Reduzierter Betrieb A1M1 'Raumtemperatur_Soll_Party_Betrieb_A1M1': {'addr': '2308', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Party Betrieb A1M1 'Aktuelle_Betriebsart_A1M1': {'addr': '2301', 'len': 1, 'unit': 'BA', 'set': False}, # Aktuelle Betriebsart A1M1 'Betriebsart_A1M1': {'addr': '2323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Betriebsart A1M1 'Sparbetrieb_A1M1': {'addr': '2302', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Sparbetrieb A1M1 'Zustand_Sparbetrieb_A1M1': {'addr': '2331', 'len': 1, 'unit': 'IUINT', 'set': False}, # Zustand Sparbetrieb A1M1 'Partybetrieb_A1M1': {'addr': '2303', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Partybetrieb A1M1 'Zustand_Partybetrieb_A1M1': {'addr': '2330', 'len': 1, 'unit': 'IUINT', 'set': False}, # Zustand Partybetrieb A1M1 'Vorlauftemperatur_A1M1': {'addr': '2900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur A1M1 'Vorlauftemperatur_Soll_A1M1': {'addr': '2544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll A1M1 'StatusFrost_A1M1': {'addr': '2500', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Status Frostwarnung A1M1 'Externe_Raumsolltemperatur_Normal_A1M1': {'addr': '2321', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 37}, # Externe Raumsolltemperatur Normal A1M1 'Externe_Betriebsartenumschaltung_A1M1': {'addr': '2549', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Externe Betriebsartenumschaltung A1M1 'Speichervorrang_A1M1': {'addr': '27A2', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 15}, # Speichervorrang auf Heizkreispumpe und Mischer 'Frostschutzgrenze_A1M1': {'addr': '27A3', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -9, 'max_value': 15}, # Frostschutzgrenze 'Frostschutz_A1M1': {'addr': '27A4', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Frostschutzgrenze 'Heizkreispumpenlogik_A1M1': {'addr': '27A5', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 15}, # HeizkreispumpenlogikFunktion 'Sparschaltung_A1M1': {'addr': '27A6', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 5, 'max_value': 35}, # AbsolutSommersparschaltung 'Mischersparfunktion_A1M1': {'addr': '27A7', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Mischersparfunktion 'Pumpenstillstandzeit_A1M1': {'addr': '27A9', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 15}, # Pumpenstillstandzeit 'Vorlauftemperatur_min_A1M1': {'addr': '27C5', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 1, 'max_value': 127}, # Minimalbegrenzung der Vorlauftemperatur 'Vorlauftemperatur_max_A1M1': {'addr': '27C6', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 10, 'max_value': 127}, # Maximalbegrenzung der Vorlauftemperatur 'Neigung_Heizkennlinie_A1M1': {'addr': '27D3', 'len': 1, 'unit': 'IU10', 'set': True, 'min_value': 0.2, 'max_value': 3.5}, # Neigung Heizkennlinie A1M1 'Niveau_Heizkennlinie_A1M1': {'addr': '27D4', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -13, 'max_value': 40}, # Niveau Heizkennlinie A1M1 'Partybetrieb_Zeitbegrenzung_A1M1': {'addr': '27F2', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 12}, # Zeitliche Begrenzung für Partybetrieb oder externe BetriebsprogrammUmschaltung mit Taster 'Temperaturgrenze_red_Betrieb_A1M1': {'addr': '27F8', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -61, 'max_value': 10}, # Temperaturgrenze für Aufhebung des reduzierten Betriebs -5 ºC 'Temperaturgrenze_red_Raumtemp_A1M1': {'addr': '27F9', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -60, 'max_value': 10}, # Temperaturgrenze für Anhebung des reduzierten RaumtemperaturSollwertes 'Vorlauftemperatur_Erhoehung_Soll_A1M1': {'addr': '27FA', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 50}, # Erhöhung des Kesselwasser- bzw. Vorlauftemperatur-Sollwertes beim Übergang von Betrieb mit reduzierter Raumtemperatur in den Betrieb mit normaler Raumtemperatur um 20 % 'Vorlauftemperatur_Erhoehung_Zeit_A1M1': {'addr': '27FA', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 150}, # Zeitdauer für die Erhöhung des Kesselwasser bzw.VorlauftemperaturSollwertes (siehe Codieradresse „FA“) 60 min. # Heizkreis M2 'Raumtemperatur_M2': {'addr': '0898', 'len': 1, 'unit': 'ISNON', 'set': False}, # Raumtemperatur 'Raumtemperatur_Soll_Normalbetrieb_M2': {'addr': '3306', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Normalbetrieb 'Raumtemperatur_Soll_Red_Betrieb_M2': {'addr': '3307', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Reduzierter Betrieb 'Raumtemperatur_Soll_Party_Betrieb_M2': {'addr': '3308', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 3, 'max_value': 37}, # Raumtemperatur Soll Party Betrieb 'Aktuelle_Betriebsart_M2': {'addr': '3301', 'len': 1, 'unit': 'BA', 'set': False}, # Aktuelle Betriebsart 'Betriebsart_M2': {'addr': '3323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Betriebsart 'Sparbetrieb_M2': {'addr': '3302', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Sparbetrieb 'Zustand_Sparbetrieb_M2': {'addr': '3331', 'len': 1, 'unit': 'IUINT', 'set': False}, # Zustand Sparbetrieb 'Partybetrieb_M2': {'addr': '3303', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Partybetrieb 'Zustand_Partybetrieb_M2': {'addr': '3330', 'len': 1, 'unit': 'IUINT', 'set': False}, # Zustand Partybetrieb 'Vorlauftemperatur_M2': {'addr': '3900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur 'Vorlauftemperatur_Soll_M2': {'addr': '3544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll 'StatusFrost_M2': {'addr': '3500', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Status Frostwarnung 'Externe_Raumsolltemperatur_Normal_M2': {'addr': '3321', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 37}, # Externe Raumsolltemperatur Normal 'Externe_Betriebsartenumschaltung_M2': {'addr': '3549', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Externe Betriebsartenumschaltung 'Speichervorrang_M2': {'addr': '37A2', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 15}, # Speichervorrang auf Heizkreispumpe und Mischer 'Frostschutzgrenze_M2': {'addr': '37A3', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -9, 'max_value': 15}, # Frostschutzgrenze 'Frostschutz_M2': {'addr': '37A4', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Frostschutzgrenze 'Heizkreispumpenlogik_M2': {'addr': '37A5', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 15}, # HeizkreispumpenlogikFunktion 'Sparschaltung_M2': {'addr': '37A6', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 5, 'max_value': 35}, # AbsolutSommersparschaltung 'Mischersparfunktion_M2': {'addr': '37A7', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Mischersparfunktion 'Pumpenstillstandzeit_M2': {'addr': '37A9', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 15}, # Pumpenstillstandzeit 'Vorlauftemperatur_min_M2': {'addr': '37C5', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 1, 'max_value': 127}, # Minimalbegrenzung der Vorlauftemperatur 'Vorlauftemperatur_max_M2': {'addr': '37C6', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 10, 'max_value': 127}, # Maximalbegrenzung der Vorlauftemperatur 'Neigung_Heizkennlinie_M2': {'addr': '37D3', 'len': 1, 'unit': 'IU10', 'set': True, 'min_value': 0.2, 'max_value': 3.5}, # Neigung Heizkennlinie 'Niveau_Heizkennlinie_M2': {'addr': '37D4', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -13, 'max_value': 40}, # Niveau Heizkennlinie 'Partybetrieb_Zeitbegrenzung_M2': {'addr': '37F2', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 12}, # Zeitliche Begrenzung für Partybetrieb oder externe BetriebsprogrammUmschaltung mit Taster 'Temperaturgrenze_red_Betrieb_M2': {'addr': '37F8', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -61, 'max_value': 10}, # Temperaturgrenze für Aufhebung des reduzierten Betriebs -5 ºC 'Temperaturgrenze_red_Raumtemp_M2': {'addr': '37F9', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': -60, 'max_value': 10}, # Temperaturgrenze für Anhebung des reduzierten RaumtemperaturSollwertes 'Vorlauftemperatur_Erhoehung_Soll_M2': {'addr': '37FA', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 50}, # Erhöhung des Kesselwasser- bzw. Vorlauftemperatur-Sollwertes beim Übergang von Betrieb mit reduzierter Raumtemperatur in den Betrieb mit normaler Raumtemperatur um 20 % 'Vorlauftemperatur_Erhoehung_Zeit_M2': {'addr': '37Fb', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 150}, # Zeitdauer für die Erhöhung des Kesselwasser bzw.VorlauftemperaturSollwertes (siehe Codieradresse „FA“) 60 min. # Warmwasser 'Warmwasser_Temperatur': {'addr': '0804', 'len': 2, 'unit': 'IU10', 'set': False}, # Warmwassertemperatur in Grad C 'Warmwasser_Solltemperatur': {'addr': '6300', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 10, 'max_value': 95}, # Warmwasser-Solltemperatur 'Status_Warmwasserbereitung':{'addr': '650a', 'len': 1, 'unit': 'IUBOOL', 'set': True, 'min_value': 0, 'max_value': 1}, # Satus Warmwasserbereitung 'WarmwasserPumpenNachlauf': {'addr': '6762', 'len': 2, 'unit': 'ISNON' , 'set': True, 'min_value': 0, 'max_value': 1}, # Warmwasserpumpennachlauf # Ferienprogramm HK_A1M1 'Ferienprogramm_A1M1': {'addr': '2535', 'len': 1, 'unit': 'IUINT', 'set': False}, # Ferienprogramm A1M1 'Ferien_Abreisetag_A1M1': {'addr': '2309', 'len': 8, 'unit': 'DA', 'set': True}, # Ferien Abreisetag A1M1 'Ferien_Rückreisetag_A1M1': {'addr': '2311', 'len': 8, 'unit': 'DA', 'set': True}, # Ferien Rückreisetag A1M1 # Ferienprogramm HK_M2 'Ferienprogramm_M2': {'addr': '3535', 'len': 1, 'unit': 'IUINT', 'set': False}, # Ferienprogramm M2 'Ferien_Abreisetag_M2': {'addr': '3309', 'len': 8, 'unit': 'DA', 'set': True}, # Ferien Abreisetag M2 'Ferien_Rückreisetag_M2': {'addr': '3311', 'len': 8, 'unit': 'DA', 'set': True}, # Ferien Rückreisetag M2 # Schaltzeiten Warmwasser 'Timer_Warmwasser_Mo': {'addr': '2100', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Montag 'Timer_Warmwasser_Di': {'addr': '2108', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Dienstag 'Timer_Warmwasser_Mi': {'addr': '2110', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Mittwoch 'Timer_Warmwasser_Do': {'addr': '2118', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Donnerstag 'Timer_Warmwasser_Fr': {'addr': '2120', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Freitag 'Timer_Warmwasser_Sa': {'addr': '2128', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Samstag 'Timer_Warmwasser_So': {'addr': '2130', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Warmwasserbereitung Sonntag # Schaltzeiten HK_A1M1 'Timer_A1M1_Mo': {'addr': '2000', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Montag 'Timer_A1M1_Di': {'addr': '2008', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Dienstag 'Timer_A1M1_Mi': {'addr': '2010', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Mittwoch 'Timer_A1M1_Do': {'addr': '2018', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Donnerstag 'Timer_A1M1_Fr': {'addr': '2020', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Freitag 'Timer_A1M1_Sa': {'addr': '2028', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Samstag 'Timer_A1M1_So': {'addr': '2030', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Sonntag # Schaltzeiten HK_M2 'Timer_M2_Mo': {'addr': '3000', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Montag 'Timer_M2_Di': {'addr': '3008', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Dienstag 'Timer_M2_Mi': {'addr': '3010', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Mittwoch 'Timer_M2_Do': {'addr': '3018', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Donnerstag 'Timer_M2_Fr': {'addr': '3020', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Freitag 'Timer_M2_Sa': {'addr': '3028', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Samstag 'Timer_M2_So': {'addr': '3030', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Heizkreis_A1M1 Sonntag # Schaltzeiten Zirkulation 'Timer_Zirku_Mo': {'addr': '2200', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Montag 'Timer_Zirku_Di': {'addr': '2208', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Dienstag 'Timer_Zirku_Mi': {'addr': '2210', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Mittwoch 'Timer_Zirku_Do': {'addr': '2218', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Donnerstag 'Timer_Zirku_Fr': {'addr': '2220', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Freitag 'Timer_Zirku_Sa': {'addr': '2228', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Samstag 'Timer_Zirku_So': {'addr': '2230', 'len': 8, 'unit': 'CT', 'set': True}, # Timer Zirkulationspumpe Sonntag }, 'V200HO1C': { # Allgemein 'Frostgefahr': {'addr': '2510', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Frostgefahr 'Aussentemperatur_TP': {'addr': '5525', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur_tiefpass 'Aussentemperatur_Dp': {'addr': '5527', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur in Grad C (Gedaempft) 'Anlagenleistung': {'addr': 'a3af', 'len': 2, 'unit': 'IS10', 'set': False}, # Anlagenleistung # Kessel 'Kesseltemperatur_TP': {'addr': '0810', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesseltemperatur_tiefpass 'Kesselsolltemperatur': {'addr': '555A', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesselsolltemperatur 'Abgastemperatur': {'addr': '0816', 'len': 2, 'unit': 'IU10', 'set': False}, # Abgastemperatur # Fehler 'Sammelstoerung': {'addr': '0a82', 'len': 1, 'unit': 'RT', 'set': False}, # Sammelstörung 'Error0': {'addr': '7507', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 1 'Error1': {'addr': '7510', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 2 # Pumpen 'Speicherladepumpe': {'addr': '6513', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Speicherladepumpe für Warmwasser 'Zirkulationspumpe': {'addr': '6515', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Zirkulationspumpe 'Interne_Pumpe': {'addr': '7660', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Interne Pumpe 'Heizkreispumpe_HK1': {'addr': '2906', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Heizkreispumpe A1 'Heizkreispumpe_HK2': {'addr': '3906', 'len': 1, 'unit': 'IUINT', 'set': False}, # Heizkreispumpe M2 # Brenner 'Brennerstarts': {'addr': '088a', 'len': 4, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brennerstarts 'Brennerleistung': {'addr': 'a305', 'len': 2, 'unit': 'IS10', 'set': False}, # Brennerleistung 'Brenner_Betriebsstunden': {'addr': '08a7', 'len': 4, 'unit': 'IU3600', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brenner-Betriebsstunden #Solar 'SolarPumpe': {'addr': '6552', 'len': 1, 'unit': 'IUBOOL', 'set': False}, 'Kollektortemperatur': {'addr': '6564', 'len': 2, 'unit': 'IS10', 'set': False}, 'Speichertemperatur': {'addr': '6566', 'len': 2, 'unit': 'IU10', 'set': False}, 'Solar_Betriebsstunden': {'addr': '6568', 'len': 4, 'unit': 'IU100', 'set': False}, 'Solar_Waermemenge': {'addr': '6560', 'len': 2, 'unit': 'IUINT', 'set': False}, 'Solar_Ausbeute': {'addr': 'CF30', 'len': 4, 'unit': 'IUINT', 'set': False}, # Heizkreis 1 'Betriebsart_HK1': {'addr': '2500', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 3}, # Betriebsart (0=Abschaltbetrieb, 1=Red. Betrieb, 2=Normalbetrieb (Schaltuhr), 3=Normalbetrieb (Dauernd)) 'Heizart_HK1': {'addr': '2323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Heizart (0=Abschaltbetrieb, 1=Nur Warmwasser, 2=Heizen und Warmwasser, 3=Normalbetrieb (Dauernd)) 'Vorlauftemperatur_Soll_HK1': {'addr': '2544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll 'Vorlauftemperatur_HK1': {'addr': '2900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Ist # Heizkreis 2 'Betriebsart_HK2': {'addr': '3500', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 3}, # Betriebsart (0=Abschaltbetrieb, 1=Red. Betrieb, 2=Normalbetrieb (Schaltuhr), 3=Normalbetrieb (Dauernd)) 'Heizart_HK2': {'addr': '3323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Heizart (0=Abschaltbetrieb, 1=Nur Warmwasser, 2=Heizen und Warmwasser, 3=Normalbetrieb (Dauernd)) 'Vorlauftemperatur_Soll_HK2': {'addr': '3544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll 'Vorlauftemperatur_HK2': {'addr': '3900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Ist # Warmwasser 'Warmwasser_Temperatur': {'addr': '0812', 'len': 2, 'unit': 'IU10', 'set': False}, # Warmwassertemperatur in Grad C 'Warmwasser_Solltemperatur': {'addr': '6300', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 10, 'max_value': 95}, # Warmwasser-Solltemperatur 'Warmwasser_Austrittstemperatur': {'addr': '0814', 'len': 2, 'unit': 'IU10', 'set': False}, # Warmwasseraustrittstemperatur in Grad C }, 'V200WO1C': { # generelle Infos 'Anlagentyp': {'addr': '00F8', 'len': 2, 'unit': 'DT', 'set': False}, # getAnlTyp -- Information - Allgemein: Anlagentyp (204D) 'Aussentemperatur': {'addr': '0101', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempA -- Information - Allgemein: Aussentemperatur (-40..70) # Anlagenstatus 'Betriebsart': {'addr': 'B000', 'len': 1, 'unit': 'BA', 'set': True}, # getBetriebsart -- Bedienung HK1 - Heizkreis 1: Betriebsart (Textstring) 'Manuell': {'addr': 'B020', 'len': 1, 'unit': 'IUNON', 'set': True, 'min_value': 0, 'max_value': 2}, # getManuell / setManuell -- 0 = normal, 1 = manueller Heizbetrieb, 2 = 1x Warmwasser auf Temp2 'Sekundaerpumpe': {'addr': '0484', 'len': 1, 'unit': 'RT', 'set': False}, # getStatusSekP -- Diagnose - Anlagenuebersicht: Sekundaerpumpe 1 (0..1) 'Heizkreispumpe': {'addr': '048D', 'len': 1, 'unit': 'RT', 'set': False}, # getStatusPumpe -- Information - Heizkreis HK1: Heizkreispumpe (0..1) 'Zirkulationspumpe': {'addr': '0490', 'len': 1, 'unit': 'RT', 'set': False}, # getStatusPumpeZirk -- Information - Warmwasser: Zirkulationspumpe (0..1) 'VentilHeizenWW': {'addr': '0494', 'len': 1, 'unit': 'RT', 'set': False}, # getStatusVentilWW -- Diagnose - Waermepumpe: 3-W-Ventil Heizen WW1 (0 (Heizen)..1 (WW)) 'Vorlaufsolltemp': {'addr': '1800', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempVLSoll -- Diagnose - Heizkreis HK1: Vorlaufsolltemperatur HK1 (0..95) 'Outdoor_Fanspeed': {'addr': '1A52', 'len': 1, 'unit': 'IUNON', 'set': False}, # getSpdFanOut -- Outdoor Fanspeed 'Status_Fanspeed': {'addr': '1A53', 'len': 1, 'unit': 'IUNON', 'set': False}, # getSpdFan -- Geschwindigkeit Luefter 'Kompressor_Freq': {'addr': '1A54', 'len': 1, 'unit': 'IUNON', 'set': False}, # getSpdKomp -- Compressor Frequency # Temperaturen 'SolltempWarmwasser': {'addr': '6000', 'len': 2, 'unit': 'IS10', 'set': True, 'min_value': 10, 'max_value': 60}, # getTempWWSoll -- Bedienung WW - Betriebsdaten WW: Warmwassersolltemperatur (10..60 (95)) 'VorlauftempSek': {'addr': '0105', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempSekVL -- Information - Heizkreis HK1: Vorlauftemperatur Sekundaer 1 (0..95) 'RuecklauftempSek': {'addr': '0106', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempSekRL -- Diagnose - Anlagenuebersicht: Ruecklauftemperatur Sekundaer 1 (0..95) 'Warmwassertemperatur': {'addr': '010d', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempWWIstOben -- Information - Warmwasser: Warmwassertemperatur oben (0..95) # Stellwerte 'Raumsolltemp': {'addr': '2000', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempRaumSollNormal -- Bedienung HK1 - Heizkreis 1: Raumsolltemperatur normal (10..30) 'RaumsolltempReduziert': {'addr': '2001', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempRaumSollRed -- Bedienung HK1 - Heizkreis 1: Raumsolltemperatur reduzierter Betrieb (10..30) 'HeizkennlinieNiveau': {'addr': '2006', 'len': 2, 'unit': 'IS10', 'set': False}, # getHKLNiveau -- Bedienung HK1 - Heizkreis 1: Niveau der Heizkennlinie (-15..40) 'HeizkennlinieNeigung': {'addr': '2007', 'len': 2, 'unit': 'IS10', 'set': False}, # getHKLNeigung -- Bedienung HK1 - Heizkreis 1: Neigung der Heizkennlinie (0..35) 'RaumsolltempParty': {'addr': '2022', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempRaumSollParty -- Bedienung HK1 - Heizkreis 1: Party Solltemperatur (10..30) # Statistiken / Laufzeiten 'EinschaltungenSekundaer': {'addr': '0504', 'len': 4, 'unit': 'IUNON', 'set': False}, # getAnzQuelleSek -- Statistik - Schaltzyklen Anlage: Einschaltungen Sekundaerquelle (?) 'EinschaltungenHeizstab1': {'addr': '0508', 'len': 4, 'unit': 'IUNON', 'set': False}, # getAnzHeizstabSt1 -- Statistik - Schaltzyklen Anlage: Einschaltungen Heizstab Stufe 1 (?) 'EinschaltungenHeizstab2': {'addr': '0509', 'len': 4, 'unit': 'IUNON', 'set': False}, # getAnzHeizstabSt2 -- Statistik - Schaltzyklen Anlage: Einschaltungen Heizstab Stufe 2 (?) 'EinschaltungenHK': {'addr': '050D', 'len': 4, 'unit': 'IUNON', 'set': False}, # getAnzHK -- Statistik - Schaltzyklen Anlage: Einschaltungen Heizkreis (?) 'LZSekundaerpumpe': {'addr': '0584', 'len': 4, 'unit': 'IU3600', 'set': False}, # getLZPumpeSek -- Statistik - Betriebsstunden Anlage: Betriebsstunden Sekundaerpumpe (?) 'LZHeizstab1': {'addr': '0588', 'len': 4, 'unit': 'IU3600', 'set': False}, # getLZHeizstabSt1 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Heizstab Stufe 1 (?) 'LZHeizstab2': {'addr': '0589', 'len': 4, 'unit': 'IU3600', 'set': False}, # getLZHeizstabSt2 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Heizstab Stufe 2 (?) 'LZPumpeHK': {'addr': '058D', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZPumpe -- Statistik - Betriebsstunden Anlage: Betriebsstunden Pumpe HK1 (0..1150000) 'LZWWVentil': {'addr': '0594', 'len': 4, 'unit': 'IU3600', 'set': False}, # getLZVentilWW -- Statistik - Betriebsstunden Anlage: Betriebsstunden Warmwasserventil (?) 'LZVerdichterStufe1': {'addr': '1620', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZVerdSt1 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Verdichter auf Stufe 1 (?) 'LZVerdichterStufe2': {'addr': '1622', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZVerdSt2 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Verdichter auf Stufe 2 (?) 'LZVerdichterStufe3': {'addr': '1624', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZVerdSt3 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Verdichter auf Stufe 3 (?) 'LZVerdichterStufe4': {'addr': '1626', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZVerdSt4 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Verdichter auf Stufe 4 (?) 'LZVerdichterStufe5': {'addr': '1628', 'len': 4, 'unit': 'IUNON', 'set': False}, # getLZVerdSt5 -- Statistik - Betriebsstunden Anlage: Betriebsstunden Verdichter auf Stufe 5 (?) 'VorlauftempSekMittel': {'addr': '16B2', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempSekVLMittel -- Statistik - Energiebilanz: mittlere sek. Vorlauftemperatur (0..95) 'RuecklauftempSekMittel': {'addr': '16B3', 'len': 2, 'unit': 'IS10', 'set': False}, # getTempSekRLMittel -- Statistik - Energiebilanz: mittlere sek.Temperatur RL1 (0..95) 'OAT_Temperature': {'addr': '1A5C', 'len': 1, 'unit': 'IUNON', 'set': False}, # getTempOAT -- OAT Temperature 'ICT_Temperature': {'addr': '1A5D', 'len': 1, 'unit': 'IUNON', 'set': False}, # getTempICT -- OCT Temperature 'CCT_Temperature': {'addr': '1A5E', 'len': 1, 'unit': 'IUNON', 'set': False}, # getTempCCT -- CCT Temperature 'HST_Temperature': {'addr': '1A5F', 'len': 1, 'unit': 'IUNON', 'set': False}, # getTempHST -- HST Temperature 'OMT_Temperature': {'addr': '1A60', 'len': 1, 'unit': 'IUNON', 'set': False}, # getTempOMT -- OMT Temperature 'LZVerdichterWP': {'addr': '5005', 'len': 4, 'unit': 'IU3600', 'set': False}, # getLZWP -- Statistik - Betriebsstunden Anlage: Betriebsstunden Waermepumpe (0..1150000) 'SollLeistungVerdichter': {'addr': '5030', 'len': 1, 'unit': 'IUNON', 'set': False}, # getPwrSollVerdichter -- Diagnose - Anlagenuebersicht: Soll-Leistung Verdichter 1 (0..100) 'WaermeWW12M': {'addr': '1660', 'len': 4, 'unit': 'IU10', 'set': False}, # Wärmeenergie für WW-Bereitung der letzten 12 Monate (kWh) 'ElektroWW12M': {'addr': '1670', 'len': 4, 'unit': 'IU10', 'set': False}, # elektr. Energie für WW-Bereitung der letzten 12 Monate (kWh) }, } unitset = { 'P300': { 'BA': {'unit_de': 'Betriebsart', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: BA 'CT': {'unit_de': 'CycleTime', 'type': 'timer', 'signed': False, 'read_value_transform': 'non'}, # vito unit: CT 'DT': {'unit_de': 'DeviceType', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: DT 'ES': {'unit_de': 'ErrorState', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: ES 'IU2': {'unit_de': 'INT unsigned 2', 'type': 'integer', 'signed': False, 'read_value_transform': '2'}, # vito unit: UT1U, PR1 'IU10': {'unit_de': 'INT unsigned 10', 'type': 'integer', 'signed': False, 'read_value_transform': '10'}, # vito unit: 'IU100': {'unit_de': 'INT unsigned 100', 'type': 'integer', 'signed': False, 'read_value_transform': '100'}, # vito unit: 'IU3600': {'unit_de': 'INT unsigned 3600', 'type': 'integer', 'signed': False, 'read_value_transform': '3600'}, # vito unit: CS 'IUBOOL': {'unit_de': 'INT unsigned bool', 'type': 'integer', 'signed': False, 'read_value_transform': 'bool'}, # vito unit: 'IUINT': {'unit_de': 'INT unsigned int', 'type': 'integer', 'signed': False, 'read_value_transform': 'int'}, # vito unit: 'IUNON': {'unit_de': 'INT unsigned non', 'type': 'integer', 'signed': False, 'read_value_transform': 'non'}, # vito unit: UTI, CO 'IS2': {'unit_de': 'INT signed 2', 'type': 'integer', 'signed': True, 'read_value_transform': '2'}, # vito unit: UT1, PR 'IS10': {'unit_de': 'INT signed 10', 'type': 'integer', 'signed': True, 'read_value_transform': '10'}, # vito unit: UT, UN 'IS100': {'unit_de': 'INT signed 100', 'type': 'integer', 'signed': True, 'read_value_transform': '100'}, # vito unit: 'IS1000': {'unit_de': 'INT signed 1000', 'type': 'integer', 'signed': True, 'read_value_transform': '1000'}, # vito unit: 'ISNON': {'unit_de': 'INT signed non', 'type': 'integer', 'signed': True, 'read_value_transform': 'non'}, # vito unit: 'RT': {'unit_de': 'ReturnStatus', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: ST, RT 'SC': {'unit_de': 'SystemScheme', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: 'SN': {'unit_de': 'Sachnummer', 'type': 'serial', 'signed': False, 'read_value_transform': 'non'}, # vito unit: 'SR': {'unit_de': 'SetReturnStatus', 'type': 'list', 'signed': False, 'read_value_transform': 'non'}, # vito unit: 'TI': {'unit_de': 'SystemTime', 'type': 'datetime', 'signed': False, 'read_value_transform': 'non'}, # vito unit: TI 'DA': {'unit_de': 'Date', 'type': 'date', 'signed': False, 'read_value_transform': 'non'}, # vito unit: } } errorset = { 'P300': { '00': 'Regelbetrieb (kein Fehler)', '0F': 'Wartung (fuer Reset Codieradresse 24 auf 0 stellen)', '10': 'Kurzschluss Aussentemperatursensor', '18': 'Unterbrechung Aussentemperatursensor', '20': 'Kurzschluss Vorlauftemperatursensor', '21': 'Kurzschluss Ruecklauftemperatursensor', '28': 'Unterbrechung Aussentemperatursensor', '29': 'Unterbrechung Ruecklauftemperatursensor', '30': 'Kurzschluss Kesseltemperatursensor', '38': 'Unterbrechung Kesseltemperatursensor', '40': 'Kurzschluss Vorlauftemperatursensor M2', '42': 'Unterbrechung Vorlauftemperatursensor M2', '50': 'Kurzschluss Speichertemperatursensor', '58': 'Unterbrechung Speichertemperatursensor', '92': 'Solar: Kurzschluss Kollektortemperatursensor', '93': 'Solar: Kurzschluss Sensor S3', '94': 'Solar: Kurzschluss Speichertemperatursensor', '9A': 'Solar: Unterbrechung Kollektortemperatursensor', '9B': 'Solar: Unterbrechung Sensor S3', '9C': 'Solar: Unterbrechung Speichertemperatursensor', '9E': 'Solar: Zu geringer bzw. kein Volumenstrom oder Temperaturwächter ausgeloest', '9F': 'Solar: Fehlermeldung Solarteil (siehe Solarregler)', 'A7': 'Bedienteil defekt', 'B0': 'Kurzschluss Abgastemperatursensor', 'B1': 'Kommunikationsfehler Bedieneinheit', 'B4': 'Interner Fehler (Elektronik)', 'B5': 'Interner Fehler (Elektronik)', 'B6': 'Ungueltige Hardwarekennung (Elektronik)', 'B7': 'Interner Fehler (Kesselkodierstecker)', 'B8': 'Unterbrechung Abgastemperatursensor', 'B9': 'Interner Fehler (Dateneingabe wiederholen)', 'BA': 'Kommunikationsfehler Erweiterungssatz fuer Mischerkreis M2', 'BC': 'Kommunikationsfehler Fernbedienung Vitorol, Heizkreis M1', 'BD': 'Kommunikationsfehler Fernbedienung Vitorol, Heizkreis M2', 'BE': 'Falsche Codierung Fernbedienung Vitorol', 'C1': 'Externe Sicherheitseinrichtung (Kessel kuehlt aus)', 'C2': 'Kommunikationsfehler Solarregelung', 'C5': 'Kommunikationsfehler drehzahlgeregelte Heizkreispumpe, Heizkreis M1', 'C6': 'Kommunikationsfehler drehzahlgeregelte Heizkreispumpe, Heizkreis M2', 'C7': 'Falsche Codierung der Heizkreispumpe', 'C9': 'Stoermeldeeingang am Schaltmodul-V aktiv', 'CD': 'Kommunikationsfehler Vitocom 100 (KM-BUS)', 'CE': 'Kommunikationsfehler Schaltmodul-V', 'CF': 'Kommunikationsfehler LON Modul', 'D1': 'Brennerstoerung', 'D4': 'Sicherheitstemperaturbegrenzer hat ausgeloest oder Stoermeldemodul nicht richtig gesteckt', 'DA': 'Kurzschluss Raumtemperatursensor, Heizkreis M1', 'DB': 'Kurzschluss Raumtemperatursensor, Heizkreis M2', 'DD': 'Unterbrechung Raumtemperatursensor, Heizkreis M1', 'DE': 'Unterbrechung Raumtemperatursensor, Heizkreis M2', 'E4': 'Fehler Versorgungsspannung', 'E5': 'Interner Fehler (Ionisationselektrode)', 'E6': 'Abgas- / Zuluftsystem verstopft', 'F0': 'Interner Fehler (Regelung tauschen)', 'F1': 'Abgastemperaturbegrenzer ausgeloest', 'F2': 'Temperaturbegrenzer ausgeloest', 'F3': 'Flammensigal beim Brennerstart bereits vorhanden', 'F4': 'Flammensigal nicht vorhanden', 'F7': 'Differenzdrucksensor defekt', 'F8': 'Brennstoffventil schliesst zu spaet', 'F9': 'Geblaesedrehzahl beim Brennerstart zu niedrig', 'FA': 'Geblaesestillstand nicht erreicht', 'FD': 'Fehler Gasfeuerungsautomat', 'FE': 'Starkes Stoerfeld (EMV) in der Naehe oder Elektronik defekt', 'FF': 'Starkes Stoerfeld (EMV) in der Naehe oder interner Fehler' }, } operatingmodes = { 'V200KW2': { '0': 'Abschaltbetrieb', '1': 'Warmwasserbetrieb', '2': 'Heiz- und Warmwasserbetrieb', '4': 'Dauerbetrieb, reduziert', '5': 'Dauerbetrieb, normal', }, 'V200KO1B': { '00': 'Warmwasser (Schaltzeiten)', '01': 'reduziert Heizen (dauernd)', '02': 'normal Heizen (dauernd)', '04': 'Heizen und Warmwasser (FS)', '03': 'Heizen und Warmwasser (Schaltzeiten)', '05': 'Standby', }, 'aktuelle_Betriebsart': { '00': 'Abschaltbetrieb', '01': 'Reduzierter Betrieb', '02': 'Normalbetrieb', '03': 'Dauernd Normalbetrieb', }, 'V200WO1C': { '00': 'Abschaltbetrieb', '01': 'Warmwasser', '02': 'Heizen und Warmwasser', '03': 'undefiniert', '04': 'dauernd reduziert', '05': 'dauernd normal', '06': 'normal Abschalt', '07': 'nur kühlen', }, 'V200HO1C': { '00': 'Abschaltbetrieb', '01': 'Warmwasser', '02': 'Heizen und Warmwasser', '03': 'Normal reduziert', '04': 'Normal dauernd' } } systemschemes = { 'V200KO1B': { '01': 'A1', '02': 'A1 + WW', '04': 'M2', '03': 'M2 + WW', '05': 'A1 + M2', '06': 'A1 + M2 + WW' }, 'V200WO1C': { '01': 'WW', '02': 'HK + WW', '04': 'HK + WW', '05': 'HK + WW' }, 'V200HO1C': { '01': 'WW', '02': 'HK + WW', '04': 'HK + WW', '05': 'HK + WW' } } devicetypes = { '2098': 'V200KW2, Protokoll: KW2', '2053': 'GWG_VBEM, Protokoll: GWG', '20CB': 'VScotHO1, Protokoll: P300', '2094': 'V200KW1, Protokoll: KW2', '209F': 'V200KO1B, Protokoll: P300, KW2', '204D': 'V200WO1C, Protokoll: P300', '20B8': 'V333MW1, Protokoll: ', '20A0': 'V100GC1, Protokoll: ', '20C2': 'VDensHO1, Protokoll: ', '20A4': 'V200GW1, Protokoll: ', '20C8': 'VPlusHO1, Protokoll: ', '2046': 'V200WO1,VBC700, Protokoll: ', '2047': 'V200WO1,VBC700, Protokoll: ', '2049': 'V200WO1,VBC700, Protokoll: ', '2032': 'VBC550, Protokoll: ', '2033': 'VBC550, Protokoll: ' } returnstatus = { 'P300': { '00': '0', '01': '1', '03': '2', 'AA': 'NOT OK', # At least for device 20CB the heating circuit pump returns status 03 when it's on and the heating runs in in night mode }, } setreturnstatus = { 'P300': { '00': 'OK', '05': 'SYNC (NOT OK)', }, } # P300 Protokoll # # Beispiel # # Senden 41 5 0 1 55 25 2 82 # Read Request -- - - - ----- - -- # | | | | | | +------- Prüfsumme (Summe über alley Bytes ohne die 41; [hex]5+0+1+55+25+2 = [dez]5+0+1+(5x16)+5+(2x16)+5+2 = 130dez = 82hex # | | | | | +---------- XX Anzahl der Bytes, die in der Antwort erwartet werden # | | | | +-------------- XX XX 2 byte Adresse der Daten oder Prozedur # | | | +------------------ XX 01 = ReadData, 02 = WriteData, 07 = Function Call # | | +-------------------- XX 00 = Anfrage, 01 = Antwort, 03 = Fehler # | +---------------------- Länge der Nutzdaten (Anzahl der Bytes zwischen dem Telegramm-Start-Byte (0x41) und der Prüfsumme) # +------------------------ Telegramm-Start-Byte # # Empfangen : 6 ----------------------- OK (Antwort auf 0x16 0x00 0x00 und auf korrekt empfangene Telegramme) # 5 ----------------------- Schnittstelle ist aktiv und wartet auf eine Initialisierung # 15 ----------------------- Schnittstelle meldet einen Fehler zurück # # 41 7 1 1 55 25 2 EF 0 74 # -- - - - ----- - ---- -- # | | | | | | | +-- Prüfsumme (Summe über alley Bytes ohne die 41; [hex]7+1+1+55+25+2+EF+0 = [dez]7+1+1+(5x16)+5+(2x16)+5+2+(14*16)+(15*16)+0 = [dez]7+1+1+(80)+5+(32)+5+2+(224)+(15)+0 = 372dez = 1.74hex) # | | | | | | +------ Wert # | | | | | +---------- XX Anzahl der Bytes, die in der Antwort erwartet werden # | | | | +-------------- XX XX 2 byte Adresse der Daten oder Prozedur # | | | +------------------ XX 01 = ReadData, 02 = WriteData, 07 = Function Call # | | +-------------------- XX 00 = Anfrage, 01 = Antwort, 03 = Fehler # | +---------------------- Länge der Nutzdaten (Anzahl der Bytes zwischen dem Telegramm-Start-Byte (0x41) und der Prüfsumme) # +------------------------ Telegramm-Start-Byte # Kommunikationsbeispiele # Information Kessel Außentemperatur read 2-Byte -60..60 0x5525 # DATA TX: 41 5 0 1 55 25 2 82 # DATA RX: 41 7 1 1 55 25 2 EF 0 74 --> 00EF = 239 --> 23.9°C (Faktor 0.1) # --> Senden 41 5 0 1 55 25 2 82 # -- - - - ----- - -- # | | | | | | +-- Prüfsumme (Summe über alley Bytes ohne die 41; [hex]5+0+1+55+25+2 = [dez]5+0+1+(5x16)+5+(2x16)+5+2 = 130dez = 82hex # | | | | | +----- XX Anzahl der Bytes, die in der Antwort erwartet werden # | | | | +--------- XX XX 2 byte Adresse der Daten oder Prozedur # | | | +------------- XX 01 = ReadData, 02 = WriteData, 07 = Function Call # | | +--------------- XX 00 = Anfrage, 01 = Antwort, 03 = Fehler # | +----------------- Länge der Nutzdaten (Anzahl der Bytes zwischen dem Telegramm-Start-Byte (0x41) und der Prüfsumme) # +------------------- Telegramm-Start-Byte # # --> Empfangen 6 41 7 1 1 55 25 2 EF 0 74 # - -- - - - ----- - ---- -- # | | | | | | | | +-- Prüfsumme (Summe über alley Bytes ohne die 41; [hex]7+1+1+55+25+2+EF+0 = [dez]7+1+1+(5x16)+5+(2x16)+5+2+(14*16)+(15*16)+0 = [dez]7+1+1+(80)+5+(32)+5+2+(224)+(15)+0 = 372dez = 1.74hex) # | | | | | | | +------ Wert # | | | | | | +---------- XX Anzahl der Bytes, die in der Antwort erwartet werden # | | | | | +-------------- XX XX 2 byte Adresse der Daten oder Prozedur # | | | | +------------------ XX 01 = ReadData, 02 = WriteData, 07 = Function Call # | | | +-------------------- XX 00 = Anfrage, 01 = Antwort, 03 = Fehler # | | +---------------------- Länge der Nutzdaten (Anzahl der Bytes zwischen dem Telegramm-Start-Byte (0x41) und der Prüfsumme) # | +------------------------ Telegramm-Start-Byte # +--------------------------- OK (Antwort auf 0x16 0x00 0x00 und auf korrekt empfangene Telegramme) # # --> Antwort: 0x00EF = 239 = 23.9°Zuletzt geändert von loeserman; 27.06.2020, 13:20.
Einen Kommentar schreiben:
-
Ich vermute stark, dass deine commands.py Fehler hat. Kannst du die mal komplett posten? Wenn du nix dagegen hast, übernehme ich dann deine Heizung gleich mit ins Plugin; das lebt ja auch von Erweiterungen.
Einen Kommentar schreiben:
-
Doch!, den Thread dazu hatte ich erwähnt.Zitat von loeserman Beitrag anzeigeneine Einrückungen mit in dieses Forum hier.
Einen Kommentar schreiben:
-
Nein habe ich schon normal eingerückt. Daran düfte es nicht liegen. Allerdings überträgt der bei mir bei STRG-C und STRG-V keine Einrückungen mit in dieses Forum hier. Daher muss man die Leerzeichen alle händisch nachziehen. Das wollte ich mir sparen. Habe das oben mal gemacht. Hoffe es ist nun besser lesbar.Zitat von Msinn Beitrag anzeigenOder hast Du die yaml Dateien wirklich ohne Einrückungen erstellt?
Danke für die Hilfe mit dem richtigen Code Import … das vereinfacht die Sache enorm.
Gäbe es Fehler bei der items.yaml, dann hätte eigentlich auch die Fehlermeldung anders aussehen müssen. Die besagt ja, dass das Item keinen korrespondierenden Eintrag im commandset findet. Das item aus der config hat er ja dann eigentlich lese können, oder?Zuletzt geändert von loeserman; 27.06.2020, 12:05.
Einen Kommentar schreiben:
-
Wie wäre es, wenn Du Deine Konfiguration in lesbarer Form postest? Oder hast Du die yaml Dateien wirklich ohne Einrückungen erstellt?
Siehe auch diesen Thread: Hilfe zu SmartHomeNG erhalten --> Python Code und Yaml Konfig richtig einfügen
Einen Kommentar schreiben:
-
Moin zusammen,
nun hatte ich mal etwas Zeit und habe mich ans Werk gemacht. Leider scheitere ich noch recht am Anfang. Vielleicht habt ihr einen Tipp für mich. Ich habe eine Vitodens343-F und eine V200HO1C Steuerung, die über P300 plaudert.
Daher habe ich die commands.py angepasst mit einer neuen Sektion
Anschließend habe ich eine item.yaml dafür erstelltCode:commandset = { 'V200KO1B': { # Kessel ... }, 'V200H01C': { # Allgemein 'Frostgefahr': {'addr': '2510', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Frostgefahr 'Aussentemperatur_TP': {'addr': '5525', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur_tiefpass 'Aussentemperatur_Dp': {'addr': '5527', 'len': 2, 'unit': 'IU10', 'set': False}, # Aussentemperatur in Grad C (Gedaempft) 'Anlagenleistung': {'addr': 'a3af', 'len': 2, 'unit': 'IS10', 'set': False}, # Anlagenleistung # Kessel 'Kesseltemperatur_TP': {'addr': '0810', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesseltemperatur_tiefpass 'Kesselsolltemperatur': {'addr': '555A', 'len': 2, 'unit': 'IU10', 'set': False}, # Kesselsolltemperatur 'Abgastemperatur': {'addr': '0816', 'len': 2, 'unit': 'IU10', 'set': False}, # Abgastemperatur # Fehler 'Sammelstoerung': {'addr': '0a82', 'len': 1, 'unit': 'RT', 'set': False}, # Sammelstörung 'Error0': {'addr': '7507', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 1 'Error1': {'addr': '7510', 'len': 9, 'unit': 'ES', 'set': False}, # Fehlerhistory Eintrag 2 # Pumpen 'Speicherladepumpe': {'addr': '6513', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Speicherladepumpe für Warmwasser 'Zirkulationspumpe': {'addr': '6515', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Zirkulationspumpe 'Interne_Pumpe': {'addr': '7660', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Interne Pumpe 'Heizkreispumpe_HK1': {'addr': '2906', 'len': 1, 'unit': 'IUBOOL', 'set': False}, # Heizkreispumpe A1 'Heizkreispumpe_HK2': {'addr': '3906', 'len': 1, 'unit': 'IUINT', 'set': False}, # Heizkreispumpe M2 # Brenner 'Brennerstarts': {'addr': '088a', 'len': 4, 'unit': 'ISNON', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brennerstarts 'Brennerleistung': {'addr': 'a305', 'len': 2, 'unit': 'IS10', 'set': False}, # Brennerleistung 'Brenner_Betriebsstunden': {'addr': '08a7', 'len': 4, 'unit': 'IU3600', 'set': True, 'min_value': 0, 'max_value': 1193045}, # Brenner-Betriebsstunden #Solar 'SolarPumpe': {'addr': '6552', 'len': 1, 'unit': 'IUBOOL', 'set': False}, 'Kollektortemperatur': {'addr': '6564', 'len': 2, 'unit': 'IS10', 'set': False}, 'Speichertemperatur': {'addr': '6566', 'len': 2, 'unit': 'IU10', 'set': False}, 'Solar_Betriebsstunden': {'addr': '6568', 'len': 4, 'unit': 'IU100', 'set': False}, 'Solar_Waermemenge': {'addr': '6560', 'len': 2, 'unit': 'IUINT', 'set': False}, 'Solar_Ausbeute': {'addr': 'CF30', 'len': 4, 'unit': 'IUINT', 'set': False}, # Heizkreis 1 'Betriebsart_HK1': {'addr': '2500', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 3}, # Betriebsart (0=Abschaltbetrieb, 1=Red. Betrieb, 2=Normalbetrieb (Schaltuhr), 3=Normalbetrieb (Dauernd)) 'Heizart_HK1': {'addr': '2323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Heizart (0=Abschaltbetrieb, 1=Nur Warmwasser, 2=Heizen und Warmwasser, 3=Normalbetrieb (Dauernd)) 'Vorlauftemperatur_Soll_HK1': {'addr': '2544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll 'Vorlauftemperatur_HK1': {'addr': '2900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Ist # Heizkreis 2 'Betriebsart_HK2': {'addr': '3500', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 3}, # Betriebsart (0=Abschaltbetrieb, 1=Red. Betrieb, 2=Normalbetrieb (Schaltuhr), 3=Normalbetrieb (Dauernd)) 'Heizart_HK2': {'addr': '3323', 'len': 1, 'unit': 'IUINT', 'set': True, 'min_value': 0, 'max_value': 4}, # Heizart (0=Abschaltbetrieb, 1=Nur Warmwasser, 2=Heizen und Warmwasser, 3=Normalbetrieb (Dauernd)) 'Vorlauftemperatur_Soll_HK2': {'addr': '3544', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Soll 'Vorlauftemperatur_HK2': {'addr': '3900', 'len': 2, 'unit': 'IU10', 'set': False}, # Vorlauftemperatur Ist # Warmwasser 'Warmwasser_Temperatur': {'addr': '0812', 'len': 2, 'unit': 'IU10', 'set': False}, # Warmwassertemperatur in Grad C 'Warmwasser_Solltemperatur': {'addr': '6300', 'len': 1, 'unit': 'ISNON', 'set': True, 'min_value': 10, 'max_value': 95}, # Warmwasser-Solltemperatur 'Warmwasser_Austrittstemperatur': {'addr': '0814', 'len': 2, 'unit': 'IU10', 'set': False}, # Warmwasseraustrittstemperatur in Grad C }, ... } ... operatingmodes = { 'V200KW2': { ... }, ... 'V200H01C': { '00': 'Abschaltbetrieb', '01': 'Warmwasser', '02': 'Heizen und Warmwasser', '03': 'Normal reduziert', '04': 'Normal dauernd' } } systemschemes = { 'V200KO1B': { ... }, ... 'V200HO1C': { '01': 'WW', '02': 'HK + WW', '04': 'HK + WW', '05': 'HK + WW' } }
Und dann natürlich noch die Plugins.yaml angepasstCode:viessmann: type: foo viessmann_update: name: Update aller Items mit 'viess_read' type: bool visu_acl: rw viess_update: 1 autotimer: 1 = 0 Allgemein: Frostgefahr: name: Frostgefahr type: bool viess_read: Frostgefahr viess_read_cycle: 300 viess_init: true database: true Aussentemperatur_TP: name: Aussentemperatur_TP type: num viess_read: Aussentemperatur_TP viess_read_cycle: 300 viess_init: true database: true Aussentemperatur_Dp: name: Aussentemperatur_Dp type: num viess_read: Aussentemperatur_Dp viess_read_cycle: 300 viess_init: true database: true Anlagenleistung: name: Anlagenleistung type: num viess_read: Anlagenleistung viess_read_cycle: 60 viess_init: true database: true Kessel: Kesseltemperatur_TP: name: Kesseltemperatur_TP type: num viess_read: Kesseltemperatur_TP viess_read_cycle: 180 viess_init: true database: init Kesselsolltemperatur: name: Kesselsolltemperatur type: num viess_read: Kesselsolltemperatur viess_read_cycle: 180 viess_init: true Abgastemperatur: name: Abgastemperatur type: num viess_read: Abgastemperatur viess_read_cycle: 180 viess_init: true database: init Stoerungen: Sammelstoerung: name: Sammelstoerung type: num viess_read: Sammelstoerung viess_read_cycle: 3600 viess_init: true database: true Error_1: name: Fehlerhistory Eintrag 1 type: foo viess_read: Error0 viess_read_cycle: 3600 viess_init: true Error_2: name: Fehlerhistory Eintrag 2 type: foo viess_read: Error1 viess_read_cycle: 3600 viess_init: true Brenner: Brennerstarts: name: Brennerstarts type: num viess_read: Brennerstarts viess_read_cycle: 300 viess_init: true database: true Brenner_Betriebsstunden: name: Brenner_Betriebsstunden type: num viess_read: Brenner_Betriebsstunden viess_read_cycle: 300 viess_init: true database: true Betrieb_2_Starts: name: Betriebsstunden / Brennertstarts type: num eval: round(sh...Brenner_Betriebsstunden() / sh...Brennerstarts(), 2) eval_trigger: - ..Brenner_Betriebsstunden - ..Brennerstarts database: true Brennerleistung: name: Brennerleistung type: num viess_read: Brennerleistung viess_read_cycle: 60 viess_init: true database: true
Starte ich das ganze erhalte ich folgende Fehlermeldungen. Habt ihr eine Idee, was ich vergessen habe?Code:viessmann: plugin_name: viessmann plugin_enabled: true protocol: P300 plugin_name: viessmann heating_type: V200H01C serialport: /dev/ttyUSB_HEIZUNG
Er erkennt kein einiges Item laut commandset. Ist glaube ich was einfaches, aber ich sehe es einfach nicht …Code:2020-06-27 12:58:55 ERROR lib.item Item viessmann.Allgemein.Frostgefahr: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Allgemein.Aussentemperatur_TP: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Allgemein.Aussentemperatur_Dp: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Allgemein.Anlagenleistung: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Kessel.Kesseltemperatur_TP: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Kessel.Kesselsolltemperatur: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Kessel.Abgastemperatur: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Stoerungen.Sammelstoerung: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Stoerungen.Error_1: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Stoerungen.Error_2: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Brenner.Brennerstarts: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Brenner.Brenner_Betriebsstunden: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset' 2020-06-27 12:58:55 ERROR lib.item Item viessmann.Brenner.Brennerleistung: problem creating: 'Viessmann' object has no attribute '_commandset' Traceback (most recent call last): File "/usr/local/smarthome/lib/item.py", line 683, in __init__ child = Item(smarthome, self, child_path, value) File "/usr/local/smarthome/lib/item.py", line 748, in __init__ update = plugin.parse_item(self) File "/usr/local/smarthome/plugins/viessmann/__init__.py", line 193, in parse_item if commandname is None or commandname not in self._commandset: AttributeError: 'Viessmann' object has no attribute '_commandset'
Danke euch!Zuletzt geändert von loeserman; 27.06.2020, 12:03.
Einen Kommentar schreiben:
-
Konntest Du schon testen?Zitat von loeserman Beitrag anzeigenStimmt, da war noch etwas. Okay ich versuche das mal bei mir einzubinden. Wo finde ich denn die letzte Version?
Einen Kommentar schreiben:
-
Hab ich!Zitat von Morg Beitrag anzeigenKannst du gern noch mal probieren, aber wenn ich sehe, wie der im Moment auf Fehler reagiert, dürfte das keine Überraschungen mehr geben
Hier Auszüge aus dem develop log:
Heizung aus; Er sendet trotzdem die Anfragen, bekommt keine Antwort, verwirft das und geht zur nächsten Anfrage
Irgendwann ist das Communication_init abgelaufen, es wird versucht die Comminication neu zu etablieren:Code:2020-06-25 20:56:24 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Speicherladepumpe 2020-06-25 20:56:24 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IUBOOL', 'addr': '6513', 'len': 1, 'set': False} 2020-06-25 20:56:24 DEBUG plugins.viessmann _send_read_command Preparing command Speicherladepumpe with packet to be sent as hexstring: 410500016513017f and as bytes: bytearray(b'A\x05\x00\x01e\x13\x01\x7f') 2020-06-25 20:56:24 DEBUG plugins.viessmann _send_command Successfully sent packet: 410500016513017f 2020-06-25 20:56:24 DEBUG plugins.viessmann _send_command Trying to receive 10 bytes of the response. 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_command Received 0 bytes chunk of response as hexstring and as bytes b'' 2020-06-25 20:56:25 ERROR plugins.viessmann _send_command Received 0 bytes chunk - ignoring response_packet! chunk was: b'' 2020-06-25 20:56:25 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Relais_K12 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Relais_K12 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IUBOOL', 'addr': '0842', 'len': 1, 'set': False} 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_read_command Preparing command Relais_K12 with packet to be sent as hexstring: 4105000108420151 and as bytes: bytearray(b'A\x05\x00\x01\x08B\x01Q') 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_command Successfully sent packet: 4105000108420151 2020-06-25 20:56:25 DEBUG plugins.viessmann _send_command Trying to receive 10 bytes of the response. 2020-06-25 20:56:26 DEBUG plugins.viessmann _send_command Received 0 bytes chunk of response as hexstring and as bytes b'' 2020-06-25 20:56:26 ERROR plugins.viessmann _send_command Received 0 bytes chunk - ignoring response_packet! chunk was: b''
Heizung wieder an, dann klappt auch das Communication_init und es geht normal weiter.Code:2020-06-25 21:03:24 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IUBOOL', 'addr': '6513', 'len': 1, 'set': False} 2020-06-25 21:03:24 DEBUG plugins.viessmann _send_read_command Preparing command Speicherladepumpe with packet to be sent as hexstring: 410500016513017f and as bytes: bytearray(b'A\x05\x00\x01e\x13\x01\x7f') 2020-06-25 21:03:24 INFO plugins.viessmann _send_command Communication timed out, trying to reestablish communication. 2020-06-25 21:03:24 INFO plugins.viessmann _init_communication Init Communication.... 2020-06-25 21:03:24 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:25 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:25 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:26 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:26 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:27 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:27 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:28 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:28 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:29 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:29 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:30 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:30 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:31 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:31 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:32 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:32 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:33 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:33 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:34 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:34 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:35 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:35 INFO plugins.viessmann _init_communication Communication initialized: False 2020-06-25 21:03:35 ERROR plugins.viessmann _send_command send_command failed with error: Interface not initialized!. 2020-06-25 21:03:35 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Relais_K12 2020-06-25 21:03:35 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Relais_K12 2020-06-25 21:03:35 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IUBOOL', 'addr': '0842', 'len': 1, 'set': False} 2020-06-25 21:03:35 DEBUG plugins.viessmann _send_read_command Preparing command Relais_K12 with packet to be sent as hexstring: 4105000108420151 and as bytes: bytearray(b'A\x05\x00\x01\x08B\x01Q') 2020-06-25 21:03:35 WARNING plugins.viessmann _send_command Communication no longer initialized, trying to reestablish. 2020-06-25 21:03:35 INFO plugins.viessmann _init_communication Init Communication.... 2020-06-25 21:03:35 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:36 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:36 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:37 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:37 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:38 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:38 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:39 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:39 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:40 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:40 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:41 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:41 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:42 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:42 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:43 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:43 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:44 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:44 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:45 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:45 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:03:46 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:03:46 INFO plugins.viessmann _init_communication Communication initialized: False 2020-06-25 21:03:46 ERROR plugins.viessmann _send_command send_command failed with error: Interface not initialized!.
Klappt also.Code:2020-06-25 21:12:17 INFO plugins.viessmann _init_communication Communication initialized: False 2020-06-25 21:12:17 ERROR plugins.viessmann _send_command send_command failed with error: Interface not initialized!. 2020-06-25 21:12:17 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Error7 2020-06-25 21:12:17 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Error7 2020-06-25 21:12:17 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'ES', 'addr': '7546', 'len': 9, 'set': False} 2020-06-25 21:12:17 DEBUG plugins.viessmann _send_read_command Preparing command Error7 with packet to be sent as hexstring: 41050001754609ca and as bytes: bytearray(b'A\x05\x00\x01uF\t\xca') 2020-06-25 21:12:17 WARNING plugins.viessmann _send_command Communication no longer initialized, trying to reestablish. 2020-06-25 21:12:17 INFO plugins.viessmann _init_communication Init Communication.... 2020-06-25 21:12:17 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:12:18 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 21:12:18 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 21:12:19 DEBUG plugins.viessmann _init_communication read_bytes: read b'\x05', last byte is b'\x05' 2020-06-25 21:12:19 DEBUG plugins.viessmann _init_communication send_bytes: Send sync command b'\x16\x00\x00' 2020-06-25 21:12:19 DEBUG plugins.viessmann _init_communication read_bytes: read b'\x06', last byte is b'\x06' 2020-06-25 21:12:19 DEBUG plugins.viessmann _init_communication Device acknowledged initialization 2020-06-25 21:12:19 INFO plugins.viessmann _init_communication Communication initialized: True 2020-06-25 21:12:19 DEBUG plugins.viessmann _send_command Successfully sent packet: 41050001754609ca 2020-06-25 21:12:19 DEBUG plugins.viessmann _send_command Trying to receive 18 bytes of the response. 2020-06-25 21:12:19 DEBUG plugins.viessmann _send_command Received 18 bytes chunk of response as hexstring 06410e010175460900202001200120034099 and as bytes b'\x06A\x0e\x01\x01uF\t\x00 \x01 \x01 \x03@\x99' 2020-06-25 21:12:19 DEBUG plugins.viessmann _parse_response Response decoded to: commandcode: 7546, responsedatacode: 1, valuebytecount: 9 2020-06-25 21:12:19 DEBUG plugins.viessmann _parse_response Rawdatabytes formatted: 002020012001200340 and unformatted: bytearray(b'\x00 \x01 \x01 \x03@') 2020-06-25 21:12:19 DEBUG plugins.viessmann _parse_response Corresponding Item: heizung.allgemein.stoerungen.error_8; Corresponding commandname: Error7 2020-06-25 21:12:19 DEBUG plugins.viessmann _parse_response Unit defined to ES with config {'read_value_transform': 'non', 'signed': False, 'type': 'list', 'unit_de': 'ErrorState'}. 2020-06-25 21:12:19 DEBUG plugins.viessmann _parse_response Matched command Error7 and read transformed errorcode Regelbetrieb (kein Fehler) (raw value was 00) and byte length 9. 2020-06-25 21:12:19 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Error9
Das passiert (meist) nur einmal beim Neustart des Plugins bzw. wenn der cyclic-Scheduler neu gesetzt wird. Wahrscheinlich dauert der erste Aufruf zu lange, wenn alle zyklischen Items abgefragt werden.Zitat von Morg Beitrag anzeigen2020-06-25 18:55:19 WARNING plugins.viessmann send_cyclic_cmds Triggered cyclic command read, but previous cyclic run is still active. Check device and cyclic configuration (too much/too short?)
Wieder ein Stück näher am Release.
Einen Kommentar schreiben:
-
Zitat von Sisamiwe Beitrag anzeigenWoran siehst Du das?
Laut Log dauert die Abfrage nicht so lange.
Auszug aus dem Log:
Code:plugins.viessmann send_cyclic_cmds cyclic command read took 1.7 seconds for 8 items plugins.viessmann send_cyclic_cmds cyclic command read took 1.9 seconds for 9 items plugins.viessmann send_cyclic_cmds cyclic command read took 2.4 seconds for 11 items plugins.viessmann send_cyclic_cmds cyclic command read took 3.3 seconds for 16 items
Das passiert offensichtlich im Fehlerfall. Ob da was hängt und dann den Disconnect verursacht, oder ob der Disconnect den cyclic read zum Hängen bringt, kann ich so noch nicht erkennen. Letzteres sollte (!) eigentlich durch die geänderte Fehlererkennung nicht passieren...Code:2020-06-25 18:55:19 WARNING plugins.viessmann send_cyclic_cmds Triggered cyclic command read, but previous cyclic run is still active. Check device and cyclic configuration (too much/too short?)
Kannst du gern noch mal probieren, aber wenn ich sehe, wie der im Moment auf Fehler reagiert, dürfte das keine Überraschungen mehr gebenIch melde mich wieder, wenn ich die Heizung mal aus hatte.
Einen Kommentar schreiben:
-
Bislang nicht, da der E/A Fehler immer im Betrieb auftrat. Aber eben sporadisch. Ich habe aber den RPI in Verdacht bzw. das sich irgendwelche "Aufgaben" blockieren bzw. die Schnittstelle.Zitat von Morg Beitrag anzeigenDu hast aber die Heizung nicht ausgehabt?
Ich schalte die Heizung dann mal aus und schaue was passiert.
Das gab es bei mir von Beginn an. Stört auch nicht, wenn der Fehler erkannt wird und die Verbindung resettet und neu aufgebaut.Zitat von Morg Beitrag anzeigenIrgendwo scheint bei dir noch der Wurm drin, den EA-Fehler hatte ich noch nie
Woran siehst Du das?Zitat von Morg Beitrag anzeigenGleichzeitig irritiert mich, dass deine cyclic scheduler runs anscheinend hängen - der braucht ja über eine Minute, und selbst (gerade) bei Fehlern sollte das mMn schneller gehen. Das kann ich hier aber nicht nachvollziehen. Selbst mit Timeout braucht er max. 20 Sekunden.
Laut Log dauert die Abfrage nicht so lange.
Auszug aus dem Log:
Code:plugins.viessmann send_cyclic_cmds cyclic command read took 1.7 seconds for 8 items plugins.viessmann send_cyclic_cmds cyclic command read took 1.9 seconds for 9 items plugins.viessmann send_cyclic_cmds cyclic command read took 2.4 seconds for 11 items plugins.viessmann send_cyclic_cmds cyclic command read took 3.3 seconds for 16 items
In den letzten Versionen hat der Neuaufbau der Verbindung nicht mehr geklappt. Nun scheint es wieder zu funktionieren.Zitat von Morg Beitrag anzeigenAnsonsten sieht das in Bezug auf Recovery schon gut aus; selbst wenn er rausfliegt, erkennt er das, verbindet neu und macht weiter. So soll das ja im Prinzip auch sein.
Ich melde mich wieder, wenn ich die Heizung mal aus hatte.
Einen Kommentar schreiben:
-
Du hast aber die Heizung nicht ausgehabt? Irgendwo scheint bei dir noch der Wurm drin, den EA-Fehler hatte ich noch nie, nichtmal bei ausgeschalteter Heizung.
Gleichzeitig irritiert mich, dass deine cyclic scheduler runs anscheinend hängen - der braucht ja über eine Minute, und selbst (gerade) bei Fehlern sollte das mMn schneller gehen. Das kann ich hier aber nicht nachvollziehen. Selbst mit Timeout braucht er max. 20 Sekunden.
Ansonsten sieht das in Bezug auf Recovery schon gut aus; selbst wenn er rausfliegt, erkennt er das, verbindet neu und macht weiter. So soll das ja im Prinzip auch sein. Mich würde echt mal interessieren, ob bei dir ein anderer Lesekopf ggf. anderes Verhalten zeigen würde. Ich hab nur keinen übrig
Einen Kommentar schreiben:
-
Hallo,
ich habe die letzte/aktuelle Version von Morg im Test gehabt. Nach 4 Tagen fehlerfrei kam heute mal wieder ein Verbindungsabriss mit dem E/A Fehler. Der Wiederaufbau der Verbindung hat aber geklappt. Die Logs:
warning:
details:Code:2020-06-25 18:55:19 ERROR plugins.viessmann send_command failed with IO error: IO Error: write failed: [Errno 5] Eingabe-/Ausgabefehler. 2020-06-25 18:55:19 ERROR plugins.viessmann Trying to reconnect (disconnecting, connecting 2020-06-25 18:55:19 ERROR plugins.viessmann Not connected, trying to reconnect. 2020-06-25 18:55:19 WARNING plugins.viessmann Communication no longer initialized, trying to reestablish.
develop:Code:2020-06-25 18:55:19 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Brenner_Betriebsstunden 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command send_command failed with IO error: IO Error: write failed: [Errno 5] Eingabe-/Ausgabefehler. 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command Trying to reconnect (disconnecting, connecting 2020-06-25 18:55:19 INFO plugins.viessmann _disconnect Disconnected 2020-06-25 18:55:19 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Aussentemperatur 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command Not connected, trying to reconnect. 2020-06-25 18:55:19 INFO plugins.viessmann _connect Connecting ... 2020-06-25 18:55:19 INFO plugins.viessmann _connect Connected to /dev/ttyUSB_optolink 2020-06-25 18:55:19 INFO plugins.viessmann _create_cyclic_scheduler Added cyclic worker thread (60 sec cycle). Shortest item update cycle found: 120 sec. 2020-06-25 18:55:19 WARNING plugins.viessmann _send_command Communication no longer initialized, trying to reestablish. 2020-06-25 18:55:19 INFO plugins.viessmann _init_communication Init Communication.... 2020-06-25 18:55:19 WARNING plugins.viessmann send_cyclic_cmds Triggered cyclic command read, but previous cyclic run is still active. Check device and cyclic configuration (too much/too short?) 2020-06-25 18:55:21 INFO plugins.viessmann _init_communication Communication initialized: True 2020-06-25 18:55:21 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Kesseltemperatur 2020-06-25 18:55:21 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Aussentemperatur_TP 2020-06-25 18:55:21 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Abgastemperatur
Ich beobachte weiter.Code:2020-06-25 18:55:19 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Brenner_Betriebsstunden 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Brenner_Betriebsstunden 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IU3600', 'max_value': 1193045, 'set': True, 'addr': '08a7', 'min_value': 0, 'len': 4} 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Preparing command Brenner_Betriebsstunden with packet to be sent as hexstring: 4105000108a704b9 and as bytes: bytearray(b'A\x05\x00\x01\x08\xa7\x04\xb9') 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command send_command failed with IO error: IO Error: write failed: [Errno 5] Eingabe-/Ausgabefehler. 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command Trying to reconnect (disconnecting, connecting 2020-06-25 18:55:19 DEBUG plugins.viessmann scheduler_get scheduler_get: name = plugins.viessmann.cyclic 2020-06-25 18:55:19 DEBUG plugins.viessmann scheduler_remove scheduler_remove: name = plugins.viessmann.cyclic 2020-06-25 18:55:19 INFO plugins.viessmann _disconnect Disconnected 2020-06-25 18:55:19 INFO plugins.viessmann send_cyclic_cmds Triggering cyclic read command: Aussentemperatur 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Got a new read job: Command Aussentemperatur 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Command config: {'unit': 'IU10', 'addr': '0800', 'len': 2, 'set': False} 2020-06-25 18:55:19 DEBUG plugins.viessmann _send_read_command Preparing command Aussentemperatur with packet to be sent as hexstring: 4105000108000210 and as bytes: bytearray(b'A\x05\x00\x01\x08\x00\x02\x10') 2020-06-25 18:55:19 ERROR plugins.viessmann _send_command Not connected, trying to reconnect. 2020-06-25 18:55:19 INFO plugins.viessmann _connect Connecting ... 2020-06-25 18:55:19 INFO plugins.viessmann _connect Connected to /dev/ttyUSB_optolink 2020-06-25 18:55:19 DEBUG plugins.viessmann scheduler_get scheduler_get: name = plugins.viessmann.cyclic 2020-06-25 18:55:19 DEBUG plugins.viessmann scheduler_get scheduler_get: name = plugins.viessmann.cyclic 2020-06-25 18:55:19 DEBUG plugins.viessmann scheduler_add scheduler_add: name = plugins.viessmann.cyclic, parameters: prio=5, cycle=60 2020-06-25 18:55:19 INFO plugins.viessmann _create_cyclic_scheduler Added cyclic worker thread (60 sec cycle). Shortest item update cycle found: 120 sec. 2020-06-25 18:55:19 WARNING plugins.viessmann _send_command Communication no longer initialized, trying to reestablish. 2020-06-25 18:55:19 INFO plugins.viessmann _init_communication Init Communication.... 2020-06-25 18:55:19 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 18:55:19 DEBUG plugins.viessmann _init_communication read_bytes: read b'\x06', last byte is b'\x06' 2020-06-25 18:55:19 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 18:55:19 WARNING plugins.viessmann send_cyclic_cmds Triggered cyclic command read, but previous cyclic run is still active. Check device and cyclic configuration (too much/too short?) 2020-06-25 18:55:20 DEBUG plugins.viessmann _init_communication read_bytes: read b'', last byte is b'' 2020-06-25 18:55:20 DEBUG plugins.viessmann _init_communication send_bytes: Send reset command b'\x04' 2020-06-25 18:55:21 DEBUG plugins.viessmann _init_communication read_bytes: read b'\x05', last byte is b'\x05' 2020-06-25 18:55:21 DEBUG plugins.viessmann _init_communication send_bytes: Send sync command b'\x16\x00\x00' 2020-06-25 18:55:21 DEBUG plugins.viessmann _init_communication read_bytes: read b'\x06', last byte is b'\x06' 2020-06-25 18:55:21 DEBUG plugins.viessmann _init_communication Device acknowledged initialization 2020-06-25 18:55:21 INFO plugins.viessmann _init_communication Communication initialized: True 2020-06-25 18:55:21 DEBUG plugins.viessmann _send_command Successfully sent packet: 4105000108000210 2020-06-25 18:55:21 DEBUG plugins.viessmann _send_command Trying to receive 11 bytes of the response. 2020-06-25 18:55:21 DEBUG plugins.viessmann _send_command Received 11 bytes chunk of response as hexstring 0641070101080002e500f8 and as bytes b'\x06A\x07\x01\x01\x08\x00\x02\xe5\x00\xf8' 2020-06-25 18:55:21 DEBUG plugins.viessmann _parse_response Response decoded to: commandcode: 0800, responsedatacode: 1, valuebytecount: 2 2020-06-25 18:55:21 DEBUG plugins.viessmann _parse_response Rawdatabytes formatted: e500 and unformatted: bytearray(b'\xe5\x00')
Beste Grüße
Michael
Einen Kommentar schreiben:
-
Im Moment schon. Vielleicht hilft es, wenn er wieder hängt bzw. die Verbindung nicht mehr da ist.Zitat von Morg Beitrag anzeigenProzess 7629 (python3) unter User smarthome hat /dev/ttyUSB2 geöffnet. Reicht dir das?
Einen Kommentar schreiben:


Einen Kommentar schreiben: