Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Datenpunkt berechnen

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Datenpunkt berechnen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators last edited by

      Ich versuche mich endlich etwas in javascript einzuarbeiten.

      Im Moment mache ich das erst einmal mit Blockly.

      Seit kurzem habe ich den Smartmeter Adapter installuert und lese über den IR Kopf meinen Zweirichtungszähler aus.

      Dueser liefert als Momentanwert aber die Bilanz aus Solarertrag und Stromverbrauch als Bezug. Positive Werte entsprechen einem höheren Verbrauch im Vergleich zur Produktion, bei negativen Werten ist die Produktion höher als der Verbrauch.

      Ich habe jetzt ein Blockly, das bei Änderung des Wertes aus dem Wechselrichter eine Differenz aus Bilanz und Solarertrag bildet, um den Verbrauch zu berechnen

      on({id: 'hm-rega.0.12885', change: "ne"}, function (obj) {
        var value = obj.state.val;
        var oldValue = obj.oldState.val;
        setState("smartmeter.0.Rechenwerte.Momentanwerte.Verbrauch"/*Verbrauch*/, (getState("smartmeter.0.1-0:16_7_0*255.value").val + getState("hm-rega.0.12885").val), true);
      

      Die zugehörige Grafik sieht so aus
      144_screenshot_20170219-092943.jpg

      Der angebliche Verbrauch schwankt viel zu sehr. Ein Wert von 0 sollte nicht erreicht werden, da meine Heizungspumpe 24/7 läuft 😞

      Zuerst sah es noch schlimmer aus, als ich auf Änderung des Smartmeters getriggert habe, da dieser alle 10 Sekunden, der PV-Wert aber nur alle 60 Sekunden refresht wird. Dieser läuft (noch) als cronjob auf dem Cubie.

      Kann mir jemand erklären, wieso es zu diesen Werten kommt?

      Gruß

      Rainer

      1 Reply Last reply Reply Quote 0
      • blauholsten
        blauholsten Developer last edited by

        Hi,

        Hast du den Code selber geschrieben, oder stammt der aus Blockly?

        Was passiert wenn du es so schreibst?

        on({id: 'hm-rega.0.12885', change: "ne"}, function (obj) {
        var smart = getState("smartmeter.0.1-0:16_7_0*255.value").val;
        var summe = obj.newState.val + smart;
        setState("smartmeter.0.Rechenwerte.Momentanwerte.Verbrauch"/*Verbrauch*/,summe , true);
        });
        

        PS: leider nur am Handy zusammen getippt

        1 Reply Last reply Reply Quote 0
        • Homoran
          Homoran Global Moderator Administrators last edited by

          @blauholsten:

          Hast du den Code selber geschrieben, `
          Der war gut :lol: :lol:

          @blauholsten:

          stammt der aus Blockly? `
          Ja!

          @blauholsten:

          Was passiert wenn du es so schreibst? `
          ich bin js-Legastheniker und traue mich gerade mittels Blockly da ranzuwagen.

          Das wird dann der übernächste Schritt :oops:

          Danke,

          Rainer

          1 Reply Last reply Reply Quote 0
          • blauholsten
            blauholsten Developer last edited by

            Das geht mir ähnlich.

            Meine Vermutung liegt darin, das soweit ich weiß getState asynchron ist. Wenn nun bei deiner Summierung ein get noch nicht fertig ist, ist natürlich die Summe beide Werte eine völlig falsche.

            PS: bitte haut mich hierfür nicht, es kann auch sein das meine These völlig Blödsinn ist :oops:

            1 Reply Last reply Reply Quote 0
            • Y
              ykuendig last edited by

              Lass Dir doch parallel dazu die Werte loggen, dann können wir auch mal selber rechnen.

              1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators last edited by

                @blauholsten:

                bitte haut mich hierfür nicht, es kann auch sein das meine These völlig Blödsinn ist `
                Irgendetwas in der Richtung habe ich auch gedacht.

                Evtl, dass dadurch dass der Cron nur jede Minute auf die CCU schreibt, die per hm-rega dann ggf. nochmals verspätet kommt. Aber:

                ich reagiere doch erst auf die Änderung des PV-AC Wertes ….. 😮

                gut dass wir drüber geschrieben haben 😉

                Klar, der von der CCU gepollte Wert ist inzwischen bis zu 30 Sekunden alt, in der Zeit kann sich der Smarthome-Wert bis zu 3x geändert haben :?:

                Manchmal kommt die Erkenntnis erst beim reden/Schreiben, gemäß dem Motto: Wie soll ich wissen was ich denke, bevor ich höre was ich rede 😛

                Dann muss ich die Abfrage der Solaranlage jetzt doch über den ioBroker Server machen - wieder eine Herausforderung für mich - Schön, es gibt was zu lernen!

                Damit erübrigt sich die folgende Antwort an Yves:
                @ykuendig:

                Lass Dir doch parallel dazu die Werte loggen, dann können wir auch mal selber rechnen. `
                geloggt werden sie sowieso, da ich den Chart schreiben will.

                Wie ich jetzt nativ an diese Werte komme weiss ich nur noch nicht :oops:

                Gruß

                Rainer

                1 Reply Last reply Reply Quote 0
                • Y
                  ykuendig last edited by

                  Hätte an sowas gedacht:

                  on({id: 'hm-rega.0.12885', change: "ne"}, function (obj) {
                  var smart = getState("smartmeter.0.1-0:16_7_0*255.value").val;
                  var summe = obj.newState.val + smart;
                  setState("smartmeter.0.Rechenwerte.Momentanwerte.Verbrauch"/*Verbrauch*/,summe , true);
                  log("Summe: "+summe+" aus Wert 1: "+obj.newState.val+" und Wert 2: "+smart, "info");
                  });
                  
                  1 Reply Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators last edited by

                    Danke Yves,

                    @ykuendig:

                    Hätte an sowas gedacht: `
                    Das werde ich jetzt mal ganz langsam verdauen - geistig in Blöcke umwandeln und dann doch schneller als geplant auf "echtes" js umsteigen.

                    Da war doch was mit kaltem Wasser und so 😉

                    EDIT:

                    Da ist ja schon alles drin, was man irgendwann mal braucht 😉

                    • variablendeklaration: ok!

                    • Funktion: muss ich mich nochmal mit befassen

                    • Datenpunkterstellung: Klasse!

                    • Rechnung: ok!

                    Danke!

                    Gruß

                    Rainer

                    1 Reply Last reply Reply Quote 0
                    • blauholsten
                      blauholsten Developer last edited by

                      @Homoran:

                      Würde mich trotzdem interessieren was passiert wenn du meinen oben geposteten Code in JS probierst.

                      EDIT: Wurde durch ykuendig mit log erweitert.

                      1 Reply Last reply Reply Quote 0
                      • Thisoft
                        Thisoft last edited by

                        Hallo Rainer,

                        ich denke du hast das Problem oben schon richtig erkannt. Du vergleichst einen im schlimmsten Fall fast 1,5 Minuten alten Wert aus der CCU mit dem aktuellen Wert vom Smartmeter-Adapter. Das kann ja höchstens zufällig Sinn ergeben. Und ich denke, du hast auch schon die Lösung erkannt: Die Abfrage der PV-Anlage direkt in ioBroker machen!

                        Keine Angst - Du schaffst das schon, auch mit Javascript. Du weißt doch, da gibt's so ein tolles Forum da wirst Du bei allem geholfen 😉

                        1 Reply Last reply Reply Quote 0
                        • E
                          ein-bayer last edited by

                          Hallo Homoran,

                          vom Gedanken bin ich auch soweit wie du, hab gerade nur nicht soviel Zeit.

                          Ich hab ein bischen überlegt und gegoogelt und hab bei wiki Volkszähler einen Beitrag gefunden:

                          http-//wiki.volkszaehler.org/howto/emh_pv-anlage

                          Darin heisst es :

                          Nun ist neben dem Bezug und der Lieferung auch der Gesamt- und Direktverbrauch von Interesse. Diese Werte können jedoch nicht aus den Zählern ausgelesen werde. Sie können nur durch Berechnung ermittelt werden.

                          Gesamtverbrauch = Bezug + Erzeugung - Lieferung

                          Direktverbrauch = Erzeugung - Lieferung

                          Ich hab an meinen Raspi jetzt einen zweiten sensor dran um den Solarertrag zu loggen. Jetzt braucht´s nur noch ein (einfaches?) script welches die Werte für den Verbrauch berechnet.

                          1 Reply Last reply Reply Quote 0
                          • Y
                            ykuendig last edited by

                            Ich mach das in ungefähr so:

                            // Create Datenpunkte für kalkulierte Werte
                            createState('javascript.0.Solar.Haus.VerbrauchL1', 0, {unit: "W", type: "number", role: "value"});
                            createState('javascript.0.Solar.Haus.VerbrauchL2', 0, {unit: "W", type: "number", role: "value"});
                            createState('javascript.0.Solar.Haus.VerbrauchL3', 0, {unit: "W", type: "number", role: "value"});
                            createState('javascript.0.Solar.Haus.Verbrauch', 0, {unit: "W", type: "number", role: "value"});
                            
                            //Schedule Script Run Modbus Poll
                            schedule("*/15 * * * * *", function (Haus){
                                log("Script Poll_Modbus; Trigger erhalten", "debug");
                            
                            	var Verbrauch = 0;
                            
                            	//Verbrauch berechnen
                            	if (solar1.Inv1P01 > 0) { Verbrauch = solar1.Inv1P01; } else { Verbrauch = 0;}
                            	setState('javascript.0.Solar.Haus.VerbrauchL1', (Verbrauch + solar1.HausP01), true);
                            	if (solar1.Inv1P02 > 0) { Verbrauch = solar1.Inv1P02; } else { Verbrauch = 0;}
                            	setState('javascript.0.Solar.Haus.VerbrauchL2', (Verbrauch + solar1.HausP02), true);
                            	if (solar1.Inv1P03 > 0) { Verbrauch = solar1.Inv1P03; } else { Verbrauch = 0;}
                            	setState('javascript.0.Solar.Haus.VerbrauchL3', (Verbrauch + solar1.HausP03), true);
                            
                            	setState('javascript.0.Solar.Haus.Verbrauch', (Inv1Import + solar1.HausPower), true);
                            });
                            
                            

                            Habe da ordentlich weggekürzt fürs Beispiel, da ich die Daten in diesem Script auch noch erheben muss.

                            Es sollte aber das Prinzip zeigen. Die Berechunung des Geamtverbrauchs kann ich mir sparen, da ich am Zähler plus/minus Leistung ablese. Das ist quasi schon verrechnet.

                            1 Reply Last reply Reply Quote 0
                            • Homoran
                              Homoran Global Moderator Administrators last edited by

                              Ich weiß nicht wie du die Daten vom Solarwechselrichter in ioBroker bekommst.

                              Mein "Problem" besteht darin, dass durch den Umweg vom Raspi über die CCU zurück zu ioBroker bei schnell wechselnder Sonneneinstrahlung tlw. kurzfristig falsche Verbrauchswerte berechnet werden.

                              Mit dem Parsen des Webinterfaces des Wechselrichters in ioBroker komme ich im Moment noch nicht klar.

                              @ein-bayer:

                              verbrauch = Bezug + Erzeugung - Lieferung `
                              Mein Zähler liefert zwar namentlich den Bezug, der kann aber auch negativ sein und enthält daher bereits die Lieferung. Ich nenne den Punkt daher lieber Bilanz.

                              Zu dieser Bilanz addiere ich den Solarertrag (doppeltes - !)

                              und gut ist, ich mache das über Blockly.

                              Gruß

                              Rainer

                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 last edited by

                                @Homoran:

                                Ich weiß nicht wie du die Daten vom Solarwechselrichter in ioBroker bekommst. `
                                Modbus.````
                                //Schedule Script Run Modbus Poll

                                ~~@Homoran:~~ 
                                
                                > Mein "Problem" besteht darin, dass durch den Umweg vom Raspi über die CCU zurück zu ioBroker bei schnell wechselnder Sonneneinstrahlung tlw. kurzfristig falsche Verbrauchswerte berechnet werden. `  
                                Wie bekommst Du die Werte in die CCU ?
                                1 Reply Last reply Reply Quote 0
                                • Homoran
                                  Homoran Global Moderator Administrators last edited by

                                  Hallo Paul,

                                  ich hätte nur gerne einen Schubs in die Richtung, in die ich gehen muss.

                                  Wenn ich an einem realen Beispiel mit einem gewissen "Leidensdruck" arbeite, denke ich kann ich besser lernen, als wenn man nur etwas abtippt.

                                  @paul53:

                                  Modbus. `
                                  nein, höchstens S0

                                  Piko 5.5

                                  @paul53:

                                  Wie bekommst Du die Werte in die CCU ? `
                                  Damals auch mit cut and paste (Das muss ein Ende haben 😉 )

                                  als shell-script auf dem Pi/Cubie…

                                  #!/bin/bash
                                  # http://homematic-forum.de/forum/viewtopic.php?p=131956#p131956
                                  #
                                  #   define common parameters for wget
                                  #
                                  COMMONWGETARGS="-q -O - --timeout=10"
                                  
                                  wget $COMMONWGETARGS --http-user=USERNAME --http-password=MySecurePassword "http://192.168.138.54/index.fhtml" | sed -e "s/nbsp/nbsp;/g" | sed -e "s/nbsp;;/nbsp;/g" | sed -e "s/\ //g" | html2text | tr -s " \t\r\n" | sed -e "s/^ //" | sed -e "s/x x x/0/g" >/tmp/power-inverter1.values
                                  PHOTOVOLTAICS_DC1U=$( cat /tmp/power-inverter1.values | grep Spannung | head -1 | cut -f2 -d" " )
                                  PHOTOVOLTAICS_DC2U=$( cat /tmp/power-inverter1.values | grep Spannung | head -2 | tail -1 | cut -f2 -d" " )
                                  PHOTOVOLTAICS_DC1I=$( cat /tmp/power-inverter1.values | grep Strom | head -1 | cut -f2 -d" " | awk '{printf "%d\n",$1*1000}' )
                                  PHOTOVOLTAICS_DC2I=$( cat /tmp/power-inverter1.values | grep Strom | head -2 | tail -1 | cut -f2 -d" " | awk '{printf "%d\n",$1*1000}' )
                                  PHOTOVOLTAICS_DC1P=$(( $PHOTOVOLTAICS_DC1U * $PHOTOVOLTAICS_DC1I / 1000 ))
                                  PHOTOVOLTAICS_DC2P=$(( $PHOTOVOLTAICS_DC2U * $PHOTOVOLTAICS_DC2I / 1000 ))
                                  
                                  PHOTOVOLTAICS_ACCURP=$( cat /tmp/power-inverter1.values | grep aktuell | cut -f2 -d" " )
                                  PHOTOVOLTAICS_ACTOTP=$( cat /tmp/power-inverter1.values | grep Gesamtenergie | cut -f5 -d" " )
                                  PHOTOVOLTAICS_DAILYP=$( cat /tmp/power-inverter1.values | grep Tagesenergie | cut -f2 -d" " )
                                  
                                  #
                                  #   update the system variables in the HomeMatic
                                  #
                                  wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DC1&value=$PHOTOVOLTAICS_DC1P"
                                  wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DC2&value=$PHOTOVOLTAICS_DC2P"
                                  wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.AC&value=$PHOTOVOLTAICS_ACCURP"
                                  wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DAILYP&value=$PHOTOVOLTAICS_DAILYP"
                                  wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.TOTP&value=$PHOTOVOLTAICS_ACTOTP"
                                  

                                  Davon verstehe ich auch nichts.

                                  Inzwischen habe ich es mit node-red hinbekommen die Website mit den Credentials aufzurufen und den Quelltext herunterzuladen,

                                  auch ein split nachbrachte schon mal einige brauchbare Blöcke.

                                  Hier fehlt mir im Moment die Weiterverarbeitung von Arrays.

                                  Danke für deine Hilfe

                                  Rainer

                                  1 Reply Last reply Reply Quote 0
                                  • E
                                    ein-bayer last edited by

                                    solardaten in iobroker => 2. ir sensor von volkszähler, und iobroker 2. instanz von smartmeter
                                    1342_bildschirmfoto_2017-02-19_um_17.59.54.png

                                    1 Reply Last reply Reply Quote 0
                                    • Y
                                      ykuendig last edited by

                                      @Homoran; Hab zwar nicht den ganzen Artikel gelesen. aber hat nicht Paul schon hier: http://forum.iobroker.net/viewtopic.php … 5.5#p48206 das Script in JS übersetzt?

                                      Geht das nicht?

                                      1 Reply Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators last edited by

                                        @ykuendig:

                                        aber hat nicht Paul schon hier: viewtopic.php?f=21&t=4888&p=48710&hilit=Piko+5.5#p48206 das Script in JS übersetzt? `
                                        Das ist die Nach-Nachfolger Firmware. Dagegen sieht meine aus wie DOS im Vergleich zu Win10

                                        Gruß

                                        Rainer

                                        1 Reply Last reply Reply Quote 0
                                        • paul53
                                          paul53 last edited by

                                          An dem shell script sehe ich, dass offenbar die Daten aus der Datei "/tmp/power-inverter1.values" geholt werden und mit grep gesucht wird.

                                          Zur Anregung: In Javacsript kann man https://github.com/ioBroker/ioBroker.javascript#readfile und falls es eine Textdatei ist, mit https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/indexOf im Text suchen und mit https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/substr Teilzeichenketten ermitteln.

                                          1 Reply Last reply Reply Quote 0
                                          • Homoran
                                            Homoran Global Moderator Administrators last edited by

                                            Hallo Paul,

                                            @paul53:

                                            dass offenbar die Daten aus der Datei "/tmp/power-inverter1.values" geholt werden und mit grep gesucht wird. `
                                            da werden sie in Zeile 8 erst einmal hingeschrieben 😞

                                            @paul53:

                                            falls es eine Textdatei ist, `
                                            leider nein, ist eine HTML-Datei.

                                            ! ````
                                            ! <title>PV Webserver</title>
                                            ! <form method="post" action="">
                                            ! | |
                                            ! | |

                                            PIKO 5.5

                                            ! Helios (255)
                                            |
                                            |
                                            ! |

                                            ! * * *
                                            ! |
                                            ! | |
                                            ! |

                                            AC-Leistung |
                                              |

                                            Energie |

                                            ! | |
                                            ! |

                                            aktuell |

                                            x x x  |
                                              W |

                                            Gesamtenergie |

                                            23117 |
                                              kWh |
                                              |

                                            ! | |
                                            ! |

                                            |

                                            |
                                              |

                                            Tagesenergie |

                                            7.47 |
                                              kWh |
                                              |

                                            ! | |
                                            ! |

                                            Status |

                                            Aus |
                                              |

                                            ! | |
                                            ! |
                                            ! |

                                            ! * * *
                                            ! |
                                            ! | |
                                            ! |
                                            ! |

                                            PV-Generator |
                                              |

                                            Ausgangsleistung |
                                              |
                                              |

                                            ! | |
                                            ! |

                                            <u>String 1</u> |
                                              |
                                              |

                                            <u>L1</u> |
                                              |
                                              |
                                              |

                                            ! |

                                            Spannung |

                                            x x x  |
                                              V |

                                            Spannung |

                                            x x x  |
                                              V |
                                              |

                                            ! | |
                                            !   |

                                            Strom |

                                            x x x  |
                                              A |

                                            Leistung |

                                            x x x  |
                                              W |
                                              |

                                            ! | |
                                            ! |

                                            <u>String 2</u> |
                                              |
                                              |

                                            <u>L2</u> |
                                              |
                                              |
                                              |

                                            ! |

                                            Spannung |

                                            x x x  |
                                              V |

                                            Spannung |

                                            x x x  |
                                              V |
                                              |

                                            ! | |
                                            !   |

                                            Strom |

                                            x x x  |
                                              A |

                                            Leistung |

                                            x x x  |
                                              W |
                                              |

                                            ! | |
                                            ! |

                                            <u>String 3</u> |
                                              |
                                              |

                                            <u>L3</u> |
                                              |
                                              |
                                              |

                                            ! |

                                            Spannung |

                                            x x x  |

                                            V |

                                            Spannung |

                                            x x x  |
                                              V |
                                              |

                                            ! | |
                                            !   |

                                            Strom |

                                            x x x  |

                                            A |

                                            Leistung |

                                            x x x  |
                                              W |
                                              |

                                            ! | |
                                            ! |
                                            ! | |

                                            ! * * *
                                            ! |
                                            ! | |
                                            ! |
                                            ! | |
                                            RS485 Kommunikation |
                                            ! | |
                                            ! | |
                                            Wechselrichter |
                                            | |
                                            ! * * *
                                            ! | |
                                            ! | |

                                            Historie

                                            Infoseite |

                                            Einstellungen

                                            ! </form>
                                            ! ````

                                            im shellscript wird die anscheinend mit dem Paket html2text in Text umgewandelt (?)

                                            Das nach dem o.a. Split herausgegebene zweite Elemet des Arrays, enthält die aktuelle Stromproduktion:

                                            msg.payload : string[116]
                                            "↵ aktuell↵↵ x x x ↵  W↵"
                                            

                                            Jetzt nur noch x x x, da ich meine Lunarmodule noch nicht montiert habe 😉

                                            Gruß

                                            Rainer

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            561
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            7
                                            70
                                            12459
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo