Ankündigung

Einklappen
Keine Ankündigung bisher.

Viessmann Plugin Neuentwicklung Python Hilfe

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • thesing
    antwortet
    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?

    Einen Kommentar schreiben:


  • loeserman
    antwortet
    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:


  • loeserman
    antwortet
    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:


  • Morg
    antwortet
    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:


  • Msinn
    antwortet
    Zitat von loeserman Beitrag anzeigen
    eine Einrückungen mit in dieses Forum hier.
    Doch!, den Thread dazu hatte ich erwähnt.

    Einen Kommentar schreiben:


  • loeserman
    antwortet
    Zitat von Msinn Beitrag anzeigen
    Oder hast Du die yaml Dateien wirklich ohne Einrückungen erstellt?
    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.

    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:


  • Msinn
    antwortet
    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:


  • loeserman
    antwortet
    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

    Code:
    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'
        }
    }
    Anschließend habe ich eine item.yaml dafür erstellt

    Code:
    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
    Und dann natürlich noch die Plugins.yaml angepasst

    Code:
    viessmann:
        plugin_name: viessmann
        plugin_enabled: true
        protocol: P300
        plugin_name: viessmann
        heating_type: V200H01C
        serialport: /dev/ttyUSB_HEIZUNG
    Starte ich das ganze erhalte ich folgende Fehlermeldungen. Habt ihr eine Idee, was ich vergessen habe?

    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'
    Er erkennt kein einiges Item laut commandset. Ist glaube ich was einfaches, aber ich sehe es einfach nicht …

    Danke euch!
    Zuletzt geändert von loeserman; 27.06.2020, 12:03.

    Einen Kommentar schreiben:


  • Sisamiwe
    antwortet
    Zitat von loeserman Beitrag anzeigen
    Stimmt, da war noch etwas. Okay ich versuche das mal bei mir einzubinden. Wo finde ich denn die letzte Version?
    Konntest Du schon testen?

    Einen Kommentar schreiben:


  • Sisamiwe
    antwortet
    Zitat von Morg Beitrag anzeigen
    Kannst du gern noch mal probieren, aber wenn ich sehe, wie der im Moment auf Fehler reagiert, dürfte das keine Überraschungen mehr geben
    Hab ich!
    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
    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''
    Irgendwann ist das Communication_init abgelaufen, es wird versucht die Comminication neu zu etablieren:
    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!.
    Heizung wieder an, dann klappt auch das Communication_init und es geht normal weiter.
    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
    Klappt also.

    Zitat von Morg Beitrag anzeigen
    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?)
    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.

    Wieder ein Stück näher am Release.


    Einen Kommentar schreiben:


  • Morg
    antwortet
    Zitat von Sisamiwe Beitrag anzeigen
    Woran 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
    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?)
    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...

    Ich melde mich wieder, wenn ich die Heizung mal aus hatte.
    Kannst du gern noch mal probieren, aber wenn ich sehe, wie der im Moment auf Fehler reagiert, dürfte das keine Überraschungen mehr geben

    Einen Kommentar schreiben:


  • Sisamiwe
    antwortet
    Zitat von Morg Beitrag anzeigen
    Du hast aber die Heizung nicht ausgehabt?
    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.
    Ich schalte die Heizung dann mal aus und schaue was passiert.

    Zitat von Morg Beitrag anzeigen
    Irgendwo scheint bei dir noch der Wurm drin, den EA-Fehler hatte ich noch nie
    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 anzeigen
    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.
    Woran 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
    Zitat von Morg Beitrag anzeigen
    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.
    In den letzten Versionen hat der Neuaufbau der Verbindung nicht mehr geklappt. Nun scheint es wieder zu funktionieren.

    Ich melde mich wieder, wenn ich die Heizung mal aus hatte.

    Einen Kommentar schreiben:


  • Morg
    antwortet
    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:


  • Sisamiwe
    antwortet
    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:
    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.
    details:
    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
    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 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')
    Ich beobachte weiter.

    Beste Grüße
    Michael

    Einen Kommentar schreiben:


  • Sisamiwe
    antwortet
    Zitat von Morg Beitrag anzeigen
    Prozess 7629 (python3) unter User smarthome hat /dev/ttyUSB2 geöffnet. Reicht dir das?
    Im Moment schon. Vielleicht hilft es, wenn er wieder hängt bzw. die Verbindung nicht mehr da ist.

    Einen Kommentar schreiben:

Lädt...
X