Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Raspi GPIO wird gesetzt, wie Ursache herausfinden?

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    705

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.8k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

Raspi GPIO wird gesetzt, wie Ursache herausfinden?

Scheduled Pinned Locked Moved JavaScript
65 Posts 4 Posters 6.5k Views 3 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • L Laser

    @ticaki 5:22 habe ich durch Suchen nach gpio.22 gefunden. Die Zeit 5:20 habe ich (ungenau) aus dem E-Chart ermittelt. Die Zeit, zu der ungewollt eingeschaltet wurde.

    HomoranH Do not disturb
    HomoranH Do not disturb
    Homoran
    Global Moderator Administrators
    wrote on last edited by
    #37

    @laser dann sieh erst einmal zu, dass sämtliche Leichen verschwinden und das log nicht zugemüllt wird.

    Vorher ergibt es keinen Sinn nach etwas zu suchen, von dem es dann heisst: gibt es nicht mehr!

    kein Support per PN! - Fragen im Forum stellen -
    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
    Das Forum freut sich über eine Spende. Benutzt dazu den Spendenbutton oben rechts. Danke!
    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    L 1 Reply Last reply
    0
    • HomoranH Homoran

      @laser dann sieh erst einmal zu, dass sämtliche Leichen verschwinden und das log nicht zugemüllt wird.

      Vorher ergibt es keinen Sinn nach etwas zu suchen, von dem es dann heisst: gibt es nicht mehr!

      L Offline
      L Offline
      Laser
      wrote on last edited by Laser
      #38

      @homoran bin ich gerade dabei! Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht. Der gpio.22 soll aber bleiben.
      javascript.0.variables.kW-Hoy war ein Schreibfehler nach einer Änderung.

      L HomoranH 2 Replies Last reply
      0
      • L Laser

        @homoran bin ich gerade dabei! Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht. Der gpio.22 soll aber bleiben.
        javascript.0.variables.kW-Hoy war ein Schreibfehler nach einer Änderung.

        L Offline
        L Offline
        Laser
        wrote on last edited by Laser
        #39

        @paul53 Auch unter dem Expertenmodus finde ich nur die Scripte, die ich benötige. Nicht den bösen "Querschießer"

        T 1 Reply Last reply
        0
        • L Laser

          @paul53 Auch unter dem Expertenmodus finde ich nur die Scripte, die ich benötige. Nicht den bösen "Querschießer"

          T Do not disturb
          T Do not disturb
          ticaki
          wrote on last edited by ticaki
          #40

          @laser
          du könntest natürlich noch die anderen Skript posten, dann schaue ich auch mal darüber. Aber erst heute abend, bin jetzt weg :)

          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

          Spenden

          L 1 Reply Last reply
          0
          • T ticaki

            @laser
            du könntest natürlich noch die anderen Skript posten, dann schaue ich auch mal darüber. Aber erst heute abend, bin jetzt weg :)

            L Offline
            L Offline
            Laser
            wrote on last edited by
            #41

            @ticaki hier das 2. Script:
            sicher unelegant, ich bin noch in der Forschungsphase, was ich überhaupt wie machen kann um den maximalen Solarertrag zu erzielen.

            // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
            let ZielwertM  = 80;
            let ZielwertA = 180;
            
             schedule({hour: [19], minute:[10] },   function () {
            setState('rpi2.0.gpio.22.state'/**/,1);  //  1 ist einschalten
            });
             // Abends einen anderen Sollwert zur Einspeisung setzen
            schedule({hour: [19], minute:[15] },   function () {
            //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
            });
            
             // Morgens einen anderen Sollwert zur Einspeisung setzen
            schedule({hour: [02], minute:[15] },   function () { 
            //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
            });
            
            schedule({hour: [09, 23 ], minute:[20] },   function () { 
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
            });
            
            schedule({hour: [09,10 ], minute:[27] },   function () { 
            setState('rpi2.0.gpio.22.state'/**/,0);  //  0 ist ausschalten
            });
            // Anpassung der Einspeiseleistung (getaktet):
            setInterval(Einspeisen,20000 );
            function Einspeisen () {
            let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
            let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
            console.log(" netzeinspeise: " +netzeinspeise);
            
            if (netzeinspeise <= (-0.01)){
            SWLeistung = (SWLeistung -10)  // Wenn eingespeist wird, takte den SW Umrichter runter
            if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
            //console.log("SWL: " + SWLeistung);
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
            };   // Ende if
            
            // Und schnell runterfahren bei großer Leistung ins Netz:
            if (netzeinspeise <= (-0.1)){
            SWLeistung = (SWLeistung -100)  // Wenn eingespeist wird, takte den SW Umrichter runter
            if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
            //console.log("SWL: " + SWLeistung);
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
            };   // Ende if
            
            
            if (netzeinspeise >= (0.01)){
            SWLeistung = (SWLeistung +10)  // Wenn eingespeist wird, takte den SW Umrichter runter
            if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
            console.log("SWL+: " + SWLeistung);
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
            };   // Ende if
            
            // schnell hochfahren bei Verbraucher >100 Watt ein:
            if (netzeinspeise >= (0.1)){
            SWLeistung = (SWLeistung +100)  // Wenn eingespeist wird, takte den SW Umrichter runter
            if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
            console.log("SWL+: " + SWLeistung);
            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
            };   // Ende if
            
            };  //Ende function Einspeisen
            
            paul53P 1 Reply Last reply
            0
            • L Laser

              @ticaki hier das 2. Script:
              sicher unelegant, ich bin noch in der Forschungsphase, was ich überhaupt wie machen kann um den maximalen Solarertrag zu erzielen.

              // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
              let ZielwertM  = 80;
              let ZielwertA = 180;
              
               schedule({hour: [19], minute:[10] },   function () {
              setState('rpi2.0.gpio.22.state'/**/,1);  //  1 ist einschalten
              });
               // Abends einen anderen Sollwert zur Einspeisung setzen
              schedule({hour: [19], minute:[15] },   function () {
              //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
              });
              
               // Morgens einen anderen Sollwert zur Einspeisung setzen
              schedule({hour: [02], minute:[15] },   function () { 
              //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
              });
              
              schedule({hour: [09, 23 ], minute:[20] },   function () { 
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
              });
              
              schedule({hour: [09,10 ], minute:[27] },   function () { 
              setState('rpi2.0.gpio.22.state'/**/,0);  //  0 ist ausschalten
              });
              // Anpassung der Einspeiseleistung (getaktet):
              setInterval(Einspeisen,20000 );
              function Einspeisen () {
              let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
              let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
              console.log(" netzeinspeise: " +netzeinspeise);
              
              if (netzeinspeise <= (-0.01)){
              SWLeistung = (SWLeistung -10)  // Wenn eingespeist wird, takte den SW Umrichter runter
              if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
              //console.log("SWL: " + SWLeistung);
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
              };   // Ende if
              
              // Und schnell runterfahren bei großer Leistung ins Netz:
              if (netzeinspeise <= (-0.1)){
              SWLeistung = (SWLeistung -100)  // Wenn eingespeist wird, takte den SW Umrichter runter
              if (SWLeistung <=10) {SWLeistung = 10};  // Begrenzer
              //console.log("SWL: " + SWLeistung);
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
              };   // Ende if
              
              
              if (netzeinspeise >= (0.01)){
              SWLeistung = (SWLeistung +10)  // Wenn eingespeist wird, takte den SW Umrichter runter
              if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
              console.log("SWL+: " + SWLeistung);
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
              };   // Ende if
              
              // schnell hochfahren bei Verbraucher >100 Watt ein:
              if (netzeinspeise >= (0.1)){
              SWLeistung = (SWLeistung +100)  // Wenn eingespeist wird, takte den SW Umrichter runter
              if (SWLeistung >=230) {SWLeistung = 230};  // Begrenzer
              console.log("SWL+: " + SWLeistung);
              setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
              };   // Ende if
              
              };  //Ende function Einspeisen
              
              paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by paul53
              #42

              @laser
              Zeilen 6 und 25 !!
              Dürfte sich allerdings nicht um 5:21 Uhr auswirken.

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              L 1 Reply Last reply
              0
              • paul53P paul53

                @laser
                Zeilen 6 und 25 !!
                Dürfte sich allerdings nicht um 5:21 Uhr auswirken.

                L Offline
                L Offline
                Laser
                wrote on last edited by Laser
                #43

                @paul53 (6 und 25) Da soll ja auch geschaltet werden. Abends ein und Morgens wieder aus.
                Und wenn die Akkuspannung absinkt (im anderen Script).

                paul53P 1 Reply Last reply
                0
                • L Laser

                  @homoran bin ich gerade dabei! Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht. Der gpio.22 soll aber bleiben.
                  javascript.0.variables.kW-Hoy war ein Schreibfehler nach einer Änderung.

                  HomoranH Do not disturb
                  HomoranH Do not disturb
                  Homoran
                  Global Moderator Administrators
                  wrote on last edited by
                  #44

                  @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                  Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht.

                  dann dürfen diese Skripte aber jetzt nicht laufen.
                  Abgesehen von dem zugemüllten log, lähmt es dein System

                  kein Support per PN! - Fragen im Forum stellen -
                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                  Das Forum freut sich über eine Spende. Benutzt dazu den Spendenbutton oben rechts. Danke!
                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                  1 Reply Last reply
                  0
                  • L Laser

                    @paul53 (6 und 25) Da soll ja auch geschaltet werden. Abends ein und Morgens wieder aus.
                    Und wenn die Akkuspannung absinkt (im anderen Script).

                    paul53P Offline
                    paul53P Offline
                    paul53
                    wrote on last edited by paul53
                    #45

                    @laser sagte: Da soll ja auch geschaltet werden.

                    ... aber nicht mit Zahlen 0 / 1, sondern mit false / true.

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    L 1 Reply Last reply
                    0
                    • paul53P paul53

                      @laser sagte: Da soll ja auch geschaltet werden.

                      ... aber nicht mit Zahlen 0 / 1, sondern mit false / true.

                      L Offline
                      L Offline
                      Laser
                      wrote on last edited by Laser
                      #46

                      @paul53 Das kapiere ich nicht. Wieso funktioniert das überhaupt mit 0 und 1? Ursprünglich hatte ich auch true und false drin. Bis zu einer Fehlermeldung (weiß ich aber nicht mehr genau). Da habe ich in 0 und 1 geändert. Habe das wieder in true/false abgeändert.

                      paul53P 1 Reply Last reply
                      0
                      • L Laser

                        @paul53 Das kapiere ich nicht. Wieso funktioniert das überhaupt mit 0 und 1? Ursprünglich hatte ich auch true und false drin. Bis zu einer Fehlermeldung (weiß ich aber nicht mehr genau). Da habe ich in 0 und 1 geändert. Habe das wieder in true/false abgeändert.

                        paul53P Offline
                        paul53P Offline
                        paul53
                        wrote on last edited by paul53
                        #47

                        @laser sagte: Wieso funktioniert das überhaupt mit 0 und 1?

                        Weil gewandelt wird. Es kommt aber eine Warnung zum falschen Typ.
                        Vielleicht ist ja auch der Datenpunkttyp "boolean" falsch und er muss "number" sein?

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        L 1 Reply Last reply
                        0
                        • paul53P paul53

                          @laser sagte: Wieso funktioniert das überhaupt mit 0 und 1?

                          Weil gewandelt wird. Es kommt aber eine Warnung zum falschen Typ.
                          Vielleicht ist ja auch der Datenpunkttyp "boolean" falsch und er muss "number" sein?

                          L Offline
                          L Offline
                          Laser
                          wrote on last edited by Laser
                          #48

                          @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
                          Das gehe ich noch mal intensiv durch.

                          paul53P T 2 Replies Last reply
                          0
                          • L Laser

                            @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
                            Das gehe ich noch mal intensiv durch.

                            paul53P Offline
                            paul53P Offline
                            paul53
                            wrote on last edited by
                            #49

                            @laser sagte: Das gehe ich noch mal intensiv durch.

                            Auszug aus der Datei main.js des Adapters "rpi2":

                            function writeGpio(port, value) {
                                port = parseInt(port, 10);
                                if (!adapter.config.gpios[port] || !adapter.config.gpios[port].enabled) {
                                    adapter.log.warn('Port ' + port + ' is not writable, because disabled.');
                                    return;
                                } else if (adapter.config.gpios[port].input === 'in' || adapter.config.gpios[port].input === 'true' || adapter.config.gpios[port].input === true) {
                                    return adapter.log.warn('Port ' + port + ' is configured as input and not writable');
                                }
                            
                                if (value === 'true')  value = true;
                                if (value === 'false') value = false;
                                if (value === '0')     value = false;
                                value = !!value;
                            

                            Zahlen werden in Logikwerte gewandelt.

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            1 Reply Last reply
                            1
                            • L Laser

                              @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
                              Das gehe ich noch mal intensiv durch.

                              T Do not disturb
                              T Do not disturb
                              ticaki
                              wrote on last edited by ticaki
                              #50

                              @laser

                              bin doch nicht weg:

                              Em ja, das Skript macht nicht das was du willst.

                              bitte achte beim Schreiben von Skripten auf das Einrücken, das verhindert schon mal ne Menge Fehler

                              {
                                code hier
                                {
                                  code hier
                                  {
                                    code hier
                                  }
                                  code hier
                                }
                                code hier
                              }
                              

                              dann hast du in Deinem Skript sowas

                              if (netzeinspeise <= (-0.01))
                              if (netzeinspeise <= (-0.1))
                              

                              das erste If kannste auch weg lasen da jede Zahl kleiner -0.01 auch kleiner -0.1 ist.

                              du wolltest wohl:

                              if (netzeinspeise <= (-0.01)){
                              } else if (netzeinspeise <= (-0.1)){
                              } else if (netzeinspeise >= (0.1)){
                              } usw.
                              

                              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                              Spenden

                              L 1 Reply Last reply
                              0
                              • T ticaki

                                @laser

                                bin doch nicht weg:

                                Em ja, das Skript macht nicht das was du willst.

                                bitte achte beim Schreiben von Skripten auf das Einrücken, das verhindert schon mal ne Menge Fehler

                                {
                                  code hier
                                  {
                                    code hier
                                    {
                                      code hier
                                    }
                                    code hier
                                  }
                                  code hier
                                }
                                

                                dann hast du in Deinem Skript sowas

                                if (netzeinspeise <= (-0.01))
                                if (netzeinspeise <= (-0.1))
                                

                                das erste If kannste auch weg lasen da jede Zahl kleiner -0.01 auch kleiner -0.1 ist.

                                du wolltest wohl:

                                if (netzeinspeise <= (-0.01)){
                                } else if (netzeinspeise <= (-0.1)){
                                } else if (netzeinspeise >= (0.1)){
                                } usw.
                                
                                L Offline
                                L Offline
                                Laser
                                wrote on last edited by Laser
                                #51

                                @ticaki Damit wollte ich etwas gestaffelt schalten. Wenn eine kleine Netzeinspeisung vorhanden ist, verändere den Wert (Eigenverbrauch) in 5 er Schritten. Wenn ein großer Wert vorliegt, ändere den Wert in großen Schritten. Z.B. wenn morgens der Toaster eingeschaltet wird, passe den Wert schneller an. Sonst in kleinen Schritten. Ist erst mal ein Versuch, ob ich so damit leben kann. Ist beim "Brot-Toasten" am Küchentisch entstanden. Besser geht immer.
                                Das Einrücken muß ich noch verbessern.

                                T 1 Reply Last reply
                                0
                                • L Laser

                                  @ticaki Damit wollte ich etwas gestaffelt schalten. Wenn eine kleine Netzeinspeisung vorhanden ist, verändere den Wert (Eigenverbrauch) in 5 er Schritten. Wenn ein großer Wert vorliegt, ändere den Wert in großen Schritten. Z.B. wenn morgens der Toaster eingeschaltet wird, passe den Wert schneller an. Sonst in kleinen Schritten. Ist erst mal ein Versuch, ob ich so damit leben kann. Ist beim "Brot-Toasten" am Küchentisch entstanden. Besser geht immer.
                                  Das Einrücken muß ich noch verbessern.

                                  T Do not disturb
                                  T Do not disturb
                                  ticaki
                                  wrote on last edited by
                                  #52

                                  @laser
                                  Ich zeige nur nicht optimalen Code auf. Das geht echt nicht darum irgendeine Bewertung vor zu nehmen. :)

                                  Zum Code, eine gestaffelte Abfrage in der nur 1 von x Möglichkeiten ausgewählt werden soll, wird mit If () else if() else usw. aufgebaut, dann trifft immer nur 1 Möglichkeit zu.

                                  Ich dachte du wolltest das erreichen.

                                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                  Spenden

                                  L 1 Reply Last reply
                                  0
                                  • T ticaki

                                    @laser
                                    Ich zeige nur nicht optimalen Code auf. Das geht echt nicht darum irgendeine Bewertung vor zu nehmen. :)

                                    Zum Code, eine gestaffelte Abfrage in der nur 1 von x Möglichkeiten ausgewählt werden soll, wird mit If () else if() else usw. aufgebaut, dann trifft immer nur 1 Möglichkeit zu.

                                    Ich dachte du wolltest das erreichen.

                                    L Offline
                                    L Offline
                                    Laser
                                    wrote on last edited by Laser
                                    #53

                                    @ticaki Werde ich anpassen. Das war wirklich mit der sehr heißen Nadel gestrickt. Das gefällt mir auch nicht.
                                    @Homoran und die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                                    HomoranH 1 Reply Last reply
                                    0
                                    • L Laser

                                      @ticaki Werde ich anpassen. Das war wirklich mit der sehr heißen Nadel gestrickt. Das gefällt mir auch nicht.
                                      @Homoran und die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                                      HomoranH Do not disturb
                                      HomoranH Do not disturb
                                      Homoran
                                      Global Moderator Administrators
                                      wrote on last edited by
                                      #54

                                      @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                      die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                                      dann wird"s auch bald übersichtlicher im Log

                                      kein Support per PN! - Fragen im Forum stellen -
                                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                      Das Forum freut sich über eine Spende. Benutzt dazu den Spendenbutton oben rechts. Danke!
                                      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                      L 1 Reply Last reply
                                      0
                                      • HomoranH Homoran

                                        @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                        die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                                        dann wird"s auch bald übersichtlicher im Log

                                        L Offline
                                        L Offline
                                        Laser
                                        wrote on last edited by Laser
                                        #55

                                        @ticaki ist das so besser?

                                        // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
                                        let ZielwertM  = 80;
                                        let ZielwertA = 180;
                                        
                                        schedule({hour: [19], minute:[10] },   function () {
                                            setState('rpi2.0.gpio.22.state'/**/,true);  //  1 ist einschalten
                                        });
                                         // Abends einen anderen Sollwert zur Einspeisung setzen
                                        schedule({hour: [19], minute:[15] },   function () {
                                        //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
                                        setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
                                        });
                                        
                                         // Morgens einen anderen Sollwert zur Einspeisung setzen
                                        schedule({hour: [02], minute:[15] },   function () { 
                                        //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
                                        setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
                                        });
                                        
                                        schedule({hour: [09, 23 ], minute:[20] },   function () { 
                                        setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
                                        });
                                        
                                        schedule({hour: [09,10 ], minute:[27] },   function () { 
                                        setState('rpi2.0.gpio.22.state'/**/,false);  //  0 ist ausschalten
                                        });
                                        
                                        // Anpassung der Einspeiseleistung (getaktet):
                                        setInterval(Einspeisen,20000 );
                                        function Einspeisen () {
                                            let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
                                            let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
                                            // console.log(" netzeinspeise: " +netzeinspeise);
                                        
                                            if (netzeinspeise <= (-0.01)){
                                            SWLeistung = (SWLeistung -10);  // Wenn eingespeist wird, takte den SW Umrichter runter
                                        
                                            // Und schnell runterfahren bei großer Leistung ins Netz:
                                            } else if (netzeinspeise <= (-0.1)) {
                                            SWLeistung = (SWLeistung -100); // Wenn eingespeist wird, takte den SW Umrichter runter
                                            // hochfahren:
                                            } else if (netzeinspeise >= (0.01)){
                                            SWLeistung = (SWLeistung +10);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                                        
                                            // schnell hochfahren bei Verbraucher >100 Watt ein:
                                            } else if (netzeinspeise >= (0.1)){
                                            SWLeistung = (SWLeistung +100);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                                        
                                            };   // Ende Else if
                                        
                                                if (SWLeistung <=10)  {
                                                SWLeistung = 10;   // Begrenzer
                                                } else if (SWLeistung >=230) {
                                                SWLeistung = 230;  // Begrenzer    
                                                } else {SWLeistung = SWLeistung};
                                                console.log("Sollwert Lstg: " +SWLeistung);
                                                setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                                           
                                        };  //Ende function Einspeisen
                                        
                                        T 1 Reply Last reply
                                        0
                                        • L Laser

                                          @ticaki ist das so besser?

                                          // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
                                          let ZielwertM  = 80;
                                          let ZielwertA = 180;
                                          
                                          schedule({hour: [19], minute:[10] },   function () {
                                              setState('rpi2.0.gpio.22.state'/**/,true);  //  1 ist einschalten
                                          });
                                           // Abends einen anderen Sollwert zur Einspeisung setzen
                                          schedule({hour: [19], minute:[15] },   function () {
                                          //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
                                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
                                          });
                                          
                                           // Morgens einen anderen Sollwert zur Einspeisung setzen
                                          schedule({hour: [02], minute:[15] },   function () { 
                                          //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
                                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
                                          });
                                          
                                          schedule({hour: [09, 23 ], minute:[20] },   function () { 
                                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
                                          });
                                          
                                          schedule({hour: [09,10 ], minute:[27] },   function () { 
                                          setState('rpi2.0.gpio.22.state'/**/,false);  //  0 ist ausschalten
                                          });
                                          
                                          // Anpassung der Einspeiseleistung (getaktet):
                                          setInterval(Einspeisen,20000 );
                                          function Einspeisen () {
                                              let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
                                              let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
                                              // console.log(" netzeinspeise: " +netzeinspeise);
                                          
                                              if (netzeinspeise <= (-0.01)){
                                              SWLeistung = (SWLeistung -10);  // Wenn eingespeist wird, takte den SW Umrichter runter
                                          
                                              // Und schnell runterfahren bei großer Leistung ins Netz:
                                              } else if (netzeinspeise <= (-0.1)) {
                                              SWLeistung = (SWLeistung -100); // Wenn eingespeist wird, takte den SW Umrichter runter
                                              // hochfahren:
                                              } else if (netzeinspeise >= (0.01)){
                                              SWLeistung = (SWLeistung +10);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                                          
                                              // schnell hochfahren bei Verbraucher >100 Watt ein:
                                              } else if (netzeinspeise >= (0.1)){
                                              SWLeistung = (SWLeistung +100);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                                          
                                              };   // Ende Else if
                                          
                                                  if (SWLeistung <=10)  {
                                                  SWLeistung = 10;   // Begrenzer
                                                  } else if (SWLeistung >=230) {
                                                  SWLeistung = 230;  // Begrenzer    
                                                  } else {SWLeistung = SWLeistung};
                                                  console.log("Sollwert Lstg: " +SWLeistung);
                                                  setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                                             
                                          };  //Ende function Einspeisen
                                          
                                          T Do not disturb
                                          T Do not disturb
                                          ticaki
                                          wrote on last edited by ticaki
                                          #56

                                          @laser
                                          👍

                                          Eine kleine Optimierung am Ende: <= 10 braucht nur <10 wenns == 10 ist, ist es ja 10 :) auch für 230

                                          und eine Formsache: ich würde das letzte else auch

                                          } else {
                                            SWLeistung = SWLeistung
                                          }
                                          

                                          so schreiben ist beim lesen einfacher zu sehen das alles abgedeckt ist.

                                          Wobei das letzte else ja keine Funktion hat, dann kannst du es auch erstmal leer lassen

                                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                          Spenden

                                          L 1 Reply Last reply
                                          1

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          297

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe